You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

903 lines
35 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. let isTesting = false;
  4. const ILCommentPrefix = "@@comments";
  5. const ILQuotesPrefix = "@@quotes";
  6. class NewLineSettings {
  7. constructor() {
  8. this.newLineAfter = [];
  9. this.noNewLineAfter = [];
  10. }
  11. newLineAfterPush(keyword) {
  12. this.newLineAfter.push(keyword);
  13. }
  14. noNewLineAfterPush(keyword) {
  15. this.noNewLineAfter.push(keyword);
  16. }
  17. push(keyword, addNewLine) {
  18. if (addNewLine) {
  19. this.newLineAfterPush(keyword);
  20. }
  21. else {
  22. this.noNewLineAfterPush(keyword);
  23. }
  24. }
  25. }
  26. exports.NewLineSettings = NewLineSettings;
  27. function ConstructNewLineSettings(dict) {
  28. let settings = new NewLineSettings();
  29. for (let key in dict) {
  30. settings.push(key, dict[key]);
  31. }
  32. return settings;
  33. }
  34. function fetchHeader(url, wch) {
  35. try {
  36. var req = new XMLHttpRequest();
  37. req.open("HEAD", url, false);
  38. req.send(null);
  39. if (req.status == 200) {
  40. return req.getResponseHeader(wch);
  41. }
  42. else
  43. return false;
  44. }
  45. catch (e) {
  46. return "";
  47. }
  48. }
  49. String.prototype.regexStartsWith = function (pattern) {
  50. var searchResult = this.search(pattern);
  51. return searchResult == 0;
  52. };
  53. String.prototype.regexIndexOf = function (pattern, startIndex) {
  54. startIndex = startIndex || 0;
  55. var searchResult = this.substr(startIndex).search(pattern);
  56. return (-1 === searchResult) ? -1 : searchResult + startIndex;
  57. };
  58. String.prototype.regexLastIndexOf = function (pattern, startIndex) {
  59. startIndex = startIndex === undefined ? this.length : startIndex;
  60. var searchResult = this.substr(0, startIndex).reverse().regexIndexOf(pattern, 0);
  61. return (-1 === searchResult) ? -1 : this.length - ++searchResult;
  62. };
  63. String.prototype.reverse = function () {
  64. return this.split('').reverse().join('');
  65. };
  66. function wordWrap() {
  67. var d = document.getElementById("result");
  68. if (d.className == "") {
  69. d.className = "wordwrap";
  70. }
  71. else {
  72. d.className = "";
  73. }
  74. }
  75. function getHTMLInputElement(name) {
  76. return document.getElementById(name);
  77. }
  78. function noFormat() {
  79. let elements = ["remove_comments",
  80. "remove_lines",
  81. "remove_report",
  82. "check_alias",
  83. "sign_align",
  84. "sign_align_all",
  85. "new_line_after_port",
  86. "new_line",
  87. "use_space",
  88. "compress",
  89. "mix_letter"];
  90. var t = !(getHTMLInputElement("remove_comments").disabled);
  91. elements.forEach(element => {
  92. getHTMLInputElement(element).disabled = t;
  93. });
  94. let keyword = document.getElementById("keyword");
  95. for (let i = 0; i < keyword.elements.length; i++) {
  96. keyword.elements[i].disabled = t;
  97. }
  98. }
  99. function indent_decode() {
  100. var custom_indent = getHTMLInputElement("cust_indent").value;
  101. var result = indentDecode(custom_indent);
  102. document.getElementById("indent_s").innerHTML = result;
  103. }
  104. function indentDecode(input) {
  105. input = input.replace(/\\t/g, " ");
  106. var count = [" & one ", " & two ", " & three ", " & four ", " & five ", " & six ", " & seven ", " & eight ", " & many "];
  107. var tokens = input.split("");
  108. var result = "";
  109. var repeatedCharCount = 0;
  110. for (var i = 0; i < tokens.length; i++) {
  111. var char = input.substr(i, 1);
  112. if (char == input.substr(i + 1, 1)) {
  113. repeatedCharCount++;
  114. }
  115. else {
  116. switch (char) {
  117. case " ":
  118. char = "blankspace";
  119. break;
  120. case "\t":
  121. char = "tab";
  122. }
  123. repeatedCharCount = repeatedCharCount > 8 ? 8 : repeatedCharCount;
  124. result += count[repeatedCharCount] + char;
  125. repeatedCharCount = 0;
  126. }
  127. }
  128. if (result.length < 0) {
  129. switch (char) {
  130. case " ":
  131. char = "blankspace";
  132. break;
  133. case "\t":
  134. char = "tab";
  135. }
  136. repeatedCharCount = repeatedCharCount > 8 ? 8 : repeatedCharCount;
  137. result = count[repeatedCharCount] + char;
  138. }
  139. result = result.replace(/^ & /, "");
  140. return result;
  141. }
  142. exports.indentDecode = indentDecode;
  143. function Compress(input) {
  144. input = input.replace(/\r\n/g, '');
  145. input = input.replace(/[\t ]+/g, ' ');
  146. input = input.replace(/[ ]?([&=:\-<>\+|])[ ]?/g, '$1');
  147. return input;
  148. }
  149. function MixLetters(input) {
  150. let arr = input.split("");
  151. for (var k = 0; k < arr.length; k++) {
  152. if (arr[k] === arr[k].toUpperCase() && Math.random() > 0.5) {
  153. arr[k] = arr[k].toLowerCase();
  154. }
  155. else if (Math.random() > 0.5) {
  156. arr[k] = arr[k].toUpperCase();
  157. }
  158. }
  159. return arr.join("");
  160. }
  161. function EscapeComments(arr, comments, commentIndex) {
  162. for (var i = 0; i < arr.length; i++) {
  163. let line = arr[i];
  164. var firstCharIndex = line.regexIndexOf(/[a-zA-Z0-9\(\&\)%_\+'"|]/);
  165. var commentStartIndex = line.indexOf("--");
  166. if (firstCharIndex < commentStartIndex && firstCharIndex >= 0) {
  167. comments.push(line.substr(commentStartIndex));
  168. arr[i] = line.substr(firstCharIndex, commentStartIndex - firstCharIndex) + ILCommentPrefix + (commentIndex++);
  169. }
  170. else if ((firstCharIndex > commentStartIndex && commentStartIndex >= 0) || (firstCharIndex < 0 && commentStartIndex >= 0)) {
  171. comments.push(line.substr(commentStartIndex));
  172. arr[i] = ILCommentPrefix + (commentIndex++);
  173. }
  174. else {
  175. firstCharIndex = firstCharIndex < 0 ? 0 : firstCharIndex;
  176. arr[i] = line.substr(firstCharIndex);
  177. }
  178. }
  179. return commentIndex;
  180. }
  181. function ToLowerCases(arr) {
  182. for (var i = 0; i < arr.length; i++) {
  183. arr[i] = arr[i].toLowerCase();
  184. }
  185. }
  186. function ToCamelCases(arr) {
  187. for (var i = 0; i < arr.length; i++) {
  188. arr[i] = arr[i].charAt(0) + arr[i].slice(1).toLowerCase();
  189. }
  190. }
  191. function ReplaceKeyWords(text, keywords) {
  192. for (var k = 0; k < keywords.length; k++) {
  193. text = text.replace(new RegExp("([^a-zA-Z0-9_@]|^)" + keywords[k] + "([^a-zA-Z0-9_]|$)", 'gi'), "$1" + keywords[k] + "$2");
  194. }
  195. return text;
  196. }
  197. function SetKeywordCase(input, keywordcase, keywords, typenames) {
  198. let inputcase = keywordcase.toLowerCase();
  199. if (inputcase == "lowercase") {
  200. ToLowerCases(keywords);
  201. ToLowerCases(typenames);
  202. }
  203. else if (inputcase == "defaultcase") {
  204. ToCamelCases(keywords);
  205. ToCamelCases(typenames);
  206. }
  207. if (inputcase != "uppercase") {
  208. input = ReplaceKeyWords(input, keywords);
  209. input = ReplaceKeyWords(input, typenames);
  210. }
  211. return input;
  212. }
  213. function SetNewLinesAfterSymbols(text, newLineSettings) {
  214. if (newLineSettings == null) {
  215. return text;
  216. }
  217. if (newLineSettings.newLineAfter != null) {
  218. newLineSettings.newLineAfter.forEach(symbol => {
  219. let regex = new RegExp("(" + symbol.toUpperCase() + ")[ ]?([^ \r\n@])", "g");
  220. text = text.replace(regex, '$1\r\n$2');
  221. });
  222. }
  223. if (newLineSettings.noNewLineAfter != null) {
  224. newLineSettings.noNewLineAfter.forEach(symbol => {
  225. let regex = new RegExp("(" + symbol.toUpperCase() + ")[ \r\n]+([^@])", "g");
  226. text = text.replace(regex, '$1 $2');
  227. });
  228. }
  229. return text;
  230. }
  231. exports.SetNewLinesAfterSymbols = SetNewLinesAfterSymbols;
  232. class BeautifierSettings {
  233. constructor(removeComments, removeReport, checkAlias, signAlign, signAlignAll, keywordCase, indentation, newLineSettings) {
  234. this.RemoveComments = removeComments;
  235. this.RemoveAsserts = removeReport;
  236. this.CheckAlias = checkAlias;
  237. this.SignAlign = signAlign;
  238. this.SignAlignAll = signAlignAll;
  239. this.KeywordCase = keywordCase;
  240. this.Indentation = indentation;
  241. this.NewLineSettings = newLineSettings;
  242. }
  243. }
  244. exports.BeautifierSettings = BeautifierSettings;
  245. let KeyWords = ["ABS", "ACCESS", "AFTER", "ALIAS", "ALL", "AND", "ARCHITECTURE", "ARRAY", "ASSERT", "ATTRIBUTE", "BEGIN", "BLOCK", "BODY", "BUFFER", "BUS", "CASE", "COMPONENT", "CONFIGURATION", "CONSTANT", "CONTEXT", "COVER", "DISCONNECT", "DOWNTO", "DEFAULT", "ELSE", "ELSIF", "END", "ENTITY", "EXIT", "FAIRNESS", "FILE", "FOR", "FORCE", "FUNCTION", "GENERATE", "GENERIC", "GROUP", "GUARDED", "IF", "IMPURE", "IN", "INERTIAL", "INOUT", "IS", "LABEL", "LIBRARY", "LINKAGE", "LITERAL", "LOOP", "MAP", "MOD", "NAND", "NEW", "NEXT", "NOR", "NOT", "NULL", "OF", "ON", "OPEN", "OR", "OTHERS", "OUT", "PACKAGE", "PORT", "POSTPONED", "PROCEDURE", "PROCESS", "PROPERTY", "PROTECTED", "PURE", "RANGE", "RECORD", "REGISTER", "REJECT", "RELEASE", "REM", "REPORT", "RESTRICT", "RESTRICT_GUARANTEE", "RETURN", "ROL", "ROR", "SELECT", "SEQUENCE", "SEVERITY", "SHARED", "SIGNAL", "SLA", "SLL", "SRA", "SRL", "STRONG", "SUBTYPE", "THEN", "TO", "TRANSPORT", "TYPE", "UNAFFECTED", "UNITS", "UNTIL", "USE", "VARIABLE", "VMODE", "VPROP", "VUNIT", "WAIT", "WHEN", "WHILE", "WITH", "XNOR", "XOR"];
  246. let TypeNames = ["BOOLEAN", "BIT", "CHARACTER", "INTEGER", "TIME", "NATURAL", "POSITIVE", "STRING"];
  247. function beautify(input, settings) {
  248. var arr = input.split("\r\n");
  249. var comments = [], commentsIndex = 0;
  250. commentsIndex = EscapeComments(arr, comments, commentsIndex);
  251. if (settings.RemoveComments) {
  252. input = input.replace(/@@comments[0-9]+/g, '');
  253. commentsIndex = 0;
  254. }
  255. input = arr.join("\r\n");
  256. input = RemoveExtraNewLines(input);
  257. input = input.replace(/[\t ]+/g, ' ');
  258. input = input.replace(/\([\t ]+/g, '\(');
  259. input = input.replace(/[ ]+;/g, ';');
  260. input = input.replace(/:[ ]*(PROCESS|ENTITY)/gi, ':$1');
  261. input = ReplaceKeyWords(input, KeyWords);
  262. input = ReplaceKeyWords(input, TypeNames);
  263. arr = input.split("\r\n");
  264. ReserveSemicolonInKeywords(arr);
  265. input = arr.join("\r\n");
  266. input = input.replace(/(PORT|PROCESS|GENERIC)[\s]*\(/g, '$1 (');
  267. input = SetNewLinesAfterSymbols(input, settings.NewLineSettings);
  268. //input = beautify2(input, settings);
  269. //new
  270. arr = input.split("\r\n");
  271. let result = [];
  272. beautify3(arr, result, settings, 0, 0);
  273. arr = FormattedLineToString(result, settings.Indentation);
  274. input = arr.join("\r\n");
  275. for (var k = 0; k < commentsIndex; k++) {
  276. input = input.replace(ILCommentPrefix + k, comments[k]);
  277. }
  278. input = input.replace(/@@semicolon/g, ";");
  279. input = input.replace(/@@[a-z]+/g, "");
  280. return input;
  281. }
  282. exports.beautify = beautify;
  283. class FormattedLine {
  284. constructor(line, indent) {
  285. this.Line = line;
  286. this.Indent = indent;
  287. }
  288. }
  289. exports.FormattedLine = FormattedLine;
  290. function FormattedLineToString(arr, indentation) {
  291. let result = [];
  292. if (arr == null) {
  293. return result;
  294. }
  295. arr.forEach(i => {
  296. if (i instanceof FormattedLine) {
  297. result.push((Array(i.Indent).join(indentation)) + i.Line);
  298. }
  299. else {
  300. result = result.concat(FormattedLineToString(i, indentation));
  301. }
  302. });
  303. return result;
  304. }
  305. function beautifyCaseBlock(inputs, result, settings, startIndex, indent, isFirstKeyWord) {
  306. if (!inputs[startIndex].regexStartsWith(/(CASE)([\s]|$)/)) {
  307. return startIndex;
  308. }
  309. result.push(new FormattedLine(inputs[startIndex], indent));
  310. let i = beautify3(inputs, result, settings, startIndex + 1, indent + 2);
  311. result[i].Indent = indent;
  312. return i;
  313. }
  314. exports.beautifyCaseBlock = beautifyCaseBlock;
  315. function beautify3(inputs, result, settings, startIndex, indent, isFirstKeyWord) {
  316. let i;
  317. let ignoreFirstKeyWords = ["WHEN"];
  318. let blockMidKeyWords = ["ELSE", "ELSIF"].concat(ignoreFirstKeyWords);
  319. let blockStartsKeyWords = ["IF", "CASE"];
  320. let blockEndsKeyWords = ["END"];
  321. let ignoreFirstKeyWordsStr = ignoreFirstKeyWords.join("|");
  322. let newLineAfterKeyWordsStr = blockStartsKeyWords.join("|");
  323. let blockEndKeyWordsStr = blockEndsKeyWords.join("|");
  324. let blockMidKeyWordsStr = blockMidKeyWords.join("|");
  325. let regexBlockMidKeyWords = new RegExp("(" + blockMidKeyWordsStr + ")([\\s]|$)");
  326. let regexIgnoreFirstKeyWords = new RegExp("(" + ignoreFirstKeyWordsStr + ")([\\s]|$)");
  327. let regexBlockStartsKeywords = new RegExp("(" + newLineAfterKeyWordsStr + ")([\\s]|$)");
  328. let regexBlockEndsKeyWords = new RegExp("(" + blockEndKeyWordsStr + ")([\\s]|$)");
  329. for (i = startIndex; i < inputs.length; i++) {
  330. let input = inputs[i];
  331. if (input.regexStartsWith(/(CASE)([\s]|$)/)) {
  332. i = beautifyCaseBlock(inputs, result, settings, i, indent);
  333. continue;
  334. }
  335. result.push(new FormattedLine(input, indent));
  336. if (startIndex != 0
  337. && (input.regexStartsWith(regexBlockMidKeyWords))) {
  338. result[i].Indent--;
  339. }
  340. else if (startIndex != 0
  341. && (input.regexStartsWith(regexBlockEndsKeyWords))) {
  342. result[i].Indent--;
  343. return i;
  344. }
  345. if (input.regexStartsWith(regexBlockStartsKeywords)) {
  346. i = beautify3(inputs, result, settings, i + 1, indent + 1);
  347. }
  348. }
  349. i--;
  350. return i;
  351. }
  352. exports.beautify3 = beautify3;
  353. function beautify2(input, settings) {
  354. let arr = input.split("\r\n");
  355. let quotes = EscapeQuotes(arr);
  356. if (settings.RemoveAsserts) {
  357. RemoveAsserts(arr); //RemoveAsserts must be after EscapeQuotes
  358. }
  359. ApplyNoNewLineAfter(arr, settings.NewLineSettings.noNewLineAfter);
  360. var align = [], align_max = [], align_i1 = 0, align_i = 0;
  361. var str = "", str1 = "";
  362. var p = 0;
  363. var n = 0, j = 0;
  364. var tab_n = 0, str_len = 0, port_s = "";
  365. var back_tab = false, forward_tab = false, semi_pos = 0, begin_b = true, port_b = false;
  366. var before_begin = true;
  367. var l = arr.length;
  368. for (i = 0; i < l; i++) {
  369. if (arr[i].indexOf("BEGIN") >= 0) {
  370. before_begin = false;
  371. }
  372. if (port_s) {
  373. port_s += arr[i];
  374. var k_port = port_s.split("(").length;
  375. if (k_port == port_s.split(")").length) {
  376. arr[i] = arr[i] + "@@end";
  377. port_s = "";
  378. port_b = false;
  379. }
  380. }
  381. if ((!port_b && arr[i].regexIndexOf(/(\s|\(|^)(PORT|GENERIC|PROCESS|PROCEDURE)(\s|\(|$)/) >= 0)
  382. || (arr[i].regexIndexOf(/:[ ]?=[ ]?\(/) >= 0 && before_begin)) {
  383. port_b = true;
  384. port_s = arr[i];
  385. var k_port = port_s.split("(").length;
  386. if (k_port == 1) {
  387. port_b = false;
  388. port_s = "";
  389. }
  390. else if (k_port == port_s.split(")").length) {
  391. port_s = "";
  392. port_b = false;
  393. arr[i] = arr[i] + "@@singleend";
  394. }
  395. else {
  396. arr[i] = arr[i].replace(/(PORT|GENERIC|PROCEDURE)([a-z0-9A-Z_ ]+)\(([a-zA-Z0-9_\(\) ]+)/, '$1$2(\r\n$3');
  397. }
  398. }
  399. }
  400. input = arr.join("\r\n");
  401. input = input.replace(/([a-zA-Z0-9\); ])\);(@@comments[0-9]+)?@@end/g, '$1\r\n);$2@@end');
  402. input = input.replace(/[ ]?([&=:\-<>\+|\*])[ ]?/g, ' $1 ');
  403. input = input.replace(/[ ]?([,])[ ]?/g, '$1 ');
  404. input = input.replace(/[ ]?(['"])(THEN)/g, '$1 $2');
  405. input = input.replace(/[ ]?(\?)?[ ]?(<|:|>|\/)?[ ]+(=)?[ ]?/g, ' $1$2$3 ');
  406. input = input.replace(/(IF)[ ]?([\(\)])/g, '$1 $2');
  407. input = input.replace(/([\(\)])[ ]?(THEN)/gi, '$1 $2');
  408. input = input.replace(/(^|[\(\)])[ ]?(AND|OR|XOR|XNOR)[ ]*([\(])/g, '$1 $2 $3');
  409. input = input.replace(/ ([\-\*\/=+<>])[ ]*([\-\*\/=+<>]) /g, " $1$2 ");
  410. input = input.replace(/\r\n[ \t]+--\r\n/g, "\r\n");
  411. input = input.replace(/[ ]+/g, ' ');
  412. input = input.replace(/\r\n\r\n\r\n/g, '\r\n');
  413. input = input.replace(/[\r\n\s]+$/g, '');
  414. input = input.replace(/[ \t]+\)/g, ')');
  415. var matches = input.match(/'([a-zA-Z]+)\s/g);
  416. if (matches != null) {
  417. for (var k2 = 0; k2 < matches.length; k2++) {
  418. input = input.replace(matches[k2], matches[k2].toUpperCase());
  419. }
  420. }
  421. input = input.replace(/(MAP)[ \r\n]+\(/g, '$1(');
  422. //input = input.replace(/(;|THEN)[ ]?(@@comments[0-9]+)([a-zA-Z])/g, '$1 $2\r\n$3');
  423. input = input.replace(/[\r\n ]+RETURN/g, ' RETURN');
  424. input = input.replace(/BEGIN[\r\n ]+/g, 'BEGIN\r\n');
  425. input = input.replace(/ (PORT|GENERIC) /g, '\r\n$1 ');
  426. if (settings.CheckAlias) {
  427. var alias = [], subarr = [], o = 0, p = 0, p2 = 0, l2 = 0, i2 = 0;
  428. arr = input.split("ARCHITECTURE ");
  429. l = arr.length;
  430. for (i = 0; i < l; i++) {
  431. subarr = arr[i].split("ALIAS ");
  432. l2 = subarr.length;
  433. if (l2 > 1) {
  434. o = 0;
  435. for (i2 = 1; i2 < l2; i2++) {
  436. o = subarr[i2].indexOf(";", n);
  437. str = subarr[i2].substring(0, o);
  438. alias[p2++] = str.split(" IS ");
  439. }
  440. i2--;
  441. var str2 = subarr[i2].substr(o);
  442. for (p = 0; p < p2; p++) {
  443. var reg = new RegExp(alias[p][1], 'gi');
  444. str2 = str2.replace(reg, alias[p][0]);
  445. }
  446. subarr[i2] = subarr[i2].substring(0, o) + str2;
  447. }
  448. arr[i] = subarr.join("ALIAS ");
  449. }
  450. input = arr.join("ARCHITECTURE ");
  451. }
  452. arr = input.split("\r\n");
  453. l = arr.length;
  454. var signAlignPos = "";
  455. var if_b = 0, white_space = "", case_b = false, case_n = 0, procfun_b = false, semi_b = false, set_false = false, entity_b = false, then_b = false, conditional_b = false, generic_map_b = false, architecture_begin_b = false, process_begin_b = false, case_indent = [0, 0, 0, 0, 0, 0, 0];
  456. var align_groups = [], align_groups_max = [], lastAlignedSign = "", current_align_group = 0, aligned_group_starts = 0;
  457. var indent_start = [];
  458. for (i = 0; i < l; i++) {
  459. str = arr[i];
  460. str_len = str.length;
  461. if (str.replace(/[ \-\t]*/, "").length > 0) {
  462. var first_word = str.split(/[^\w]/)[0];
  463. var indent_start_last = indent_start.length == 0 ? 0 : indent_start[indent_start.length - 1];
  464. if (then_b) {
  465. arr[i] = " " + arr[i];
  466. if (str.indexOf(" THEN") >= 0) {
  467. then_b = false;
  468. back_tab = true;
  469. }
  470. }
  471. arr[i] = white_space + arr[i];
  472. if (first_word == "ELSIF") {
  473. tab_n = indent_start_last - 1;
  474. indent_start.pop();
  475. back_tab = true;
  476. }
  477. else if (str.indexOf("END CASE") == 0) {
  478. indent_start.pop();
  479. case_n--;
  480. tab_n = indent_start[indent_start.length - 1];
  481. }
  482. else if (first_word == "END") {
  483. tab_n = indent_start_last - 1;
  484. indent_start.pop();
  485. if (str.indexOf("END IF") == 0) {
  486. if_b--;
  487. }
  488. if (i == l - 1) {
  489. tab_n = 1;
  490. }
  491. }
  492. else if (first_word == "ELSE" && if_b) {
  493. tab_n = indent_start_last - 1;
  494. indent_start.pop();
  495. back_tab = true;
  496. }
  497. else if (case_n) {
  498. if (first_word == "WHEN") {
  499. tab_n = case_indent[case_n - 1];
  500. //back_tab = true;
  501. }
  502. }
  503. else if (first_word == "BEGIN") {
  504. if (begin_b) {
  505. if (architecture_begin_b) {
  506. tab_n = indent_start_last - 1;
  507. architecture_begin_b = false;
  508. }
  509. else if (process_begin_b) {
  510. tab_n = indent_start_last - 1;
  511. process_begin_b = false;
  512. }
  513. else {
  514. tab_n = indent_start_last;
  515. indent_start.push(tab_n + 1);
  516. }
  517. //indent_start.pop();
  518. back_tab = true;
  519. begin_b = false;
  520. if (procfun_b) {
  521. tab_n++;
  522. indent_start.push(tab_n);
  523. begin_b = true;
  524. }
  525. }
  526. else {
  527. back_tab = true;
  528. }
  529. }
  530. else if (first_word == "PROCESS") {
  531. begin_b = true;
  532. }
  533. else if (str.indexOf(": PROCESS") >= 0) {
  534. back_tab = true;
  535. begin_b = true;
  536. process_begin_b = true;
  537. }
  538. else if (str.indexOf(": ENTITY") >= 0) {
  539. back_tab = true;
  540. entity_b = true;
  541. }
  542. else if (str.indexOf("PROCEDURE ") >= 0) {
  543. back_tab = true;
  544. begin_b = true;
  545. }
  546. if (port_b && str.indexOf("@@") < 0) {
  547. if (i + 1 <= arr.length - 1 && arr[i + 1].indexOf("@@") < 0) {
  548. if (signAlignPos == ":") {
  549. if (str.indexOf(';') < 0) {
  550. arr[i] += arr[i + 1];
  551. arr[i + 1] = '@@removeline';
  552. }
  553. }
  554. else if (signAlignPos == "=>") {
  555. if (str.indexOf(',') < 0) {
  556. arr[i] += arr[i + 1];
  557. arr[i + 1] = '@@removeline';
  558. }
  559. }
  560. }
  561. }
  562. if (str.indexOf("PORT MAP") >= 0) {
  563. back_tab = true;
  564. port_b = true;
  565. if (str.indexOf(");") < 0) {
  566. align_i1 = align_i;
  567. var t = str.indexOf("=>");
  568. if (t >= 0) {
  569. signAlignPos = "=>";
  570. }
  571. else {
  572. if (i + 1 < arr.length) {
  573. t = arr[i + 1].indexOf("=>");
  574. if (t >= 0) {
  575. signAlignPos = "=>";
  576. }
  577. }
  578. }
  579. }
  580. else {
  581. signAlignPos = "";
  582. }
  583. }
  584. else if (str.indexOf("GENERIC MAP") >= 0) {
  585. tab_n++;
  586. indent_start.push(tab_n);
  587. generic_map_b = true;
  588. if (!begin_b) {
  589. back_tab = false;
  590. }
  591. }
  592. else if (str.indexOf("PORT (") >= 0 && begin_b) {
  593. back_tab = true;
  594. port_b = true;
  595. t = str.indexOf(":");
  596. if (str.indexOf(");") < 0) {
  597. align_i1 = align_i;
  598. if (t >= 0) {
  599. signAlignPos = ":";
  600. }
  601. else {
  602. t = arr[i + 1].indexOf(":");
  603. if (t >= 0) {
  604. signAlignPos = ":";
  605. }
  606. }
  607. }
  608. else {
  609. signAlignPos = "";
  610. }
  611. }
  612. if (set_false) {
  613. procfun_b = false;
  614. set_false = false;
  615. }
  616. if (str.indexOf("(") >= 0) {
  617. if (str.indexOf("PROCEDURE") >= 0 || str.indexOf("FUNCTION") >= 0) {
  618. procfun_b = true;
  619. back_tab = true;
  620. }
  621. if ((str.indexOf("GENERIC") >= 0 || str.indexOf(":= (") >= 0 || str.regexIndexOf(/PROCEDURE[a-zA-Z0-9_ ]+\(/) >= 0) && begin_b) {
  622. port_b = true;
  623. back_tab = true;
  624. }
  625. }
  626. else if (first_word == "FUNCTION") {
  627. back_tab = true;
  628. begin_b = true;
  629. }
  630. if (str.indexOf("@@singleend") >= 0) {
  631. back_tab = false;
  632. port_b = false;
  633. if (!begin_b) {
  634. forward_tab = true;
  635. }
  636. }
  637. else if (str.indexOf("@@end") >= 0 && port_b) {
  638. port_b = false;
  639. indent_start.pop();
  640. tab_n = indent_start[indent_start.length - 1];
  641. if (entity_b) {
  642. forward_tab = true;
  643. }
  644. if (generic_map_b) {
  645. forward_tab = true;
  646. generic_map_b = false;
  647. }
  648. }
  649. if (settings.SignAlignAll) {
  650. var alignedSigns = [":", "<=", "=>"];
  651. for (var currentSign = 0; currentSign < alignedSigns.length; currentSign++) {
  652. if (str.indexOf(alignedSigns[currentSign]) > 0) {
  653. var char_before_sign = str.split(alignedSigns[currentSign])[0];
  654. var char_before_sign_length = char_before_sign.length;
  655. align_groups.push(char_before_sign_length);
  656. align_groups_max.push(char_before_sign_length);
  657. if (alignedSigns[currentSign] == lastAlignedSign) {
  658. if (align_groups_max[current_align_group - 1] < char_before_sign_length) {
  659. for (var k3 = aligned_group_starts; k3 <= current_align_group; k3++) {
  660. align_groups_max[k3] = char_before_sign_length;
  661. }
  662. }
  663. else {
  664. align_groups_max[current_align_group] = align_groups_max[current_align_group - 1];
  665. }
  666. }
  667. else {
  668. aligned_group_starts = current_align_group;
  669. }
  670. arr[i] = char_before_sign + "@@alignall" + (current_align_group++) + str.substring(char_before_sign.length, arr[i].length);
  671. lastAlignedSign = alignedSigns[currentSign];
  672. break;
  673. }
  674. }
  675. if (currentSign == alignedSigns.length) {
  676. lastAlignedSign = "";
  677. }
  678. }
  679. else if (settings.SignAlign) {
  680. if (port_b && signAlignPos != "") {
  681. if (str.indexOf(signAlignPos) >= 0) {
  682. var a1 = arr[i].split(signAlignPos);
  683. var l1 = a1[0].length;
  684. if (align_i >= 0 && align_i > align_i1) {
  685. align_max[align_i] = align_max[align_i - 1];
  686. }
  687. else {
  688. align_max[align_i] = l1;
  689. }
  690. if (align_i > align_i1 && align_max[align_i] < l1) {
  691. for (var k3 = align_i1; k3 <= align_i; k3++) {
  692. align_max[k3] = l1;
  693. }
  694. }
  695. align[align_i] = l1;
  696. arr[i] = a1[0] + "@@align" + (align_i++) + signAlignPos + arr[i].substring(l1 + signAlignPos.length, arr[i].length);
  697. }
  698. }
  699. }
  700. tab_n = tab_n < 1 ? 1 : tab_n;
  701. if (str_len) {
  702. if (isTesting) {
  703. console.log(tab_n, arr[i], indent_start);
  704. }
  705. arr[i] = (Array(tab_n).join(settings.Indentation)) + arr[i]; //indent
  706. if (settings.NewLineSettings.newLineAfter.indexOf("port")) {
  707. if (str.indexOf('@@singleend') < 0) {
  708. arr[i] = arr[i].replace(/(PORT)([ \r\n\w]*)\(/, "$1$2\r\n" + (Array(tab_n).join(settings.Indentation)) + "(");
  709. }
  710. }
  711. if (settings.NewLineSettings.newLineAfter.indexOf("generic")) {
  712. if (str.indexOf('@@singleend') < 0) {
  713. arr[i] = arr[i].replace(/(GENERIC)([ \r\n\w]*)\(/, "$1$2\r\n" + (Array(tab_n).join(settings.Indentation)) + "(");
  714. }
  715. }
  716. }
  717. if (back_tab) {
  718. tab_n++;
  719. indent_start.push(tab_n);
  720. back_tab = false;
  721. }
  722. if (forward_tab) {
  723. tab_n = indent_start_last;
  724. indent_start.pop();
  725. forward_tab = false;
  726. }
  727. if (conditional_b && str.indexOf(";") >= 0) {
  728. conditional_b = false;
  729. white_space = "";
  730. }
  731. else if (str.indexOf(";") >= 0 && semi_b) {
  732. semi_b = false;
  733. tab_n = indent_start_last;
  734. indent_start.pop();
  735. }
  736. else if (!semi_b && str.indexOf(";") < 0 && !port_b) {
  737. if (!conditional_b) {
  738. if (str.indexOf("WHEN") > 3 && str.indexOf("<=") > 1) {
  739. conditional_b = true;
  740. white_space = (Array(str.indexOf("= ") + 3).join(" "));
  741. }
  742. else if (first_word == "WHEN" && i + 1 < arr.length && arr[i + 1].indexOf("WHEN") < 0) {
  743. tab_n = indent_start_last + 1;
  744. }
  745. else if (str.indexOf("=>") < 0 && ((str.indexOf(ILQuotesPrefix) >= 0 && str.indexOf("= " + ILQuotesPrefix) < 0 && str.indexOf("IF") < 0) || (str.indexOf("<=") > 0 && str.indexOf("IF") < 0 && str.indexOf("THEN") < 0))) {
  746. tab_n++;
  747. indent_start.push(tab_n);
  748. semi_b = true;
  749. }
  750. }
  751. }
  752. if (first_word == "ENTITY") {
  753. tab_n++;
  754. indent_start.push(tab_n);
  755. }
  756. else if (",RECORD,PACKAGE,FOR,COMPONENT,CONFIGURATION,".indexOf("," + first_word + ",") >= 0) {
  757. tab_n++;
  758. indent_start.push(tab_n);
  759. }
  760. else if (str.indexOf(": FOR ") >= 0) {
  761. tab_n++;
  762. indent_start.push(tab_n);
  763. }
  764. else if (first_word == "CASE" || str.indexOf(": CASE") >= 0) {
  765. tab_n++;
  766. indent_start.push(tab_n);
  767. case_indent[case_n] = tab_n;
  768. case_n++;
  769. }
  770. else if (first_word == "ARCHITECTURE") {
  771. tab_n++;
  772. indent_start.push(tab_n);
  773. begin_b = true;
  774. architecture_begin_b = true;
  775. }
  776. else if (first_word == "IF") {
  777. if_b++;
  778. tab_n++;
  779. indent_start.push(tab_n);
  780. if (str.indexOf(" THEN") < 0) {
  781. then_b = true;
  782. tab_n = indent_start_last;
  783. //indent_start.pop();
  784. }
  785. }
  786. if (procfun_b) {
  787. if (str.regexIndexOf(/(\))|(RETURN [A-Za-z0-9 ]+)[\r\n ]+IS/) >= 0) {
  788. tab_n = indent_start_last;
  789. indent_start.pop();
  790. set_false = true;
  791. }
  792. }
  793. }
  794. }
  795. input = arr.join("\r\n");
  796. input = input.replace(/[\t]*@@removeline\r\n/g, '');
  797. p = input.indexOf('PROCESS');
  798. while (p >= 0) {
  799. let nextBracket = input.indexOf('(', p);
  800. let nextNewLine = input.indexOf('\r\n', p);
  801. let nextCloseBracket = input.indexOf(')', nextBracket);
  802. if (nextBracket < nextNewLine && nextCloseBracket > nextNewLine) {
  803. let processArray = input.substring(p, nextCloseBracket).split('\r\n');
  804. if (settings.Indentation.replace(/[ ]+/g, '').length == 0) {
  805. for (var i = 1; i < processArray.length; i++) {
  806. processArray[i] = (Array(nextBracket - p + 2).join(' ')) + processArray[i];
  807. }
  808. }
  809. else {
  810. for (var i = 1; i < processArray.length; i++) {
  811. processArray[i] = settings.Indentation + processArray[i];
  812. }
  813. }
  814. input = input.substring(0, p) + processArray.join('\r\n') + input.substring(nextCloseBracket, input.length);
  815. p = input.regexIndexOf('PROCESS[ ]+\\(', nextCloseBracket);
  816. }
  817. else {
  818. p = input.indexOf('PROCESS[ ]+\\(', p + 7);
  819. }
  820. }
  821. input = SetKeywordCase(input, settings.KeywordCase, KeyWords, TypeNames);
  822. if (settings.SignAlignAll) {
  823. for (var k = 0; k < current_align_group; k++) {
  824. input = input.replace("@@alignall" + k, Array((align_groups_max[k] - align_groups[k] + 1)).join(" "));
  825. }
  826. }
  827. if (settings.SignAlign) {
  828. for (var k = 0; k < align_i; k++) {
  829. input = input.replace("@@align" + k, Array((align_max[k] - align[k] + 2)).join(" "));
  830. }
  831. }
  832. for (var k = 0; k < quotes.length; k++) {
  833. input = input.replace(ILQuotesPrefix + k, quotes[k]);
  834. }
  835. input = input.replace(/@@singleline[ \r\n]*/, " ");
  836. return input;
  837. }
  838. function ReserveSemicolonInKeywords(arr) {
  839. for (let i = 0; i < arr.length; i++) {
  840. if (arr[i].match(/FUNCTION|PROCEDURE/) != null) {
  841. arr[i] = arr[i].replace(/;/g, '@@semicolon');
  842. }
  843. }
  844. }
  845. function ApplyNoNewLineAfter(arr, noNewLineAfter) {
  846. if (noNewLineAfter == null) {
  847. return;
  848. }
  849. for (let i = 0; i < arr.length; i++) {
  850. noNewLineAfter.forEach(n => {
  851. let regex = new RegExp("(" + n.toUpperCase + ")[ a-z0-9]+[a-z0-9]+");
  852. if (arr[i].regexIndexOf(regex) >= 0) {
  853. arr[i] += "@@singleline";
  854. }
  855. });
  856. }
  857. }
  858. exports.ApplyNoNewLineAfter = ApplyNoNewLineAfter;
  859. function RemoveAsserts(arr) {
  860. let need_semi = false;
  861. let inAssert = false;
  862. let n = 0;
  863. for (let i = 0; i < arr.length; i++) {
  864. let has_semi = arr[i].indexOf(";") >= 0;
  865. if (need_semi) {
  866. arr[i] = '';
  867. }
  868. n = arr[i].indexOf("ASSERT ");
  869. if (n >= 0) {
  870. inAssert = true;
  871. arr[i] = '';
  872. }
  873. if (!has_semi) {
  874. if (inAssert) {
  875. need_semi = true;
  876. }
  877. }
  878. else {
  879. need_semi = false;
  880. }
  881. }
  882. }
  883. exports.RemoveAsserts = RemoveAsserts;
  884. function EscapeQuotes(arr) {
  885. let quotes = [];
  886. let quotesIndex = 0;
  887. for (let i = 0; i < arr.length; i++) {
  888. let quote = arr[i].match(/"([^"]+)"/g);
  889. if (quote != null) {
  890. for (var j = 0; j < quote.length; j++) {
  891. arr[i] = arr[i].replace(quote[j], ILQuotesPrefix + quotesIndex);
  892. quotes[quotesIndex++] = quote[j];
  893. }
  894. }
  895. }
  896. return quotes;
  897. }
  898. function RemoveExtraNewLines(input) {
  899. input = input.replace(/(?:\r\n|\r|\n)/g, '\r\n');
  900. input = input.replace(/ \r\n/g, '\r\n');
  901. input = input.replace(/\r\n\r\n\r\n/g, '\r\n');
  902. return input;
  903. }
  904. //# sourceMappingURL=VHDLFormatter.js.map