1265 lines
55 KiB
JavaScript
1265 lines
55 KiB
JavaScript
|
import { c as v, s as Ce, g as ve, a as Oe, b as Pe, C as Ae, D as Ge, l as B, f as D, E as Ie, H as Se, j as Ne, A as He, I as Be } from "./mermaid-9f2aa176.js";
|
||
|
var me = function() {
|
||
|
var r = function(G, o, u, d) {
|
||
|
for (u = u || {}, d = G.length; d--; u[G[d]] = o)
|
||
|
;
|
||
|
return u;
|
||
|
}, n = [1, 3], l = [1, 6], h = [1, 4], i = [1, 5], c = [2, 5], p = [1, 12], m = [5, 7, 13, 19, 21, 23, 24, 26, 28, 31, 37, 40, 47], x = [7, 13, 19, 21, 23, 24, 26, 28, 31, 37, 40], y = [7, 12, 13, 19, 21, 23, 24, 26, 28, 31, 37, 40], a = [7, 13, 47], R = [1, 42], _ = [1, 41], b = [7, 13, 29, 32, 35, 38, 47], f = [1, 55], k = [1, 56], g = [1, 57], E = [7, 13, 32, 35, 42, 47], z = {
|
||
|
trace: function() {
|
||
|
},
|
||
|
yy: {},
|
||
|
symbols_: { error: 2, start: 3, eol: 4, GG: 5, document: 6, EOF: 7, ":": 8, DIR: 9, options: 10, body: 11, OPT: 12, NL: 13, line: 14, statement: 15, commitStatement: 16, mergeStatement: 17, cherryPickStatement: 18, acc_title: 19, acc_title_value: 20, acc_descr: 21, acc_descr_value: 22, acc_descr_multiline_value: 23, section: 24, branchStatement: 25, CHECKOUT: 26, ref: 27, BRANCH: 28, ORDER: 29, NUM: 30, CHERRY_PICK: 31, COMMIT_ID: 32, STR: 33, PARENT_COMMIT: 34, COMMIT_TAG: 35, EMPTYSTR: 36, MERGE: 37, COMMIT_TYPE: 38, commitType: 39, COMMIT: 40, commit_arg: 41, COMMIT_MSG: 42, NORMAL: 43, REVERSE: 44, HIGHLIGHT: 45, ID: 46, ";": 47, $accept: 0, $end: 1 },
|
||
|
terminals_: { 2: "error", 5: "GG", 7: "EOF", 8: ":", 9: "DIR", 12: "OPT", 13: "NL", 19: "acc_title", 20: "acc_title_value", 21: "acc_descr", 22: "acc_descr_value", 23: "acc_descr_multiline_value", 24: "section", 26: "CHECKOUT", 28: "BRANCH", 29: "ORDER", 30: "NUM", 31: "CHERRY_PICK", 32: "COMMIT_ID", 33: "STR", 34: "PARENT_COMMIT", 35: "COMMIT_TAG", 36: "EMPTYSTR", 37: "MERGE", 38: "COMMIT_TYPE", 40: "COMMIT", 42: "COMMIT_MSG", 43: "NORMAL", 44: "REVERSE", 45: "HIGHLIGHT", 46: "ID", 47: ";" },
|
||
|
productions_: [0, [3, 2], [3, 3], [3, 4], [3, 5], [6, 0], [6, 2], [10, 2], [10, 1], [11, 0], [11, 2], [14, 2], [14, 1], [15, 1], [15, 1], [15, 1], [15, 2], [15, 2], [15, 1], [15, 1], [15, 1], [15, 2], [25, 2], [25, 4], [18, 3], [18, 5], [18, 5], [18, 7], [18, 7], [18, 5], [18, 5], [18, 5], [18, 7], [18, 7], [18, 7], [18, 7], [17, 2], [17, 4], [17, 4], [17, 4], [17, 6], [17, 6], [17, 6], [17, 6], [17, 6], [17, 6], [17, 8], [17, 8], [17, 8], [17, 8], [17, 8], [17, 8], [16, 2], [16, 3], [16, 3], [16, 5], [16, 5], [16, 3], [16, 5], [16, 5], [16, 5], [16, 5], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 3], [16, 5], [16, 5], [16, 5], [16, 5], [16, 5], [16, 5], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 7], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [16, 9], [41, 0], [41, 1], [39, 1], [39, 1], [39, 1], [27, 1], [27, 1], [4, 1], [4, 1], [4, 1]],
|
||
|
performAction: function(o, u, d, s, T, e, X) {
|
||
|
var t = e.length - 1;
|
||
|
switch (T) {
|
||
|
case 2:
|
||
|
return e[t];
|
||
|
case 3:
|
||
|
return e[t - 1];
|
||
|
case 4:
|
||
|
return s.setDirection(e[t - 3]), e[t - 1];
|
||
|
case 6:
|
||
|
s.setOptions(e[t - 1]), this.$ = e[t];
|
||
|
break;
|
||
|
case 7:
|
||
|
e[t - 1] += e[t], this.$ = e[t - 1];
|
||
|
break;
|
||
|
case 9:
|
||
|
this.$ = [];
|
||
|
break;
|
||
|
case 10:
|
||
|
e[t - 1].push(e[t]), this.$ = e[t - 1];
|
||
|
break;
|
||
|
case 11:
|
||
|
this.$ = e[t - 1];
|
||
|
break;
|
||
|
case 16:
|
||
|
this.$ = e[t].trim(), s.setAccTitle(this.$);
|
||
|
break;
|
||
|
case 17:
|
||
|
case 18:
|
||
|
this.$ = e[t].trim(), s.setAccDescription(this.$);
|
||
|
break;
|
||
|
case 19:
|
||
|
s.addSection(e[t].substr(8)), this.$ = e[t].substr(8);
|
||
|
break;
|
||
|
case 21:
|
||
|
s.checkout(e[t]);
|
||
|
break;
|
||
|
case 22:
|
||
|
s.branch(e[t]);
|
||
|
break;
|
||
|
case 23:
|
||
|
s.branch(e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 24:
|
||
|
s.cherryPick(e[t], "", void 0);
|
||
|
break;
|
||
|
case 25:
|
||
|
s.cherryPick(e[t - 2], "", void 0, e[t]);
|
||
|
break;
|
||
|
case 26:
|
||
|
s.cherryPick(e[t - 2], "", e[t]);
|
||
|
break;
|
||
|
case 27:
|
||
|
s.cherryPick(e[t - 4], "", e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 28:
|
||
|
s.cherryPick(e[t - 4], "", e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 29:
|
||
|
s.cherryPick(e[t], "", e[t - 2]);
|
||
|
break;
|
||
|
case 30:
|
||
|
s.cherryPick(e[t], "", "");
|
||
|
break;
|
||
|
case 31:
|
||
|
s.cherryPick(e[t - 2], "", "");
|
||
|
break;
|
||
|
case 32:
|
||
|
s.cherryPick(e[t - 4], "", "", e[t - 2]);
|
||
|
break;
|
||
|
case 33:
|
||
|
s.cherryPick(e[t - 4], "", "", e[t]);
|
||
|
break;
|
||
|
case 34:
|
||
|
s.cherryPick(e[t - 2], "", e[t - 4], e[t]);
|
||
|
break;
|
||
|
case 35:
|
||
|
s.cherryPick(e[t - 2], "", "", e[t]);
|
||
|
break;
|
||
|
case 36:
|
||
|
s.merge(e[t], "", "", "");
|
||
|
break;
|
||
|
case 37:
|
||
|
s.merge(e[t - 2], e[t], "", "");
|
||
|
break;
|
||
|
case 38:
|
||
|
s.merge(e[t - 2], "", e[t], "");
|
||
|
break;
|
||
|
case 39:
|
||
|
s.merge(e[t - 2], "", "", e[t]);
|
||
|
break;
|
||
|
case 40:
|
||
|
s.merge(e[t - 4], e[t], "", e[t - 2]);
|
||
|
break;
|
||
|
case 41:
|
||
|
s.merge(e[t - 4], "", e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 42:
|
||
|
s.merge(e[t - 4], "", e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 43:
|
||
|
s.merge(e[t - 4], e[t - 2], e[t], "");
|
||
|
break;
|
||
|
case 44:
|
||
|
s.merge(e[t - 4], e[t - 2], "", e[t]);
|
||
|
break;
|
||
|
case 45:
|
||
|
s.merge(e[t - 4], e[t], e[t - 2], "");
|
||
|
break;
|
||
|
case 46:
|
||
|
s.merge(e[t - 6], e[t - 4], e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 47:
|
||
|
s.merge(e[t - 6], e[t], e[t - 4], e[t - 2]);
|
||
|
break;
|
||
|
case 48:
|
||
|
s.merge(e[t - 6], e[t - 4], e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 49:
|
||
|
s.merge(e[t - 6], e[t - 2], e[t - 4], e[t]);
|
||
|
break;
|
||
|
case 50:
|
||
|
s.merge(e[t - 6], e[t], e[t - 2], e[t - 4]);
|
||
|
break;
|
||
|
case 51:
|
||
|
s.merge(e[t - 6], e[t - 2], e[t], e[t - 4]);
|
||
|
break;
|
||
|
case 52:
|
||
|
s.commit(e[t]);
|
||
|
break;
|
||
|
case 53:
|
||
|
s.commit("", "", s.commitType.NORMAL, e[t]);
|
||
|
break;
|
||
|
case 54:
|
||
|
s.commit("", "", e[t], "");
|
||
|
break;
|
||
|
case 55:
|
||
|
s.commit("", "", e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 56:
|
||
|
s.commit("", "", e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 57:
|
||
|
s.commit("", e[t], s.commitType.NORMAL, "");
|
||
|
break;
|
||
|
case 58:
|
||
|
s.commit("", e[t - 2], s.commitType.NORMAL, e[t]);
|
||
|
break;
|
||
|
case 59:
|
||
|
s.commit("", e[t], s.commitType.NORMAL, e[t - 2]);
|
||
|
break;
|
||
|
case 60:
|
||
|
s.commit("", e[t - 2], e[t], "");
|
||
|
break;
|
||
|
case 61:
|
||
|
s.commit("", e[t], e[t - 2], "");
|
||
|
break;
|
||
|
case 62:
|
||
|
s.commit("", e[t - 4], e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 63:
|
||
|
s.commit("", e[t - 4], e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 64:
|
||
|
s.commit("", e[t - 2], e[t - 4], e[t]);
|
||
|
break;
|
||
|
case 65:
|
||
|
s.commit("", e[t], e[t - 4], e[t - 2]);
|
||
|
break;
|
||
|
case 66:
|
||
|
s.commit("", e[t], e[t - 2], e[t - 4]);
|
||
|
break;
|
||
|
case 67:
|
||
|
s.commit("", e[t - 2], e[t], e[t - 4]);
|
||
|
break;
|
||
|
case 68:
|
||
|
s.commit(e[t], "", s.commitType.NORMAL, "");
|
||
|
break;
|
||
|
case 69:
|
||
|
s.commit(e[t], "", s.commitType.NORMAL, e[t - 2]);
|
||
|
break;
|
||
|
case 70:
|
||
|
s.commit(e[t - 2], "", s.commitType.NORMAL, e[t]);
|
||
|
break;
|
||
|
case 71:
|
||
|
s.commit(e[t - 2], "", e[t], "");
|
||
|
break;
|
||
|
case 72:
|
||
|
s.commit(e[t], "", e[t - 2], "");
|
||
|
break;
|
||
|
case 73:
|
||
|
s.commit(e[t], e[t - 2], s.commitType.NORMAL, "");
|
||
|
break;
|
||
|
case 74:
|
||
|
s.commit(e[t - 2], e[t], s.commitType.NORMAL, "");
|
||
|
break;
|
||
|
case 75:
|
||
|
s.commit(e[t - 4], "", e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 76:
|
||
|
s.commit(e[t - 4], "", e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 77:
|
||
|
s.commit(e[t - 2], "", e[t - 4], e[t]);
|
||
|
break;
|
||
|
case 78:
|
||
|
s.commit(e[t], "", e[t - 4], e[t - 2]);
|
||
|
break;
|
||
|
case 79:
|
||
|
s.commit(e[t], "", e[t - 2], e[t - 4]);
|
||
|
break;
|
||
|
case 80:
|
||
|
s.commit(e[t - 2], "", e[t], e[t - 4]);
|
||
|
break;
|
||
|
case 81:
|
||
|
s.commit(e[t - 4], e[t], e[t - 2], "");
|
||
|
break;
|
||
|
case 82:
|
||
|
s.commit(e[t - 4], e[t - 2], e[t], "");
|
||
|
break;
|
||
|
case 83:
|
||
|
s.commit(e[t - 2], e[t], e[t - 4], "");
|
||
|
break;
|
||
|
case 84:
|
||
|
s.commit(e[t], e[t - 2], e[t - 4], "");
|
||
|
break;
|
||
|
case 85:
|
||
|
s.commit(e[t], e[t - 4], e[t - 2], "");
|
||
|
break;
|
||
|
case 86:
|
||
|
s.commit(e[t - 2], e[t - 4], e[t], "");
|
||
|
break;
|
||
|
case 87:
|
||
|
s.commit(e[t - 4], e[t], s.commitType.NORMAL, e[t - 2]);
|
||
|
break;
|
||
|
case 88:
|
||
|
s.commit(e[t - 4], e[t - 2], s.commitType.NORMAL, e[t]);
|
||
|
break;
|
||
|
case 89:
|
||
|
s.commit(e[t - 2], e[t], s.commitType.NORMAL, e[t - 4]);
|
||
|
break;
|
||
|
case 90:
|
||
|
s.commit(e[t], e[t - 2], s.commitType.NORMAL, e[t - 4]);
|
||
|
break;
|
||
|
case 91:
|
||
|
s.commit(e[t], e[t - 4], s.commitType.NORMAL, e[t - 2]);
|
||
|
break;
|
||
|
case 92:
|
||
|
s.commit(e[t - 2], e[t - 4], s.commitType.NORMAL, e[t]);
|
||
|
break;
|
||
|
case 93:
|
||
|
s.commit(e[t - 6], e[t - 4], e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 94:
|
||
|
s.commit(e[t - 6], e[t - 4], e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 95:
|
||
|
s.commit(e[t - 6], e[t - 2], e[t - 4], e[t]);
|
||
|
break;
|
||
|
case 96:
|
||
|
s.commit(e[t - 6], e[t], e[t - 4], e[t - 2]);
|
||
|
break;
|
||
|
case 97:
|
||
|
s.commit(e[t - 6], e[t - 2], e[t], e[t - 4]);
|
||
|
break;
|
||
|
case 98:
|
||
|
s.commit(e[t - 6], e[t], e[t - 2], e[t - 4]);
|
||
|
break;
|
||
|
case 99:
|
||
|
s.commit(e[t - 4], e[t - 6], e[t - 2], e[t]);
|
||
|
break;
|
||
|
case 100:
|
||
|
s.commit(e[t - 4], e[t - 6], e[t], e[t - 2]);
|
||
|
break;
|
||
|
case 101:
|
||
|
s.commit(e[t - 2], e[t - 6], e[t - 4], e[t]);
|
||
|
break;
|
||
|
case 102:
|
||
|
s.commit(e[t], e[t - 6], e[t - 4], e[t - 2]);
|
||
|
break;
|
||
|
case 103:
|
||
|
s.commit(e[t - 2], e[t - 6], e[t], e[t - 4]);
|
||
|
break;
|
||
|
case 104:
|
||
|
s.commit(e[t], e[t - 6], e[t - 2], e[t - 4]);
|
||
|
break;
|
||
|
case 105:
|
||
|
s.commit(e[t], e[t - 4], e[t - 2], e[t - 6]);
|
||
|
break;
|
||
|
case 106:
|
||
|
s.commit(e[t - 2], e[t - 4], e[t], e[t - 6]);
|
||
|
break;
|
||
|
case 107:
|
||
|
s.commit(e[t], e[t - 2], e[t - 4], e[t - 6]);
|
||
|
break;
|
||
|
case 108:
|
||
|
s.commit(e[t - 2], e[t], e[t - 4], e[t - 6]);
|
||
|
break;
|
||
|
case 109:
|
||
|
s.commit(e[t - 4], e[t - 2], e[t], e[t - 6]);
|
||
|
break;
|
||
|
case 110:
|
||
|
s.commit(e[t - 4], e[t], e[t - 2], e[t - 6]);
|
||
|
break;
|
||
|
case 111:
|
||
|
s.commit(e[t - 2], e[t - 4], e[t - 6], e[t]);
|
||
|
break;
|
||
|
case 112:
|
||
|
s.commit(e[t], e[t - 4], e[t - 6], e[t - 2]);
|
||
|
break;
|
||
|
case 113:
|
||
|
s.commit(e[t - 2], e[t], e[t - 6], e[t - 4]);
|
||
|
break;
|
||
|
case 114:
|
||
|
s.commit(e[t], e[t - 2], e[t - 6], e[t - 4]);
|
||
|
break;
|
||
|
case 115:
|
||
|
s.commit(e[t - 4], e[t - 2], e[t - 6], e[t]);
|
||
|
break;
|
||
|
case 116:
|
||
|
s.commit(e[t - 4], e[t], e[t - 6], e[t - 2]);
|
||
|
break;
|
||
|
case 117:
|
||
|
this.$ = "";
|
||
|
break;
|
||
|
case 118:
|
||
|
this.$ = e[t];
|
||
|
break;
|
||
|
case 119:
|
||
|
this.$ = s.commitType.NORMAL;
|
||
|
break;
|
||
|
case 120:
|
||
|
this.$ = s.commitType.REVERSE;
|
||
|
break;
|
||
|
case 121:
|
||
|
this.$ = s.commitType.HIGHLIGHT;
|
||
|
break;
|
||
|
}
|
||
|
},
|
||
|
table: [{ 3: 1, 4: 2, 5: n, 7: l, 13: h, 47: i }, { 1: [3] }, { 3: 7, 4: 2, 5: n, 7: l, 13: h, 47: i }, { 6: 8, 7: c, 8: [1, 9], 9: [1, 10], 10: 11, 13: p }, r(m, [2, 124]), r(m, [2, 125]), r(m, [2, 126]), { 1: [2, 1] }, { 7: [1, 13] }, { 6: 14, 7: c, 10: 11, 13: p }, { 8: [1, 15] }, r(x, [2, 9], { 11: 16, 12: [1, 17] }), r(y, [2, 8]), { 1: [2, 2] }, { 7: [1, 18] }, { 6: 19, 7: c, 10: 11, 13: p }, { 7: [2, 6], 13: [1, 22], 14: 20, 15: 21, 16: 23, 17: 24, 18: 25, 19: [1, 26], 21: [1, 27], 23: [1, 28], 24: [1, 29], 25: 30, 26: [1, 31], 28: [1, 35], 31: [1, 34], 37: [1, 33], 40: [1, 32] }, r(y, [2, 7]), { 1: [2, 3] }, { 7: [1, 36] }, r(x, [2, 10]), { 4: 37, 7: l, 13: h, 47: i }, r(x, [2, 12]), r(a, [2, 13]), r(a, [2, 14]), r(a, [2, 15]), { 20: [1, 38] }, { 22: [1, 39] }, r(a, [2, 18]), r(a, [2, 19]), r(a, [2, 20]), { 27: 40, 33: R, 46: _ }, r(a, [2, 117], { 41: 43, 32: [1, 46], 33: [1, 48], 35: [1, 44], 38: [1, 45], 42: [1, 47] }), { 27: 49, 33: R, 46: _ }, { 32: [1, 50], 35: [1, 51] }, { 27: 52, 33: R, 46: _ }, { 1: [2, 4] }, r(x, [2, 11]), r(a, [2, 16]), r(a, [2, 17]), r(a, [2, 21]), r(b, [2, 122]), r(b, [2, 123]), r(a, [2, 52]), { 33: [1, 53] }, { 39: 54, 43: f, 44: k, 45: g }, { 33: [1, 58] }, { 33: [1, 59] }, r(a, [2, 118]), r(a, [2, 36], { 32: [1, 60], 35: [1, 62], 38: [1, 61] }), { 33: [1, 63] }, { 33: [1, 64], 36: [1, 65] }, r(a, [2, 22], { 29: [1, 66] }), r(a, [2, 53], { 32: [1, 68], 38: [1, 67], 42: [1, 69] }), r(a, [2, 54], { 32: [1, 71], 35: [1, 70], 42: [1, 72] }), r(E, [2, 119]), r(E, [2, 120]), r(E, [2, 121]), r(a, [2, 57], { 35: [1, 73], 38: [1, 74], 42: [1, 75] }), r(a, [2, 68], { 32: [1, 78], 35: [1, 76], 38: [1, 77] }), { 33: [1, 79] }, { 39: 80, 43: f, 44: k, 45: g }, { 33: [1, 81] }, r(a, [2, 24], { 34: [1, 82], 35: [1, 83] }), { 32: [1, 84] }, { 32: [1, 85] }, { 30: [1, 86] }, { 39: 87, 43: f, 44: k, 45: g }, { 33: [1, 88] }, { 33: [1, 89] }, { 33: [1, 90] }, { 33: [1, 91] }, { 33: [1, 92] }, { 33: [1, 93] }, { 39: 94, 43: f, 44: k, 45: g }, { 33: [1, 95] }, { 33: [1, 96] }, { 39: 97, 43: f, 44: k, 45: g }, { 33: [1, 98] }, r(a, [2, 37], { 35: [1, 100], 38: [1, 99] }), r(a, [2, 38], { 32: [1, 102], 35: [1, 101] }), r(a, [2, 39], { 32: [1, 103], 38: [1, 104] }), { 33: [1, 105] }, { 33: [1, 106], 36: [1, 107] }, { 33: [1, 108] }, { 33: [1, 109] }, r(a, [2, 23]), r(a, [2, 55], { 32: [1, 110], 42: [1, 111] }), r(a, [2, 59], { 38: [1, 112], 42: [1, 113] }), r(a, [2, 69], { 32: [1, 115], 38: [1, 114] }), r(a, [2, 56], { 32: [1, 116], 42: [1, 117] }), r(a, [2, 61], { 35: [1, 118], 42: [1, 119] }), r(a, [2, 72], { 32: [1, 121], 35: [1, 120] }), r(a, [2, 58], { 38: [1, 122], 42: [1, 123] }), r(a, [2, 60], { 35: [1, 124], 42: [1, 125] }), r(a, [2, 73], { 35: [1, 127], 38: [1, 126] }), r(a, [2, 70], { 32: [1, 129], 38: [1, 128] }), r(a, [2, 71], { 32: [1, 131], 35: [1, 130] }), r(a, [2, 74], { 35: [1, 133], 38: [1, 132] }), { 39: 134, 43: f, 44: k, 45: g }, { 33: [1, 135] }, { 33: [1, 136] }, { 33: [1, 137] }, { 33: [1, 138] }, { 39: 139, 43: f, 44: k, 45: g }, r(a, [2, 25], { 35: [1, 140] }), r(a, [2, 26], { 34: [1, 141] }), r(a, [2, 31], { 34: [1, 142] }), r(a, [2, 29], { 34: [1, 143] }), r(a, [2, 30], { 34: [1, 144] }), { 33: [1, 145] }, { 33: [1, 146] }, { 39: 147, 43: f, 44: k, 45: g }, { 33: [1, 148] }, { 39: 149, 43: f, 44: k, 45: g }, { 33: [1, 150] }, { 33: [1, 151] }, { 33: [1, 152] }, { 33: [1, 153] }, { 33: [1, 154] }, { 33: [1, 155] }, { 33: [1, 156] }, { 39: 157, 43: f, 44: k, 45: g }, { 33: [1, 158] }, { 33: [1, 159] }, { 33: [1, 160] }, { 39: 161, 43: f, 44: k, 45: g }, { 33: [1, 162] }, { 39: 163, 43: f, 44: k, 45: g }, { 33: [1, 164] }, { 33: [1, 165] }, { 33: [1, 166] }, { 39: 167, 43: f, 44: k, 45: g }, { 33: [1, 168] }, r(a, [2, 43], { 35: [1, 169] }), r(a, [2, 44], { 38: [1, 170] }), r(a, [2, 42], { 32: [1, 171] }), r(a, [2, 45], { 35: [1, 172] }), r(a, [2, 40], { 38: [1, 173] }), r(a, [2, 41], { 32: [1, 174] }), { 33: [1, 175], 36: [1, 176] }, { 33: [1, 177] }, { 33: [1, 178] }, { 33: [1, 179] }, { 33: [1, 180] }, r(a, [2, 66], { 42: [1, 181] }), r(a, [2, 79], { 32: [1, 182] }), r(a, [
|
||
|
defaultActions: { 7: [2, 1], 13: [2, 2], 18: [2, 3], 36: [2, 4] },
|
||
|
parseError: function(o, u) {
|
||
|
if (u.recoverable)
|
||
|
this.trace(o);
|
||
|
else {
|
||
|
var d = new Error(o);
|
||
|
throw d.hash = u, d;
|
||
|
}
|
||
|
},
|
||
|
parse: function(o) {
|
||
|
var u = this, d = [0], s = [], T = [null], e = [], X = this.table, t = "", re = 0, fe = 0, we = 2, pe = 1, Le = e.slice.call(arguments, 1), O = Object.create(this.lexer), F = { yy: {} };
|
||
|
for (var ce in this.yy)
|
||
|
Object.prototype.hasOwnProperty.call(this.yy, ce) && (F.yy[ce] = this.yy[ce]);
|
||
|
O.setInput(o, F.yy), F.yy.lexer = O, F.yy.parser = this, typeof O.yylloc > "u" && (O.yylloc = {});
|
||
|
var oe = O.yylloc;
|
||
|
e.push(oe);
|
||
|
var Re = O.options && O.options.ranges;
|
||
|
typeof F.yy.parseError == "function" ? this.parseError = F.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
|
||
|
function Me() {
|
||
|
var q;
|
||
|
return q = s.pop() || O.lex() || pe, typeof q != "number" && (q instanceof Array && (s = q, q = s.pop()), q = u.symbols_[q] || q), q;
|
||
|
}
|
||
|
for (var N, K, V, le, J = {}, ie, j, be, se; ; ) {
|
||
|
if (K = d[d.length - 1], this.defaultActions[K] ? V = this.defaultActions[K] : ((N === null || typeof N > "u") && (N = Me()), V = X[K] && X[K][N]), typeof V > "u" || !V.length || !V[0]) {
|
||
|
var he = "";
|
||
|
se = [];
|
||
|
for (ie in X[K])
|
||
|
this.terminals_[ie] && ie > we && se.push("'" + this.terminals_[ie] + "'");
|
||
|
O.showPosition ? he = "Parse error on line " + (re + 1) + `:
|
||
|
` + O.showPosition() + `
|
||
|
Expecting ` + se.join(", ") + ", got '" + (this.terminals_[N] || N) + "'" : he = "Parse error on line " + (re + 1) + ": Unexpected " + (N == pe ? "end of input" : "'" + (this.terminals_[N] || N) + "'"), this.parseError(he, {
|
||
|
text: O.match,
|
||
|
token: this.terminals_[N] || N,
|
||
|
line: O.yylineno,
|
||
|
loc: oe,
|
||
|
expected: se
|
||
|
});
|
||
|
}
|
||
|
if (V[0] instanceof Array && V.length > 1)
|
||
|
throw new Error("Parse Error: multiple actions possible at state: " + K + ", token: " + N);
|
||
|
switch (V[0]) {
|
||
|
case 1:
|
||
|
d.push(N), T.push(O.yytext), e.push(O.yylloc), d.push(V[1]), N = null, fe = O.yyleng, t = O.yytext, re = O.yylineno, oe = O.yylloc;
|
||
|
break;
|
||
|
case 2:
|
||
|
if (j = this.productions_[V[1]][1], J.$ = T[T.length - j], J._$ = {
|
||
|
first_line: e[e.length - (j || 1)].first_line,
|
||
|
last_line: e[e.length - 1].last_line,
|
||
|
first_column: e[e.length - (j || 1)].first_column,
|
||
|
last_column: e[e.length - 1].last_column
|
||
|
}, Re && (J._$.range = [
|
||
|
e[e.length - (j || 1)].range[0],
|
||
|
e[e.length - 1].range[1]
|
||
|
]), le = this.performAction.apply(J, [
|
||
|
t,
|
||
|
fe,
|
||
|
re,
|
||
|
F.yy,
|
||
|
V[1],
|
||
|
T,
|
||
|
e
|
||
|
].concat(Le)), typeof le < "u")
|
||
|
return le;
|
||
|
j && (d = d.slice(0, -1 * j * 2), T = T.slice(0, -1 * j), e = e.slice(0, -1 * j)), d.push(this.productions_[V[1]][0]), T.push(J.$), e.push(J._$), be = X[d[d.length - 2]][d[d.length - 1]], d.push(be);
|
||
|
break;
|
||
|
case 3:
|
||
|
return !0;
|
||
|
}
|
||
|
}
|
||
|
return !0;
|
||
|
}
|
||
|
}, M = function() {
|
||
|
var G = {
|
||
|
EOF: 1,
|
||
|
parseError: function(u, d) {
|
||
|
if (this.yy.parser)
|
||
|
this.yy.parser.parseError(u, d);
|
||
|
else
|
||
|
throw new Error(u);
|
||
|
},
|
||
|
// resets the lexer, sets new input
|
||
|
setInput: function(o, u) {
|
||
|
return this.yy = u || this.yy || {}, this._input = o, this._more = this._backtrack = this.done = !1, this.yylineno = this.yyleng = 0, this.yytext = this.matched = this.match = "", this.conditionStack = ["INITIAL"], this.yylloc = {
|
||
|
first_line: 1,
|
||
|
first_column: 0,
|
||
|
last_line: 1,
|
||
|
last_column: 0
|
||
|
}, this.options.ranges && (this.yylloc.range = [0, 0]), this.offset = 0, this;
|
||
|
},
|
||
|
// consumes and returns one char from the input
|
||
|
input: function() {
|
||
|
var o = this._input[0];
|
||
|
this.yytext += o, this.yyleng++, this.offset++, this.match += o, this.matched += o;
|
||
|
var u = o.match(/(?:\r\n?|\n).*/g);
|
||
|
return u ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), o;
|
||
|
},
|
||
|
// unshifts one char (or a string) into the input
|
||
|
unput: function(o) {
|
||
|
var u = o.length, d = o.split(/(?:\r\n?|\n)/g);
|
||
|
this._input = o + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - u), this.offset -= u;
|
||
|
var s = this.match.split(/(?:\r\n?|\n)/g);
|
||
|
this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), d.length - 1 && (this.yylineno -= d.length - 1);
|
||
|
var T = this.yylloc.range;
|
||
|
return this.yylloc = {
|
||
|
first_line: this.yylloc.first_line,
|
||
|
last_line: this.yylineno + 1,
|
||
|
first_column: this.yylloc.first_column,
|
||
|
last_column: d ? (d.length === s.length ? this.yylloc.first_column : 0) + s[s.length - d.length].length - d[0].length : this.yylloc.first_column - u
|
||
|
}, this.options.ranges && (this.yylloc.range = [T[0], T[0] + this.yyleng - u]), this.yyleng = this.yytext.length, this;
|
||
|
},
|
||
|
// When called from action, caches matched text and appends it on next action
|
||
|
more: function() {
|
||
|
return this._more = !0, this;
|
||
|
},
|
||
|
// When called from action, signals the lexer that this rule fails to match the input, so the next matching rule (regex) should be tested instead.
|
||
|
reject: function() {
|
||
|
if (this.options.backtrack_lexer)
|
||
|
this._backtrack = !0;
|
||
|
else
|
||
|
return this.parseError("Lexical error on line " + (this.yylineno + 1) + `. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).
|
||
|
` + this.showPosition(), {
|
||
|
text: "",
|
||
|
token: null,
|
||
|
line: this.yylineno
|
||
|
});
|
||
|
return this;
|
||
|
},
|
||
|
// retain first n characters of the match
|
||
|
less: function(o) {
|
||
|
this.unput(this.match.slice(o));
|
||
|
},
|
||
|
// displays already matched input, i.e. for error messages
|
||
|
pastInput: function() {
|
||
|
var o = this.matched.substr(0, this.matched.length - this.match.length);
|
||
|
return (o.length > 20 ? "..." : "") + o.substr(-20).replace(/\n/g, "");
|
||
|
},
|
||
|
// displays upcoming input, i.e. for error messages
|
||
|
upcomingInput: function() {
|
||
|
var o = this.match;
|
||
|
return o.length < 20 && (o += this._input.substr(0, 20 - o.length)), (o.substr(0, 20) + (o.length > 20 ? "..." : "")).replace(/\n/g, "");
|
||
|
},
|
||
|
// displays the character position where the lexing error occurred, i.e. for error messages
|
||
|
showPosition: function() {
|
||
|
var o = this.pastInput(), u = new Array(o.length + 1).join("-");
|
||
|
return o + this.upcomingInput() + `
|
||
|
` + u + "^";
|
||
|
},
|
||
|
// test the lexed token: return FALSE when not a match, otherwise return token
|
||
|
test_match: function(o, u) {
|
||
|
var d, s, T;
|
||
|
if (this.options.backtrack_lexer && (T = {
|
||
|
yylineno: this.yylineno,
|
||
|
yylloc: {
|
||
|
first_line: this.yylloc.first_line,
|
||
|
last_line: this.last_line,
|
||
|
first_column: this.yylloc.first_column,
|
||
|
last_column: this.yylloc.last_column
|
||
|
},
|
||
|
yytext: this.yytext,
|
||
|
match: this.match,
|
||
|
matches: this.matches,
|
||
|
matched: this.matched,
|
||
|
yyleng: this.yyleng,
|
||
|
offset: this.offset,
|
||
|
_more: this._more,
|
||
|
_input: this._input,
|
||
|
yy: this.yy,
|
||
|
conditionStack: this.conditionStack.slice(0),
|
||
|
done: this.done
|
||
|
}, this.options.ranges && (T.yylloc.range = this.yylloc.range.slice(0))), s = o[0].match(/(?:\r\n?|\n).*/g), s && (this.yylineno += s.length), this.yylloc = {
|
||
|
first_line: this.yylloc.last_line,
|
||
|
last_line: this.yylineno + 1,
|
||
|
first_column: this.yylloc.last_column,
|
||
|
last_column: s ? s[s.length - 1].length - s[s.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + o[0].length
|
||
|
}, this.yytext += o[0], this.match += o[0], this.matches = o, this.yyleng = this.yytext.length, this.options.ranges && (this.yylloc.range = [this.offset, this.offset += this.yyleng]), this._more = !1, this._backtrack = !1, this._input = this._input.slice(o[0].length), this.matched += o[0], d = this.performAction.call(this, this.yy, this, u, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), d)
|
||
|
return d;
|
||
|
if (this._backtrack) {
|
||
|
for (var e in T)
|
||
|
this[e] = T[e];
|
||
|
return !1;
|
||
|
}
|
||
|
return !1;
|
||
|
},
|
||
|
// return next match in input
|
||
|
next: function() {
|
||
|
if (this.done)
|
||
|
return this.EOF;
|
||
|
this._input || (this.done = !0);
|
||
|
var o, u, d, s;
|
||
|
this._more || (this.yytext = "", this.match = "");
|
||
|
for (var T = this._currentRules(), e = 0; e < T.length; e++)
|
||
|
if (d = this._input.match(this.rules[T[e]]), d && (!u || d[0].length > u[0].length)) {
|
||
|
if (u = d, s = e, this.options.backtrack_lexer) {
|
||
|
if (o = this.test_match(d, T[e]), o !== !1)
|
||
|
return o;
|
||
|
if (this._backtrack) {
|
||
|
u = !1;
|
||
|
continue;
|
||
|
} else
|
||
|
return !1;
|
||
|
} else if (!this.options.flex)
|
||
|
break;
|
||
|
}
|
||
|
return u ? (o = this.test_match(u, T[s]), o !== !1 ? o : !1) : this._input === "" ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + `. Unrecognized text.
|
||
|
` + this.showPosition(), {
|
||
|
text: "",
|
||
|
token: null,
|
||
|
line: this.yylineno
|
||
|
});
|
||
|
},
|
||
|
// return next match that has a token
|
||
|
lex: function() {
|
||
|
var u = this.next();
|
||
|
return u || this.lex();
|
||
|
},
|
||
|
// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
|
||
|
begin: function(u) {
|
||
|
this.conditionStack.push(u);
|
||
|
},
|
||
|
// pop the previously active lexer condition state off the condition stack
|
||
|
popState: function() {
|
||
|
var u = this.conditionStack.length - 1;
|
||
|
return u > 0 ? this.conditionStack.pop() : this.conditionStack[0];
|
||
|
},
|
||
|
// produce the lexer rule set which is active for the currently active lexer condition state
|
||
|
_currentRules: function() {
|
||
|
return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules;
|
||
|
},
|
||
|
// return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available
|
||
|
topState: function(u) {
|
||
|
return u = this.conditionStack.length - 1 - Math.abs(u || 0), u >= 0 ? this.conditionStack[u] : "INITIAL";
|
||
|
},
|
||
|
// alias for begin(condition)
|
||
|
pushState: function(u) {
|
||
|
this.begin(u);
|
||
|
},
|
||
|
// return the number of states currently on the stack
|
||
|
stateStackSize: function() {
|
||
|
return this.conditionStack.length;
|
||
|
},
|
||
|
options: { "case-insensitive": !0 },
|
||
|
performAction: function(u, d, s, T) {
|
||
|
switch (s) {
|
||
|
case 0:
|
||
|
return this.begin("acc_title"), 19;
|
||
|
case 1:
|
||
|
return this.popState(), "acc_title_value";
|
||
|
case 2:
|
||
|
return this.begin("acc_descr"), 21;
|
||
|
case 3:
|
||
|
return this.popState(), "acc_descr_value";
|
||
|
case 4:
|
||
|
this.begin("acc_descr_multiline");
|
||
|
break;
|
||
|
case 5:
|
||
|
this.popState();
|
||
|
break;
|
||
|
case 6:
|
||
|
return "acc_descr_multiline_value";
|
||
|
case 7:
|
||
|
return 13;
|
||
|
case 8:
|
||
|
break;
|
||
|
case 9:
|
||
|
break;
|
||
|
case 10:
|
||
|
return 5;
|
||
|
case 11:
|
||
|
return 40;
|
||
|
case 12:
|
||
|
return 32;
|
||
|
case 13:
|
||
|
return 38;
|
||
|
case 14:
|
||
|
return 42;
|
||
|
case 15:
|
||
|
return 43;
|
||
|
case 16:
|
||
|
return 44;
|
||
|
case 17:
|
||
|
return 45;
|
||
|
case 18:
|
||
|
return 35;
|
||
|
case 19:
|
||
|
return 28;
|
||
|
case 20:
|
||
|
return 29;
|
||
|
case 21:
|
||
|
return 37;
|
||
|
case 22:
|
||
|
return 31;
|
||
|
case 23:
|
||
|
return 34;
|
||
|
case 24:
|
||
|
return 26;
|
||
|
case 25:
|
||
|
return 9;
|
||
|
case 26:
|
||
|
return 9;
|
||
|
case 27:
|
||
|
return 8;
|
||
|
case 28:
|
||
|
return "CARET";
|
||
|
case 29:
|
||
|
this.begin("options");
|
||
|
break;
|
||
|
case 30:
|
||
|
this.popState();
|
||
|
break;
|
||
|
case 31:
|
||
|
return 12;
|
||
|
case 32:
|
||
|
return 36;
|
||
|
case 33:
|
||
|
this.begin("string");
|
||
|
break;
|
||
|
case 34:
|
||
|
this.popState();
|
||
|
break;
|
||
|
case 35:
|
||
|
return 33;
|
||
|
case 36:
|
||
|
return 30;
|
||
|
case 37:
|
||
|
return 46;
|
||
|
case 38:
|
||
|
return 7;
|
||
|
}
|
||
|
},
|
||
|
rules: [/^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?:(\r?\n)+)/i, /^(?:#[^\n]*)/i, /^(?:%[^\n]*)/i, /^(?:gitGraph\b)/i, /^(?:commit(?=\s|$))/i, /^(?:id:)/i, /^(?:type:)/i, /^(?:msg:)/i, /^(?:NORMAL\b)/i, /^(?:REVERSE\b)/i, /^(?:HIGHLIGHT\b)/i, /^(?:tag:)/i, /^(?:branch(?=\s|$))/i, /^(?:order:)/i, /^(?:merge(?=\s|$))/i, /^(?:cherry-pick(?=\s|$))/i, /^(?:parent:)/i, /^(?:checkout(?=\s|$))/i, /^(?:LR\b)/i, /^(?:TB\b)/i, /^(?::)/i, /^(?:\^)/i, /^(?:options\r?\n)/i, /^(?:[ \r\n\t]+end\b)/i, /^(?:[\s\S]+(?=[ \r\n\t]+end))/i, /^(?:["]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?:[0-9]+(?=\s|$))/i, /^(?:\w([-\./\w]*[-\w])?)/i, /^(?:$)/i, /^(?:\s+)/i],
|
||
|
conditions: { acc_descr_multiline: { rules: [5, 6], inclusive: !1 }, acc_descr: { rules: [3], inclusive: !1 }, acc_title: { rules: [1], inclusive: !1 }, options: { rules: [30, 31], inclusive: !1 }, string: { rules: [34, 35], inclusive: !1 }, INITIAL: { rules: [0, 2, 4, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 32, 33, 36, 37, 38, 39], inclusive: !0 } }
|
||
|
};
|
||
|
return G;
|
||
|
}();
|
||
|
z.lexer = M;
|
||
|
function I() {
|
||
|
this.yy = {};
|
||
|
}
|
||
|
return I.prototype = z, z.Parser = I, new I();
|
||
|
}();
|
||
|
me.parser = me;
|
||
|
const Ve = me;
|
||
|
let ae = v().gitGraph.mainBranchName, De = v().gitGraph.mainBranchOrder, C = {}, S = null, ee = {};
|
||
|
ee[ae] = { name: ae, order: De };
|
||
|
let L = {};
|
||
|
L[ae] = S;
|
||
|
let A = ae, ke = "LR", W = 0;
|
||
|
function ue() {
|
||
|
return Se({ length: 7 });
|
||
|
}
|
||
|
function ze(r, n) {
|
||
|
const l = /* @__PURE__ */ Object.create(null);
|
||
|
return r.reduce((h, i) => {
|
||
|
const c = n(i);
|
||
|
return l[c] || (l[c] = !0, h.push(i)), h;
|
||
|
}, []);
|
||
|
}
|
||
|
const je = function(r) {
|
||
|
ke = r;
|
||
|
};
|
||
|
let xe = {};
|
||
|
const qe = function(r) {
|
||
|
B.debug("options str", r), r = r && r.trim(), r = r || "{}";
|
||
|
try {
|
||
|
xe = JSON.parse(r);
|
||
|
} catch (n) {
|
||
|
B.error("error while parsing gitGraph options", n.message);
|
||
|
}
|
||
|
}, Ye = function() {
|
||
|
return xe;
|
||
|
}, Fe = function(r, n, l, h) {
|
||
|
B.debug("Entering commit:", r, n, l, h), n = D.sanitizeText(n, v()), r = D.sanitizeText(r, v()), h = D.sanitizeText(h, v());
|
||
|
const i = {
|
||
|
id: n || W + "-" + ue(),
|
||
|
message: r,
|
||
|
seq: W++,
|
||
|
type: l || Q.NORMAL,
|
||
|
tag: h || "",
|
||
|
parents: S == null ? [] : [S.id],
|
||
|
branch: A
|
||
|
};
|
||
|
S = i, C[i.id] = i, L[A] = i.id, B.debug("in pushCommit " + i.id);
|
||
|
}, Ke = function(r, n) {
|
||
|
if (r = D.sanitizeText(r, v()), L[r] === void 0)
|
||
|
L[r] = S != null ? S.id : null, ee[r] = { name: r, order: n ? parseInt(n, 10) : null }, ye(r), B.debug("in createBranch");
|
||
|
else {
|
||
|
let l = new Error(
|
||
|
'Trying to create an existing branch. (Help: Either use a new name if you want create a new branch or try using "checkout ' + r + '")'
|
||
|
);
|
||
|
throw l.hash = {
|
||
|
text: "branch " + r,
|
||
|
token: "branch " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ['"checkout ' + r + '"']
|
||
|
}, l;
|
||
|
}
|
||
|
}, Ue = function(r, n, l, h) {
|
||
|
r = D.sanitizeText(r, v()), n = D.sanitizeText(n, v());
|
||
|
const i = C[L[A]], c = C[L[r]];
|
||
|
if (A === r) {
|
||
|
let m = new Error('Incorrect usage of "merge". Cannot merge a branch to itself');
|
||
|
throw m.hash = {
|
||
|
text: "merge " + r,
|
||
|
token: "merge " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["branch abc"]
|
||
|
}, m;
|
||
|
} else if (i === void 0 || !i) {
|
||
|
let m = new Error(
|
||
|
'Incorrect usage of "merge". Current branch (' + A + ")has no commits"
|
||
|
);
|
||
|
throw m.hash = {
|
||
|
text: "merge " + r,
|
||
|
token: "merge " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["commit"]
|
||
|
}, m;
|
||
|
} else if (L[r] === void 0) {
|
||
|
let m = new Error(
|
||
|
'Incorrect usage of "merge". Branch to be merged (' + r + ") does not exist"
|
||
|
);
|
||
|
throw m.hash = {
|
||
|
text: "merge " + r,
|
||
|
token: "merge " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["branch " + r]
|
||
|
}, m;
|
||
|
} else if (c === void 0 || !c) {
|
||
|
let m = new Error(
|
||
|
'Incorrect usage of "merge". Branch to be merged (' + r + ") has no commits"
|
||
|
);
|
||
|
throw m.hash = {
|
||
|
text: "merge " + r,
|
||
|
token: "merge " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ['"commit"']
|
||
|
}, m;
|
||
|
} else if (i === c) {
|
||
|
let m = new Error('Incorrect usage of "merge". Both branches have same head');
|
||
|
throw m.hash = {
|
||
|
text: "merge " + r,
|
||
|
token: "merge " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["branch abc"]
|
||
|
}, m;
|
||
|
} else if (n && C[n] !== void 0) {
|
||
|
let m = new Error(
|
||
|
'Incorrect usage of "merge". Commit with id:' + n + " already exists, use different custom Id"
|
||
|
);
|
||
|
throw m.hash = {
|
||
|
text: "merge " + r + n + l + h,
|
||
|
token: "merge " + r + n + l + h,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: [
|
||
|
"merge " + r + " " + n + "_UNIQUE " + l + " " + h
|
||
|
]
|
||
|
}, m;
|
||
|
}
|
||
|
const p = {
|
||
|
id: n || W + "-" + ue(),
|
||
|
message: "merged branch " + r + " into " + A,
|
||
|
seq: W++,
|
||
|
parents: [S == null ? null : S.id, L[r]],
|
||
|
branch: A,
|
||
|
type: Q.MERGE,
|
||
|
customType: l,
|
||
|
customId: !!n,
|
||
|
tag: h || ""
|
||
|
};
|
||
|
S = p, C[p.id] = p, L[A] = p.id, B.debug(L), B.debug("in mergeBranch");
|
||
|
}, We = function(r, n, l, h) {
|
||
|
if (B.debug("Entering cherryPick:", r, n, l), r = D.sanitizeText(r, v()), n = D.sanitizeText(n, v()), l = D.sanitizeText(l, v()), h = D.sanitizeText(h, v()), !r || C[r] === void 0) {
|
||
|
let p = new Error(
|
||
|
'Incorrect usage of "cherryPick". Source commit id should exist and provided'
|
||
|
);
|
||
|
throw p.hash = {
|
||
|
text: "cherryPick " + r + " " + n,
|
||
|
token: "cherryPick " + r + " " + n,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["cherry-pick abc"]
|
||
|
}, p;
|
||
|
}
|
||
|
let i = C[r], c = i.branch;
|
||
|
if (h && !(Array.isArray(i.parents) && i.parents.includes(h)))
|
||
|
throw new Error(
|
||
|
"Invalid operation: The specified parent commit is not an immediate parent of the cherry-picked commit."
|
||
|
);
|
||
|
if (i.type === Q.MERGE && !h)
|
||
|
throw new Error(
|
||
|
"Incorrect usage of cherry-pick: If the source commit is a merge commit, an immediate parent commit must be specified."
|
||
|
);
|
||
|
if (!n || C[n] === void 0) {
|
||
|
if (c === A) {
|
||
|
let x = new Error(
|
||
|
'Incorrect usage of "cherryPick". Source commit is already on current branch'
|
||
|
);
|
||
|
throw x.hash = {
|
||
|
text: "cherryPick " + r + " " + n,
|
||
|
token: "cherryPick " + r + " " + n,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["cherry-pick abc"]
|
||
|
}, x;
|
||
|
}
|
||
|
const p = C[L[A]];
|
||
|
if (p === void 0 || !p) {
|
||
|
let x = new Error(
|
||
|
'Incorrect usage of "cherry-pick". Current branch (' + A + ")has no commits"
|
||
|
);
|
||
|
throw x.hash = {
|
||
|
text: "cherryPick " + r + " " + n,
|
||
|
token: "cherryPick " + r + " " + n,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ["cherry-pick abc"]
|
||
|
}, x;
|
||
|
}
|
||
|
const m = {
|
||
|
id: W + "-" + ue(),
|
||
|
message: "cherry-picked " + i + " into " + A,
|
||
|
seq: W++,
|
||
|
parents: [S == null ? null : S.id, i.id],
|
||
|
branch: A,
|
||
|
type: Q.CHERRY_PICK,
|
||
|
tag: l ?? `cherry-pick:${i.id}${i.type === Q.MERGE ? `|parent:${h}` : ""}`
|
||
|
};
|
||
|
S = m, C[m.id] = m, L[A] = m.id, B.debug(L), B.debug("in cherryPick");
|
||
|
}
|
||
|
}, ye = function(r) {
|
||
|
if (r = D.sanitizeText(r, v()), L[r] === void 0) {
|
||
|
let n = new Error(
|
||
|
'Trying to checkout branch which is not yet created. (Help try using "branch ' + r + '")'
|
||
|
);
|
||
|
throw n.hash = {
|
||
|
text: "checkout " + r,
|
||
|
token: "checkout " + r,
|
||
|
line: "1",
|
||
|
loc: { first_line: 1, last_line: 1, first_column: 1, last_column: 1 },
|
||
|
expected: ['"branch ' + r + '"']
|
||
|
}, n;
|
||
|
} else {
|
||
|
A = r;
|
||
|
const n = L[A];
|
||
|
S = C[n];
|
||
|
}
|
||
|
};
|
||
|
function ge(r, n, l) {
|
||
|
const h = r.indexOf(n);
|
||
|
h === -1 ? r.push(l) : r.splice(h, 1, l);
|
||
|
}
|
||
|
function _e(r) {
|
||
|
const n = r.reduce((i, c) => i.seq > c.seq ? i : c, r[0]);
|
||
|
let l = "";
|
||
|
r.forEach(function(i) {
|
||
|
i === n ? l += " *" : l += " |";
|
||
|
});
|
||
|
const h = [l, n.id, n.seq];
|
||
|
for (let i in L)
|
||
|
L[i] === n.id && h.push(i);
|
||
|
if (B.debug(h.join(" ")), n.parents && n.parents.length == 2) {
|
||
|
const i = C[n.parents[0]];
|
||
|
ge(r, n, i), r.push(C[n.parents[1]]);
|
||
|
} else {
|
||
|
if (n.parents.length == 0)
|
||
|
return;
|
||
|
{
|
||
|
const i = C[n.parents];
|
||
|
ge(r, n, i);
|
||
|
}
|
||
|
}
|
||
|
r = ze(r, (i) => i.id), _e(r);
|
||
|
}
|
||
|
const Je = function() {
|
||
|
B.debug(C);
|
||
|
const r = Ee()[0];
|
||
|
_e([r]);
|
||
|
}, Qe = function() {
|
||
|
C = {}, S = null;
|
||
|
let r = v().gitGraph.mainBranchName, n = v().gitGraph.mainBranchOrder;
|
||
|
L = {}, L[r] = null, ee = {}, ee[r] = { name: r, order: n }, A = r, W = 0, Ie();
|
||
|
}, Xe = function() {
|
||
|
return Object.values(ee).map((n, l) => n.order !== null ? n : {
|
||
|
...n,
|
||
|
order: parseFloat(`0.${l}`, 10)
|
||
|
}).sort((n, l) => n.order - l.order).map(({ name: n }) => ({ name: n }));
|
||
|
}, Ze = function() {
|
||
|
return L;
|
||
|
}, $e = function() {
|
||
|
return C;
|
||
|
}, Ee = function() {
|
||
|
const r = Object.keys(C).map(function(n) {
|
||
|
return C[n];
|
||
|
});
|
||
|
return r.forEach(function(n) {
|
||
|
B.debug(n.id);
|
||
|
}), r.sort((n, l) => n.seq - l.seq), r;
|
||
|
}, et = function() {
|
||
|
return A;
|
||
|
}, tt = function() {
|
||
|
return ke;
|
||
|
}, rt = function() {
|
||
|
return S;
|
||
|
}, Q = {
|
||
|
NORMAL: 0,
|
||
|
REVERSE: 1,
|
||
|
HIGHLIGHT: 2,
|
||
|
MERGE: 3,
|
||
|
CHERRY_PICK: 4
|
||
|
}, it = {
|
||
|
getConfig: () => v().gitGraph,
|
||
|
setDirection: je,
|
||
|
setOptions: qe,
|
||
|
getOptions: Ye,
|
||
|
commit: Fe,
|
||
|
branch: Ke,
|
||
|
merge: Ue,
|
||
|
cherryPick: We,
|
||
|
checkout: ye,
|
||
|
//reset,
|
||
|
prettyPrint: Je,
|
||
|
clear: Qe,
|
||
|
getBranchesAsObjArray: Xe,
|
||
|
getBranches: Ze,
|
||
|
getCommits: $e,
|
||
|
getCommitsArray: Ee,
|
||
|
getCurrentBranch: et,
|
||
|
getDirection: tt,
|
||
|
getHead: rt,
|
||
|
setAccTitle: Ce,
|
||
|
getAccTitle: ve,
|
||
|
getAccDescription: Oe,
|
||
|
setAccDescription: Pe,
|
||
|
setDiagramTitle: Ae,
|
||
|
getDiagramTitle: Ge,
|
||
|
commitType: Q
|
||
|
};
|
||
|
let Z = {};
|
||
|
const P = {
|
||
|
NORMAL: 0,
|
||
|
REVERSE: 1,
|
||
|
HIGHLIGHT: 2,
|
||
|
MERGE: 3,
|
||
|
CHERRY_PICK: 4
|
||
|
}, U = 8;
|
||
|
let H = {}, Y = {}, ne = [], te = 0, w = "LR";
|
||
|
const st = () => {
|
||
|
H = {}, Y = {}, Z = {}, te = 0, ne = [], w = "LR";
|
||
|
}, Te = (r) => {
|
||
|
const n = document.createElementNS("http://www.w3.org/2000/svg", "text");
|
||
|
let l = [];
|
||
|
typeof r == "string" ? l = r.split(/\\n|\n|<br\s*\/?>/gi) : Array.isArray(r) ? l = r : l = [];
|
||
|
for (const h of l) {
|
||
|
const i = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
|
||
|
i.setAttributeNS("http://www.w3.org/XML/1998/namespace", "xml:space", "preserve"), i.setAttribute("dy", "1em"), i.setAttribute("x", "0"), i.setAttribute("class", "row"), i.textContent = h.trim(), n.appendChild(i);
|
||
|
}
|
||
|
return n;
|
||
|
}, at = (r) => {
|
||
|
let n = "", l = 0;
|
||
|
return r.forEach((h) => {
|
||
|
const i = w === "TB" ? Y[h].y : Y[h].x;
|
||
|
i >= l && (n = h, l = i);
|
||
|
}), n || void 0;
|
||
|
}, de = (r, n, l) => {
|
||
|
const h = v().gitGraph, i = r.append("g").attr("class", "commit-bullets"), c = r.append("g").attr("class", "commit-labels");
|
||
|
let p = 0;
|
||
|
w === "TB" && (p = 30);
|
||
|
const x = Object.keys(n).sort((_, b) => n[_].seq - n[b].seq), y = h.parallelCommits, a = 10, R = 40;
|
||
|
x.forEach((_) => {
|
||
|
const b = n[_];
|
||
|
if (y)
|
||
|
if (b.parents.length) {
|
||
|
const E = at(b.parents);
|
||
|
p = w === "TB" ? Y[E].y + R : Y[E].x + R;
|
||
|
} else
|
||
|
p = 0, w === "TB" && (p = 30);
|
||
|
const f = p + a, k = w === "TB" ? f : H[b.branch].pos, g = w === "TB" ? H[b.branch].pos : f;
|
||
|
if (l) {
|
||
|
let E, z = b.customType !== void 0 && b.customType !== "" ? b.customType : b.type;
|
||
|
switch (z) {
|
||
|
case P.NORMAL:
|
||
|
E = "commit-normal";
|
||
|
break;
|
||
|
case P.REVERSE:
|
||
|
E = "commit-reverse";
|
||
|
break;
|
||
|
case P.HIGHLIGHT:
|
||
|
E = "commit-highlight";
|
||
|
break;
|
||
|
case P.MERGE:
|
||
|
E = "commit-merge";
|
||
|
break;
|
||
|
case P.CHERRY_PICK:
|
||
|
E = "commit-cherry-pick";
|
||
|
break;
|
||
|
default:
|
||
|
E = "commit-normal";
|
||
|
}
|
||
|
if (z === P.HIGHLIGHT) {
|
||
|
const M = i.append("rect");
|
||
|
M.attr("x", g - 10), M.attr("y", k - 10), M.attr("height", 20), M.attr("width", 20), M.attr(
|
||
|
"class",
|
||
|
`commit ${b.id} commit-highlight${H[b.branch].index % U} ${E}-outer`
|
||
|
), i.append("rect").attr("x", g - 6).attr("y", k - 6).attr("height", 12).attr("width", 12).attr(
|
||
|
"class",
|
||
|
`commit ${b.id} commit${H[b.branch].index % U} ${E}-inner`
|
||
|
);
|
||
|
} else if (z === P.CHERRY_PICK)
|
||
|
i.append("circle").attr("cx", g).attr("cy", k).attr("r", 10).attr("class", `commit ${b.id} ${E}`), i.append("circle").attr("cx", g - 3).attr("cy", k + 2).attr("r", 2.75).attr("fill", "#fff").attr("class", `commit ${b.id} ${E}`), i.append("circle").attr("cx", g + 3).attr("cy", k + 2).attr("r", 2.75).attr("fill", "#fff").attr("class", `commit ${b.id} ${E}`), i.append("line").attr("x1", g + 3).attr("y1", k + 1).attr("x2", g).attr("y2", k - 5).attr("stroke", "#fff").attr("class", `commit ${b.id} ${E}`), i.append("line").attr("x1", g - 3).attr("y1", k + 1).attr("x2", g).attr("y2", k - 5).attr("stroke", "#fff").attr("class", `commit ${b.id} ${E}`);
|
||
|
else {
|
||
|
const M = i.append("circle");
|
||
|
if (M.attr("cx", g), M.attr("cy", k), M.attr("r", b.type === P.MERGE ? 9 : 10), M.attr(
|
||
|
"class",
|
||
|
`commit ${b.id} commit${H[b.branch].index % U}`
|
||
|
), z === P.MERGE) {
|
||
|
const I = i.append("circle");
|
||
|
I.attr("cx", g), I.attr("cy", k), I.attr("r", 6), I.attr(
|
||
|
"class",
|
||
|
`commit ${E} ${b.id} commit${H[b.branch].index % U}`
|
||
|
);
|
||
|
}
|
||
|
z === P.REVERSE && i.append("path").attr("d", `M ${g - 5},${k - 5}L${g + 5},${k + 5}M${g - 5},${k + 5}L${g + 5},${k - 5}`).attr(
|
||
|
"class",
|
||
|
`commit ${E} ${b.id} commit${H[b.branch].index % U}`
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
if (w === "TB" ? Y[b.id] = { x: g, y: f } : Y[b.id] = { x: f, y: k }, l) {
|
||
|
if (b.type !== P.CHERRY_PICK && (b.customId && b.type === P.MERGE || b.type !== P.MERGE) && h.showCommitLabel) {
|
||
|
const M = c.append("g"), I = M.insert("rect").attr("class", "commit-label-bkg"), G = M.append("text").attr("x", p).attr("y", k + 25).attr("class", "commit-label").text(b.id);
|
||
|
let o = G.node().getBBox();
|
||
|
if (I.attr("x", f - o.width / 2 - 2).attr("y", k + 13.5).attr("width", o.width + 2 * 2).attr("height", o.height + 2 * 2), w === "TB" && (I.attr("x", g - (o.width + 4 * 4 + 5)).attr("y", k - 12), G.attr("x", g - (o.width + 4 * 4)).attr("y", k + o.height - 12)), w !== "TB" && G.attr("x", f - o.width / 2), h.rotateCommitLabel)
|
||
|
if (w === "TB")
|
||
|
G.attr("transform", "rotate(-45, " + g + ", " + k + ")"), I.attr("transform", "rotate(-45, " + g + ", " + k + ")");
|
||
|
else {
|
||
|
let u = -7.5 - (o.width + 10) / 25 * 9.5, d = 10 + o.width / 25 * 8.5;
|
||
|
M.attr(
|
||
|
"transform",
|
||
|
"translate(" + u + ", " + d + ") rotate(-45, " + p + ", " + k + ")"
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
if (b.tag) {
|
||
|
const M = c.insert("polygon"), I = c.append("circle"), G = c.append("text").attr("y", k - 16).attr("class", "tag-label").text(b.tag);
|
||
|
let o = G.node().getBBox();
|
||
|
G.attr("x", f - o.width / 2);
|
||
|
const u = o.height / 2, d = k - 19.2;
|
||
|
M.attr("class", "tag-label-bkg").attr(
|
||
|
"points",
|
||
|
`
|
||
|
${p - o.width / 2 - 4 / 2},${d + 2}
|
||
|
${p - o.width / 2 - 4 / 2},${d - 2}
|
||
|
${f - o.width / 2 - 4},${d - u - 2}
|
||
|
${f + o.width / 2 + 4},${d - u - 2}
|
||
|
${f + o.width / 2 + 4},${d + u + 2}
|
||
|
${f - o.width / 2 - 4},${d + u + 2}`
|
||
|
), I.attr("cx", p - o.width / 2 + 4 / 2).attr("cy", d).attr("r", 1.5).attr("class", "tag-hole"), w === "TB" && (M.attr("class", "tag-label-bkg").attr(
|
||
|
"points",
|
||
|
`
|
||
|
${g},${p + 2}
|
||
|
${g},${p - 2}
|
||
|
${g + a},${p - u - 2}
|
||
|
${g + a + o.width + 4},${p - u - 2}
|
||
|
${g + a + o.width + 4},${p + u + 2}
|
||
|
${g + a},${p + u + 2}`
|
||
|
).attr("transform", "translate(12,12) rotate(45, " + g + "," + p + ")"), I.attr("cx", g + 4 / 2).attr("cy", p).attr("transform", "translate(12,12) rotate(45, " + g + "," + p + ")"), G.attr("x", g + 5).attr("y", p + 3).attr("transform", "translate(14,14) rotate(45, " + g + "," + p + ")"));
|
||
|
}
|
||
|
}
|
||
|
p += R + a, p > te && (te = p);
|
||
|
});
|
||
|
}, nt = (r, n, l, h, i) => {
|
||
|
const p = (w === "TB" ? l.x < h.x : l.y < h.y) ? n.branch : r.branch, m = (y) => y.branch === p, x = (y) => y.seq > r.seq && y.seq < n.seq;
|
||
|
return Object.values(i).some((y) => x(y) && m(y));
|
||
|
}, $ = (r, n, l = 0) => {
|
||
|
const h = r + Math.abs(r - n) / 2;
|
||
|
if (l > 5)
|
||
|
return h;
|
||
|
if (ne.every((p) => Math.abs(p - h) >= 10))
|
||
|
return ne.push(h), h;
|
||
|
const c = Math.abs(r - n);
|
||
|
return $(r, n - c / 5, l + 1);
|
||
|
}, ct = (r, n, l, h) => {
|
||
|
const i = Y[n.id], c = Y[l.id], p = nt(n, l, i, c, h);
|
||
|
let m = "", x = "", y = 0, a = 0, R = H[l.branch].index;
|
||
|
l.type === P.MERGE && n.id !== l.parents[0] && (R = H[n.branch].index);
|
||
|
let _;
|
||
|
if (p) {
|
||
|
m = "A 10 10, 0, 0, 0,", x = "A 10 10, 0, 0, 1,", y = 10, a = 10;
|
||
|
const b = i.y < c.y ? $(i.y, c.y) : $(c.y, i.y), f = i.x < c.x ? $(i.x, c.x) : $(c.x, i.x);
|
||
|
w === "TB" ? i.x < c.x ? _ = `M ${i.x} ${i.y} L ${f - y} ${i.y} ${x} ${f} ${i.y + a} L ${f} ${c.y - y} ${m} ${f + a} ${c.y} L ${c.x} ${c.y}` : (R = H[n.branch].index, _ = `M ${i.x} ${i.y} L ${f + y} ${i.y} ${m} ${f} ${i.y + a} L ${f} ${c.y - y} ${x} ${f - a} ${c.y} L ${c.x} ${c.y}`) : i.y < c.y ? _ = `M ${i.x} ${i.y} L ${i.x} ${b - y} ${m} ${i.x + a} ${b} L ${c.x - y} ${b} ${x} ${c.x} ${b + a} L ${c.x} ${c.y}` : (R = H[n.branch].index, _ = `M ${i.x} ${i.y} L ${i.x} ${b + y} ${x} ${i.x + a} ${b} L ${c.x - y} ${b} ${m} ${c.x} ${b - a} L ${c.x} ${c.y}`);
|
||
|
} else
|
||
|
m = "A 20 20, 0, 0, 0,", x = "A 20 20, 0, 0, 1,", y = 20, a = 20, w === "TB" ? (i.x < c.x && (l.type === P.MERGE && n.id !== l.parents[0] ? _ = `M ${i.x} ${i.y} L ${i.x} ${c.y - y} ${m} ${i.x + a} ${c.y} L ${c.x} ${c.y}` : _ = `M ${i.x} ${i.y} L ${c.x - y} ${i.y} ${x} ${c.x} ${i.y + a} L ${c.x} ${c.y}`), i.x > c.x && (m = "A 20 20, 0, 0, 0,", x = "A 20 20, 0, 0, 1,", y = 20, a = 20, l.type === P.MERGE && n.id !== l.parents[0] ? _ = `M ${i.x} ${i.y} L ${i.x} ${c.y - y} ${x} ${i.x - a} ${c.y} L ${c.x} ${c.y}` : _ = `M ${i.x} ${i.y} L ${c.x + y} ${i.y} ${m} ${c.x} ${i.y + a} L ${c.x} ${c.y}`), i.x === c.x && (_ = `M ${i.x} ${i.y} L ${c.x} ${c.y}`)) : (i.y < c.y && (l.type === P.MERGE && n.id !== l.parents[0] ? _ = `M ${i.x} ${i.y} L ${c.x - y} ${i.y} ${x} ${c.x} ${i.y + a} L ${c.x} ${c.y}` : _ = `M ${i.x} ${i.y} L ${i.x} ${c.y - y} ${m} ${i.x + a} ${c.y} L ${c.x} ${c.y}`), i.y > c.y && (l.type === P.MERGE && n.id !== l.parents[0] ? _ = `M ${i.x} ${i.y} L ${c.x - y} ${i.y} ${m} ${c.x} ${i.y - a} L ${c.x} ${c.y}` : _ = `M ${i.x} ${i.y} L ${i.x} ${c.y + y} ${x} ${i.x + a} ${c.y} L ${c.x} ${c.y}`), i.y === c.y && (_ = `M ${i.x} ${i.y} L ${c.x} ${c.y}`));
|
||
|
r.append("path").attr("d", _).attr("class", "arrow arrow" + R % U);
|
||
|
}, ot = (r, n) => {
|
||
|
const l = r.append("g").attr("class", "commit-arrows");
|
||
|
Object.keys(n).forEach((h) => {
|
||
|
const i = n[h];
|
||
|
i.parents && i.parents.length > 0 && i.parents.forEach((c) => {
|
||
|
ct(l, n[c], i, n);
|
||
|
});
|
||
|
});
|
||
|
}, lt = (r, n) => {
|
||
|
const l = v().gitGraph, h = r.append("g");
|
||
|
n.forEach((i, c) => {
|
||
|
const p = c % U, m = H[i.name].pos, x = h.append("line");
|
||
|
x.attr("x1", 0), x.attr("y1", m), x.attr("x2", te), x.attr("y2", m), x.attr("class", "branch branch" + p), w === "TB" && (x.attr("y1", 30), x.attr("x1", m), x.attr("y2", te), x.attr("x2", m)), ne.push(m);
|
||
|
let y = i.name;
|
||
|
const a = Te(y), R = h.insert("rect"), b = h.insert("g").attr("class", "branchLabel").insert("g").attr("class", "label branch-label" + p);
|
||
|
b.node().appendChild(a);
|
||
|
let f = a.getBBox();
|
||
|
R.attr("class", "branchLabelBkg label" + p).attr("rx", 4).attr("ry", 4).attr("x", -f.width - 4 - (l.rotateCommitLabel === !0 ? 30 : 0)).attr("y", -f.height / 2 + 8).attr("width", f.width + 18).attr("height", f.height + 4), b.attr(
|
||
|
"transform",
|
||
|
"translate(" + (-f.width - 14 - (l.rotateCommitLabel === !0 ? 30 : 0)) + ", " + (m - f.height / 2 - 1) + ")"
|
||
|
), w === "TB" && (R.attr("x", m - f.width / 2 - 10).attr("y", 0), b.attr("transform", "translate(" + (m - f.width / 2 - 5) + ", 0)")), w !== "TB" && R.attr("transform", "translate(-19, " + (m - f.height / 2) + ")");
|
||
|
});
|
||
|
}, ht = function(r, n, l, h) {
|
||
|
st();
|
||
|
const i = v(), c = i.gitGraph;
|
||
|
B.debug("in gitgraph renderer", r + `
|
||
|
`, "id:", n, l), Z = h.db.getCommits();
|
||
|
const p = h.db.getBranchesAsObjArray();
|
||
|
w = h.db.getDirection();
|
||
|
const m = Ne(`[id="${n}"]`);
|
||
|
let x = 0;
|
||
|
p.forEach((y, a) => {
|
||
|
const R = Te(y.name), _ = m.append("g"), b = _.insert("g").attr("class", "branchLabel"), f = b.insert("g").attr("class", "label branch-label");
|
||
|
f.node().appendChild(R);
|
||
|
let k = R.getBBox();
|
||
|
H[y.name] = { pos: x, index: a }, x += 50 + (c.rotateCommitLabel ? 40 : 0) + (w === "TB" ? k.width / 2 : 0), f.remove(), b.remove(), _.remove();
|
||
|
}), de(m, Z, !1), c.showBranches && lt(m, p), ot(m, Z), de(m, Z, !0), He.insertTitle(
|
||
|
m,
|
||
|
"gitTitleText",
|
||
|
c.titleTopMargin,
|
||
|
h.db.getDiagramTitle()
|
||
|
), Be(
|
||
|
void 0,
|
||
|
m,
|
||
|
c.diagramPadding,
|
||
|
c.useMaxWidth ?? i.useMaxWidth
|
||
|
);
|
||
|
}, mt = {
|
||
|
draw: ht
|
||
|
}, ut = (r) => `
|
||
|
.commit-id,
|
||
|
.commit-msg,
|
||
|
.branch-label {
|
||
|
fill: lightgrey;
|
||
|
color: lightgrey;
|
||
|
font-family: 'trebuchet ms', verdana, arial, sans-serif;
|
||
|
font-family: var(--mermaid-font-family);
|
||
|
}
|
||
|
${[0, 1, 2, 3, 4, 5, 6, 7].map(
|
||
|
(n) => `
|
||
|
.branch-label${n} { fill: ${r["gitBranchLabel" + n]}; }
|
||
|
.commit${n} { stroke: ${r["git" + n]}; fill: ${r["git" + n]}; }
|
||
|
.commit-highlight${n} { stroke: ${r["gitInv" + n]}; fill: ${r["gitInv" + n]}; }
|
||
|
.label${n} { fill: ${r["git" + n]}; }
|
||
|
.arrow${n} { stroke: ${r["git" + n]}; }
|
||
|
`
|
||
|
).join(`
|
||
|
`)}
|
||
|
|
||
|
.branch {
|
||
|
stroke-width: 1;
|
||
|
stroke: ${r.lineColor};
|
||
|
stroke-dasharray: 2;
|
||
|
}
|
||
|
.commit-label { font-size: ${r.commitLabelFontSize}; fill: ${r.commitLabelColor};}
|
||
|
.commit-label-bkg { font-size: ${r.commitLabelFontSize}; fill: ${r.commitLabelBackground}; opacity: 0.5; }
|
||
|
.tag-label { font-size: ${r.tagLabelFontSize}; fill: ${r.tagLabelColor};}
|
||
|
.tag-label-bkg { fill: ${r.tagLabelBackground}; stroke: ${r.tagLabelBorder}; }
|
||
|
.tag-hole { fill: ${r.textColor}; }
|
||
|
|
||
|
.commit-merge {
|
||
|
stroke: ${r.primaryColor};
|
||
|
fill: ${r.primaryColor};
|
||
|
}
|
||
|
.commit-reverse {
|
||
|
stroke: ${r.primaryColor};
|
||
|
fill: ${r.primaryColor};
|
||
|
stroke-width: 3;
|
||
|
}
|
||
|
.commit-highlight-outer {
|
||
|
}
|
||
|
.commit-highlight-inner {
|
||
|
stroke: ${r.primaryColor};
|
||
|
fill: ${r.primaryColor};
|
||
|
}
|
||
|
|
||
|
.arrow { stroke-width: 8; stroke-linecap: round; fill: none}
|
||
|
.gitTitleText {
|
||
|
text-anchor: middle;
|
||
|
font-size: 18px;
|
||
|
fill: ${r.textColor};
|
||
|
}
|
||
|
`, ft = ut, bt = {
|
||
|
parser: Ve,
|
||
|
db: it,
|
||
|
renderer: mt,
|
||
|
styles: ft
|
||
|
};
|
||
|
export {
|
||
|
bt as diagram
|
||
|
};
|