@bbob/parser
Advanced tools
Comparing version 2.5.1 to 2.5.2
@@ -6,2 +6,18 @@ # Change Log | ||
<a name="2.5.2"></a> | ||
## [2.5.2](https://github.com/JiLiZART/bbob/compare/v2.4.1...v2.5.2) (2019-06-30) | ||
### Bug Fixes | ||
* **parser:** infinity loop problem when escape `[\b]` ([#31](https://github.com/JiLiZART/bbob/issues/31)) ([b4cf271](https://github.com/JiLiZART/bbob/commit/b4cf271)), closes [#23](https://github.com/JiLiZART/bbob/issues/23) | ||
### Features | ||
* **parse:** allow tags to be escaped with backslash ([#17](https://github.com/JiLiZART/bbob/issues/17)) ([c4f78c1](https://github.com/JiLiZART/bbob/commit/c4f78c1)) | ||
<a name="2.5.1"></a> | ||
@@ -8,0 +24,0 @@ ## [2.5.1](https://github.com/JiLiZART/bbob/compare/v2.4.1...v2.5.1) (2019-06-18) |
@@ -146,2 +146,7 @@ (function (global, factory) { | ||
var attrsToString = function attrsToString(values) { | ||
// To avoid some malformed attributes | ||
if (typeof values === 'undefined') { | ||
return ''; | ||
} | ||
return Object.keys(values).reduce(function (arr, key) { | ||
@@ -598,5 +603,8 @@ return [].concat(arr, [attrValue(key, values[key])]); | ||
var closeTag = options.closeTag || char_10; | ||
var escapeTags = options.enableEscapeTags; | ||
var RESERVED_CHARS = [closeTag, openTag, char_7, char_14, char_8, char_5, char_6, char_2, EM]; | ||
var NOT_CHAR_TOKENS = [].concat(options.enableEscapeTags ? [char_14] : [], [openTag, char_8, char_5, char_2]); | ||
var NOT_CHAR_TOKENS = [ | ||
// ...(options.enableEscapeTags ? [BACKSLASH] : []), | ||
openTag, char_8, char_5, char_2]; | ||
var WHITESPACES = [char_8, char_5]; | ||
@@ -617,2 +625,8 @@ var SPECIAL_CHARS = [char_6, char_8, char_5]; | ||
}; | ||
var isEscapableChar = function isEscapableChar(char$$1) { | ||
return char$$1 === openTag || char$$1 === closeTag || char$$1 === char_14; | ||
}; | ||
var isEscapeChar = function isEscapeChar(char$$1) { | ||
return char$$1 === char_14; | ||
}; | ||
@@ -714,10 +728,6 @@ /** | ||
emitToken(createToken(TYPE_SPACE, str, row, col)); | ||
} else if (options.enableEscapeTags && currChar === char_14 && (nextChar === openTag || nextChar === closeTag)) { | ||
} else if (escapeTags && isEscapeChar(currChar) && isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); // skip the \ without emitting anything | ||
bufferGrabber.skip(); // skip past the [ or ] as well | ||
bufferGrabber.skip(); // skip past the [, ] or \ as well | ||
emitToken(createToken(TYPE_WORD, nextChar, row, col)); | ||
} else if (options.enableEscapeTags && currChar === char_14 && nextChar === char_14) { | ||
bufferGrabber.skip(); // skip the first \ without emitting anything | ||
bufferGrabber.skip(); // skip past the second \ and emit it | ||
emitToken(createToken(TYPE_WORD, nextChar, row, col)); | ||
} else if (currChar === openTag) { | ||
@@ -758,5 +768,15 @@ bufferGrabber.skip(); // skip openTag | ||
} else if (isCharToken(currChar)) { | ||
var _str2 = bufferGrabber.grabWhile(isCharToken); | ||
if (escapeTags && isEscapeChar(currChar) && !isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); | ||
emitToken(createToken(TYPE_WORD, currChar, row, col)); | ||
} else { | ||
var _str2 = bufferGrabber.grabWhile(function (char$$1) { | ||
if (escapeTags) { | ||
return isCharToken(char$$1) && !isEscapeChar(char$$1); | ||
} | ||
return isCharToken(char$$1); | ||
}); | ||
emitToken(createToken(TYPE_WORD, _str2, row, col)); | ||
emitToken(createToken(TYPE_WORD, _str2, row, col)); | ||
} | ||
} | ||
@@ -763,0 +783,0 @@ }; |
@@ -1,1 +0,1 @@ | ||
!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n(t.BbobParser={})}(this,function(t){"use strict";function n(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}function e(t,n){return t(n={exports:{}},n.exports),n.exports}var a=e(function(t,n){n.__esModule=!0;n.N="\n",n.F="\f",n.R="\r",n.TAB="\t",n.EQ="=",n.QUOTEMARK='"',n.SPACE=" ",n.OPEN_BRAKET="[",n.CLOSE_BRAKET="]",n.SLASH="/",n.PLACEHOLDER_SPACE_TAB=" ",n.PLACEHOLDER_SPACE=" ",n.BACKSLASH="\\"});n(a);var E=a.N,u=a.TAB,N=a.EQ,b=a.QUOTEMARK,L=a.SPACE,O=a.OPEN_BRAKET,S=a.CLOSE_BRAKET,x=a.SLASH,k=a.BACKSLASH,o=e(function(t,n){n.__esModule=!0,n.isEOL=n.isStringNode=n.isTagNode=n.getNodeLength=n.appendToNode=n.attrValue=n.attrsToString=void 0;var r=function(t){return"object"==typeof t&&!!t.tag},o=function(t){return"string"==typeof t},i=function(t){return t.replace(/"/g,""")},u=function(t,n){var e=typeof n,r={boolean:function(){return n?""+t:""},number:function(){return t+'="'+n+'"'},string:function(){return t+'="'+i(n)+'"'},object:function(){return t+'="'+i(JSON.stringify(n))+'"'}};return r[e]?r[e]():""};n.attrsToString=function(e){return Object.keys(e).reduce(function(t,n){return[].concat(t,[u(n,e[n])])},[""]).join(" ")},n.attrValue=u,n.appendToNode=function(t,n){t.content.push(n)},n.getNodeLength=function e(t){return r(t)?t.content.reduce(function(t,n){return t+e(n)},0):o(t)?t.length:0},n.isTagNode=r,n.isStringNode=o,n.isEOL=function(t){return t===a.N}});n(o);var r=e(function(t,n){n.__esModule=!0,n.TagNode=void 0;var e=function(){function r(t,n){for(var e=0;e<n.length;e++){var r=n[e];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,r.key,r)}}return function(t,n,e){return n&&r(t.prototype,n),e&&r(t,e),t}}();var r=function(){function r(t,n,e){!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,r),this.tag=t,this.attrs=n,this.content=[].concat(e)}return r.prototype.attr=function(t,n){return void 0!==n&&(this.attrs[t]=n),this.attrs[t]},r.prototype.append=function(t){return(0,o.appendToNode)(this,t)},r.prototype.toString=function(){var t=a.OPEN_BRAKET,n=a.CLOSE_BRAKET;return t+this.tag+n+this.content.reduce(function(t,n){return t+""+n},"")+t+a.SLASH+this.tag+n},e(r,[{key:"length",get:function(){return(0,o.getNodeLength)(this)}}]),r}();r.create=function(t){return new r(t,1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},2<arguments.length&&void 0!==arguments[2]?arguments[2]:[])},r.isOf=function(t,n){return t.tag===n},n.TagNode=r,n.default=r}),h=n(r),i=r.TagNode,s="type",f="value",c="line",l="word",g="attr-name",p="attr-value",d="space",v="new-line",T=function(t){return t[f]},y=function(t){return T(t).charCodeAt(0)==x.charCodeAt(0)},A=function(){function o(t,n,e,r){!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,o),this[s]=t+"",this[f]=n+"",this[c]=+e,this.row=+r}return o.prototype.isEmpty=function(){return!!this[s]},o.prototype.isText=function(){return(t=this)[s]===d||t[s]===v||t[s]===l;var t},o.prototype.isTag=function(){return"tag"===this[s]},o.prototype.isAttrName=function(){return this[s]===g},o.prototype.isAttrValue=function(){return this[s]===p},o.prototype.isStart=function(){return!y(this)},o.prototype.isEnd=function(){return y(this)},o.prototype.getName=function(){return n=T(t=this),y(t)?n.slice(1):n;var t,n},o.prototype.getValue=function(){return T(this)},o.prototype.getLine=function(){return this[c]},o.prototype.getColumn=function(){return this.row},o.prototype.toString=function(){return t=O,t+=T(this),t+=S;var t},o}(),C=l,m=function(e){var t=(1<arguments.length&&void 0!==arguments[1]?arguments[1]:{}).onSkip,r=0,o=function(){r+=1,t&&t()},i=function(){return r<e.length},u=function(){return e.substr(r)},a=function(){return e[r]};return{skip:o,hasNext:i,isLast:function(){return r===e.length},grabWhile:function(t){for(var n=r;i()&&t(a());)o();return e.substr(n,r-n)},getNext:function(){return e[r+1]},getPrev:function(){return e[r-1]},getCurr:a,getRest:u,substrUntilChar:function(t){var n=u(),e=n.indexOf(t);return e<0?"":n.substr(0,e)}}},_=function(){var n=0<arguments.length&&void 0!==arguments[0]?arguments[0]:[];return{getLast:function(){return n.length?n[n.length-1]:null},flushLast:function(){return!!n.length&&n.pop()},push:function(t){return n.push(t)},toArray:function(){return n}}},w=function(t,n){return new A(t,n,2<arguments.length&&void 0!==arguments[2]?arguments[2]:0,3<arguments.length&&void 0!==arguments[3]?arguments[3]:0)};function P(e){var s=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},f=0,c=0,n=-1,r=Array(Math.floor(e.length)),l=s.openTag||O,g=s.closeTag||S,p=[g,l,b,k,L,u,N,E,"!"],o=[].concat(s.enableEscapeTags?[k]:[],[l,L,u,E]),i=[L,u],h=[N,L,u],d=function(t){return 0<=i.indexOf(t)},v=function(t){return-1==o.indexOf(t)},T=function(t){s.onToken&&s.onToken(t),r[n+=1]=t},y=function(t){for(var u=null,a=!1,r=[],s=m(t),o=function(t){var n=t===N,e=d(t),r=s.getPrev(),o=s.getNext(),i=r===k;return null===u?!1===(n||e||s.isLast()):!(!a||h.indexOf(t)<0)||!!(t!==b||i||(a=!a)||o===N||d(o))&&!1===(n||e)},n=function(){var t=s.grabWhile(o),n=s.getCurr();if(null===u)u=t;else if(d(n)||n===b||!s.hasNext()){var e=function(t,n){for(;t.charAt(0)===n;)t=t.substring(1);for(;t.charAt(t.length-1)===n;)t=t.substring(0,t.length-1);return t}(t,b).replace(k+b,b);r.push(w("attr-value",e,f,c))}else r.push(w("attr-name",t,f,c));s.skip()};s.hasNext();)n();return{tag:u,attrs:r}},A=m(e,{onSkip:function(){c++}}),t=function(){var t=A.getCurr(),n=A.getNext();if(t===E)A.skip(),T(w("new-line",t,++f,c=0));else if(d(t)){var e=A.grabWhile(d);T(w("space",e,f,c))}else if(!s.enableEscapeTags||t!==k||n!==l&&n!==g){if(s.enableEscapeTags&&t===k&&n===k)A.skip(),A.skip(),T(w(C,n,f,c));else if(t===l){A.skip();var r=A.substrUntilChar(g),o=0===r.length||0<=r.indexOf(l);if(0<=p.indexOf(n)||o||A.isLast())T(w(C,t,f,c));else{var i=A.grabWhile(function(t){return t!==g});if(A.skip(),-1==i.indexOf(N)||i[0]===x)T(w("tag",i,f,c));else{var u=y(i);T(w("tag",u.tag,f,c)),u.attrs.map(T)}}}else if(t===g)A.skip(),T(w(C,t,f,c));else if(v(t)){var a=A.grabWhile(v);T(w(C,a,f,c))}}else A.skip(),A.skip(),T(w(C,n,f,c))};return{tokenize:function(){for(;A.hasNext();)t();return r.length=n+1,r},isTokenNested:function(t){var n=l+x+t.getValue();return-1<e.indexOf(n)}}}var B=function(t){var n=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},i=n,o=null,e=_(),u=_(),a=_(),s=_(),f={},c=function(){a.flushLast()&&s.flushLast()},l=function(t){var n;(n=u.getLast(),n?n.content:e.toArray()).push(t)},r=function(t){c();var n,e=h.create(t.getValue()),r=(void 0===f[(n=t).getValue()]&&(f[n.getValue()]=o.isTokenNested(n)),f[n.getValue()]);a.push(e),r?u.push(e):l(e)},g=function(t){t.isStart()&&r(t),t.isEnd()&&function(t){c();var n=u.flushLast();if(n)l(n);else if(i.onError){var e=t.getValue(),r=t.getLine(),o=t.getColumn();i.onError({message:"Inconsistent tag '"+e+"' on line "+r+" and column "+o,tagName:e,lineNumber:r,columnNumber:o})}}(t)},p=function(t){var n=a.getLast(),e=t.getValue(),r=!!f[t];if(n)if(t.isAttrName())s.push(e),n.attr(s.getLast(),"");else if(t.isAttrValue()){var o=s.getLast();o?(n.attr(o,e),s.flushLast()):n.attr(e,e)}else t.isText()?r?n.append(e):l(e):t.isTag()&&l(""+t);else t.isText()?l(e):t.isTag()&&l(""+t)};(o=(n.createTokenizer?n.createTokenizer:P)(t,{onToken:function(t){var n;!t.isTag()||(n=t.getName(),i.onlyAllowTags&&i.onlyAllowTags.length&&i.onlyAllowTags.indexOf(n)<0)?p(t):g(t)},onlyAllowTags:i.onlyAllowTags,openTag:i.openTag,closeTag:i.closeTag,enableEscapeTags:i.enableEscapeTags})).tokenize();return e.toArray()};t.default=B,t.parse=B,t.TagNode=i,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n(t.BbobParser={})}(this,function(t){"use strict";function n(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}function e(t,n){return t(n={exports:{}},n.exports),n.exports}var a=e(function(t,n){n.__esModule=!0;n.N="\n",n.F="\f",n.R="\r",n.TAB="\t",n.EQ="=",n.QUOTEMARK='"',n.SPACE=" ",n.OPEN_BRAKET="[",n.CLOSE_BRAKET="]",n.SLASH="/",n.PLACEHOLDER_SPACE_TAB=" ",n.PLACEHOLDER_SPACE=" ",n.BACKSLASH="\\"});n(a);var b=a.N,L=a.TAB,O=a.EQ,S=a.QUOTEMARK,x=a.SPACE,k=a.OPEN_BRAKET,C=a.CLOSE_BRAKET,m=a.SLASH,_=a.BACKSLASH,o=e(function(t,n){n.__esModule=!0,n.isEOL=n.isStringNode=n.isTagNode=n.getNodeLength=n.appendToNode=n.attrValue=n.attrsToString=void 0;var r=function(t){return"object"==typeof t&&!!t.tag},o=function(t){return"string"==typeof t},i=function(t){return t.replace(/"/g,""")},u=function(t,n){var e=typeof n,r={boolean:function(){return n?""+t:""},number:function(){return t+'="'+n+'"'},string:function(){return t+'="'+i(n)+'"'},object:function(){return t+'="'+i(JSON.stringify(n))+'"'}};return r[e]?r[e]():""};n.attrsToString=function(e){return void 0===e?"":Object.keys(e).reduce(function(t,n){return[].concat(t,[u(n,e[n])])},[""]).join(" ")},n.attrValue=u,n.appendToNode=function(t,n){t.content.push(n)},n.getNodeLength=function e(t){return r(t)?t.content.reduce(function(t,n){return t+e(n)},0):o(t)?t.length:0},n.isTagNode=r,n.isStringNode=o,n.isEOL=function(t){return t===a.N}});n(o);var r=e(function(t,n){n.__esModule=!0,n.TagNode=void 0;var e=function(){function r(t,n){for(var e=0;e<n.length;e++){var r=n[e];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,r.key,r)}}return function(t,n,e){return n&&r(t.prototype,n),e&&r(t,e),t}}();var r=function(){function r(t,n,e){!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,r),this.tag=t,this.attrs=n,this.content=[].concat(e)}return r.prototype.attr=function(t,n){return void 0!==n&&(this.attrs[t]=n),this.attrs[t]},r.prototype.append=function(t){return(0,o.appendToNode)(this,t)},r.prototype.toString=function(){var t=a.OPEN_BRAKET,n=a.CLOSE_BRAKET;return t+this.tag+n+this.content.reduce(function(t,n){return t+""+n},"")+t+a.SLASH+this.tag+n},e(r,[{key:"length",get:function(){return(0,o.getNodeLength)(this)}}]),r}();r.create=function(t){return new r(t,1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},2<arguments.length&&void 0!==arguments[2]?arguments[2]:[])},r.isOf=function(t,n){return t.tag===n},n.TagNode=r,n.default=r}),h=n(r),i=r.TagNode,u="type",s="value",f="line",c="word",l="attr-name",g="attr-value",p="space",d="new-line",v=function(t){return t[s]},T=function(t){return v(t).charCodeAt(0)==m.charCodeAt(0)},y=function(){function o(t,n,e,r){!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,o),this[u]=t+"",this[s]=n+"",this[f]=+e,this.row=+r}return o.prototype.isEmpty=function(){return!!this[u]},o.prototype.isText=function(){return(t=this)[u]===p||t[u]===d||t[u]===c;var t},o.prototype.isTag=function(){return"tag"===this[u]},o.prototype.isAttrName=function(){return this[u]===l},o.prototype.isAttrValue=function(){return this[u]===g},o.prototype.isStart=function(){return!T(this)},o.prototype.isEnd=function(){return T(this)},o.prototype.getName=function(){return n=v(t=this),T(t)?n.slice(1):n;var t,n},o.prototype.getValue=function(){return v(this)},o.prototype.getLine=function(){return this[f]},o.prototype.getColumn=function(){return this.row},o.prototype.toString=function(){return t=k,t+=v(this),t+=C;var t},o}(),w=c,P=function(e){var t=(1<arguments.length&&void 0!==arguments[1]?arguments[1]:{}).onSkip,r=0,o=function(){r+=1,t&&t()},i=function(){return r<e.length},u=function(){return e.substr(r)},a=function(){return e[r]};return{skip:o,hasNext:i,isLast:function(){return r===e.length},grabWhile:function(t){for(var n=r;i()&&t(a());)o();return e.substr(n,r-n)},getNext:function(){return e[r+1]},getPrev:function(){return e[r-1]},getCurr:a,getRest:u,substrUntilChar:function(t){var n=u(),e=n.indexOf(t);return e<0?"":n.substr(0,e)}}},A=function(){var n=0<arguments.length&&void 0!==arguments[0]?arguments[0]:[];return{getLast:function(){return n.length?n[n.length-1]:null},flushLast:function(){return!!n.length&&n.pop()},push:function(t){return n.push(t)},toArray:function(){return n}}},B=function(t,n){return new y(t,n,2<arguments.length&&void 0!==arguments[2]?arguments[2]:0,3<arguments.length&&void 0!==arguments[3]?arguments[3]:0)};function N(e){var n=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},f=0,c=0,r=-1,o=Array(Math.floor(e.length)),s=n.openTag||k,l=n.closeTag||C,g=n.enableEscapeTags,p=[l,s,S,_,x,L,O,b,"!"],i=[s,x,L,b],u=[x,L],h=[O,x,L],d=function(t){return 0<=u.indexOf(t)},v=function(t){return-1==i.indexOf(t)},T=function(t){return t===s||t===l||t===_},y=function(t){return t===_},A=function(t){n.onToken&&n.onToken(t),o[r+=1]=t},N=function(t){for(var u=null,a=!1,r=[],s=P(t),o=function(t){var n=t===O,e=d(t),r=s.getPrev(),o=s.getNext(),i=r===_;return null===u?!1===(n||e||s.isLast()):!(!a||h.indexOf(t)<0)||!!(t!==S||i||(a=!a)||o===O||d(o))&&!1===(n||e)},n=function(){var t=s.grabWhile(o),n=s.getCurr();if(null===u)u=t;else if(d(n)||n===S||!s.hasNext()){var e=function(t,n){for(;t.charAt(0)===n;)t=t.substring(1);for(;t.charAt(t.length-1)===n;)t=t.substring(0,t.length-1);return t}(t,S).replace(_+S,S);r.push(B("attr-value",e,f,c))}else r.push(B("attr-name",t,f,c));s.skip()};s.hasNext();)n();return{tag:u,attrs:r}},E=P(e,{onSkip:function(){c++}}),t=function(){var t=E.getCurr(),n=E.getNext();if(t===b)E.skip(),A(B("new-line",t,++f,c=0));else if(d(t)){var e=E.grabWhile(d);A(B("space",e,f,c))}else if(g&&y(t)&&T(n))E.skip(),E.skip(),A(B(w,n,f,c));else if(t===s){E.skip();var r=E.substrUntilChar(l),o=0===r.length||0<=r.indexOf(s);if(0<=p.indexOf(n)||o||E.isLast())A(B(w,t,f,c));else{var i=E.grabWhile(function(t){return t!==l});if(E.skip(),-1==i.indexOf(O)||i[0]===m)A(B("tag",i,f,c));else{var u=N(i);A(B("tag",u.tag,f,c)),u.attrs.map(A)}}}else if(t===l)E.skip(),A(B(w,t,f,c));else if(v(t))if(g&&y(t)&&!T(n))E.skip(),A(B(w,t,f,c));else{var a=E.grabWhile(function(t){return g?v(t)&&!y(t):v(t)});A(B(w,a,f,c))}};return{tokenize:function(){for(;E.hasNext();)t();return o.length=r+1,o},isTokenNested:function(t){var n=s+m+t.getValue();return-1<e.indexOf(n)}}}var E=function(t){var n=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},i=n,o=null,e=A(),u=A(),a=A(),s=A(),f={},c=function(){a.flushLast()&&s.flushLast()},l=function(t){var n;(n=u.getLast(),n?n.content:e.toArray()).push(t)},r=function(t){c();var n,e=h.create(t.getValue()),r=(void 0===f[(n=t).getValue()]&&(f[n.getValue()]=o.isTokenNested(n)),f[n.getValue()]);a.push(e),r?u.push(e):l(e)},g=function(t){t.isStart()&&r(t),t.isEnd()&&function(t){c();var n=u.flushLast();if(n)l(n);else if(i.onError){var e=t.getValue(),r=t.getLine(),o=t.getColumn();i.onError({message:"Inconsistent tag '"+e+"' on line "+r+" and column "+o,tagName:e,lineNumber:r,columnNumber:o})}}(t)},p=function(t){var n=a.getLast(),e=t.getValue(),r=!!f[t];if(n)if(t.isAttrName())s.push(e),n.attr(s.getLast(),"");else if(t.isAttrValue()){var o=s.getLast();o?(n.attr(o,e),s.flushLast()):n.attr(e,e)}else t.isText()?r?n.append(e):l(e):t.isTag()&&l(""+t);else t.isText()?l(e):t.isTag()&&l(""+t)};(o=(n.createTokenizer?n.createTokenizer:N)(t,{onToken:function(t){var n;!t.isTag()||(n=t.getName(),i.onlyAllowTags&&i.onlyAllowTags.length&&i.onlyAllowTags.indexOf(n)<0)?p(t):g(t)},onlyAllowTags:i.onlyAllowTags,openTag:i.openTag,closeTag:i.closeTag,enableEscapeTags:i.enableEscapeTags})).tokenize();return e.toArray()};t.default=E,t.parse=E,t.TagNode=i,Object.defineProperty(t,"__esModule",{value:!0})}); |
@@ -48,5 +48,8 @@ /* eslint-disable no-plusplus,no-param-reassign */ | ||
var closeTag = options.closeTag || CLOSE_BRAKET; | ||
var escapeTags = options.enableEscapeTags; | ||
var RESERVED_CHARS = [closeTag, openTag, QUOTEMARK, BACKSLASH, SPACE, TAB, EQ, N, EM]; | ||
var NOT_CHAR_TOKENS = [].concat(options.enableEscapeTags ? [BACKSLASH] : [], [openTag, SPACE, TAB, N]); | ||
var NOT_CHAR_TOKENS = [ | ||
// ...(options.enableEscapeTags ? [BACKSLASH] : []), | ||
openTag, SPACE, TAB, N]; | ||
var WHITESPACES = [SPACE, TAB]; | ||
@@ -67,2 +70,8 @@ var SPECIAL_CHARS = [EQ, SPACE, TAB]; | ||
}; | ||
var isEscapableChar = function isEscapableChar(char) { | ||
return char === openTag || char === closeTag || char === BACKSLASH; | ||
}; | ||
var isEscapeChar = function isEscapeChar(char) { | ||
return char === BACKSLASH; | ||
}; | ||
@@ -164,10 +173,6 @@ /** | ||
emitToken(createToken(TYPE_SPACE, str, row, col)); | ||
} else if (options.enableEscapeTags && currChar === BACKSLASH && (nextChar === openTag || nextChar === closeTag)) { | ||
} else if (escapeTags && isEscapeChar(currChar) && isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); // skip the \ without emitting anything | ||
bufferGrabber.skip(); // skip past the [ or ] as well | ||
bufferGrabber.skip(); // skip past the [, ] or \ as well | ||
emitToken(createToken(TYPE_WORD, nextChar, row, col)); | ||
} else if (options.enableEscapeTags && currChar === BACKSLASH && nextChar === BACKSLASH) { | ||
bufferGrabber.skip(); // skip the first \ without emitting anything | ||
bufferGrabber.skip(); // skip past the second \ and emit it | ||
emitToken(createToken(TYPE_WORD, nextChar, row, col)); | ||
} else if (currChar === openTag) { | ||
@@ -208,5 +213,15 @@ bufferGrabber.skip(); // skip openTag | ||
} else if (isCharToken(currChar)) { | ||
var _str2 = bufferGrabber.grabWhile(isCharToken); | ||
if (escapeTags && isEscapeChar(currChar) && !isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); | ||
emitToken(createToken(TYPE_WORD, currChar, row, col)); | ||
} else { | ||
var _str2 = bufferGrabber.grabWhile(function (char) { | ||
if (escapeTags) { | ||
return isCharToken(char) && !isEscapeChar(char); | ||
} | ||
return isCharToken(char); | ||
}); | ||
emitToken(createToken(TYPE_WORD, _str2, row, col)); | ||
emitToken(createToken(TYPE_WORD, _str2, row, col)); | ||
} | ||
} | ||
@@ -213,0 +228,0 @@ }; |
@@ -54,5 +54,8 @@ 'use strict'; | ||
var closeTag = options.closeTag || _char.CLOSE_BRAKET; | ||
var escapeTags = options.enableEscapeTags; | ||
var RESERVED_CHARS = [closeTag, openTag, _char.QUOTEMARK, _char.BACKSLASH, _char.SPACE, _char.TAB, _char.EQ, _char.N, EM]; | ||
var NOT_CHAR_TOKENS = [].concat(options.enableEscapeTags ? [_char.BACKSLASH] : [], [openTag, _char.SPACE, _char.TAB, _char.N]); | ||
var NOT_CHAR_TOKENS = [ | ||
// ...(options.enableEscapeTags ? [BACKSLASH] : []), | ||
openTag, _char.SPACE, _char.TAB, _char.N]; | ||
var WHITESPACES = [_char.SPACE, _char.TAB]; | ||
@@ -73,2 +76,8 @@ var SPECIAL_CHARS = [_char.EQ, _char.SPACE, _char.TAB]; | ||
}; | ||
var isEscapableChar = function isEscapableChar(char) { | ||
return char === openTag || char === closeTag || char === _char.BACKSLASH; | ||
}; | ||
var isEscapeChar = function isEscapeChar(char) { | ||
return char === _char.BACKSLASH; | ||
}; | ||
@@ -170,10 +179,6 @@ /** | ||
emitToken(createToken(_Token.TYPE_SPACE, str, row, col)); | ||
} else if (options.enableEscapeTags && currChar === _char.BACKSLASH && (nextChar === openTag || nextChar === closeTag)) { | ||
} else if (escapeTags && isEscapeChar(currChar) && isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); // skip the \ without emitting anything | ||
bufferGrabber.skip(); // skip past the [ or ] as well | ||
bufferGrabber.skip(); // skip past the [, ] or \ as well | ||
emitToken(createToken(_Token.TYPE_WORD, nextChar, row, col)); | ||
} else if (options.enableEscapeTags && currChar === _char.BACKSLASH && nextChar === _char.BACKSLASH) { | ||
bufferGrabber.skip(); // skip the first \ without emitting anything | ||
bufferGrabber.skip(); // skip past the second \ and emit it | ||
emitToken(createToken(_Token.TYPE_WORD, nextChar, row, col)); | ||
} else if (currChar === openTag) { | ||
@@ -214,5 +219,15 @@ bufferGrabber.skip(); // skip openTag | ||
} else if (isCharToken(currChar)) { | ||
var _str2 = bufferGrabber.grabWhile(isCharToken); | ||
if (escapeTags && isEscapeChar(currChar) && !isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); | ||
emitToken(createToken(_Token.TYPE_WORD, currChar, row, col)); | ||
} else { | ||
var _str2 = bufferGrabber.grabWhile(function (char) { | ||
if (escapeTags) { | ||
return isCharToken(char) && !isEscapeChar(char); | ||
} | ||
return isCharToken(char); | ||
}); | ||
emitToken(createToken(_Token.TYPE_WORD, _str2, row, col)); | ||
emitToken(createToken(_Token.TYPE_WORD, _str2, row, col)); | ||
} | ||
} | ||
@@ -219,0 +234,0 @@ }; |
{ | ||
"name": "@bbob/parser", | ||
"version": "2.5.1", | ||
"version": "2.5.2", | ||
"description": "Just parses BBcode to AST array. Part of @bbob bbcode parser", | ||
@@ -16,3 +16,3 @@ "keywords": [ | ||
"dependencies": { | ||
"@bbob/plugin-helper": "^2.4.0" | ||
"@bbob/plugin-helper": "^2.5.2" | ||
}, | ||
@@ -19,0 +19,0 @@ "main": "lib/index.js", |
@@ -52,6 +52,7 @@ /* eslint-disable no-plusplus,no-param-reassign */ | ||
const closeTag = options.closeTag || CLOSE_BRAKET; | ||
const escapeTags = options.enableEscapeTags; | ||
const RESERVED_CHARS = [closeTag, openTag, QUOTEMARK, BACKSLASH, SPACE, TAB, EQ, N, EM]; | ||
const NOT_CHAR_TOKENS = [ | ||
...(options.enableEscapeTags ? [BACKSLASH] : []), | ||
// ...(options.enableEscapeTags ? [BACKSLASH] : []), | ||
openTag, SPACE, TAB, N, | ||
@@ -66,2 +67,4 @@ ]; | ||
const isSpecialChar = char => (SPECIAL_CHARS.indexOf(char) >= 0); | ||
const isEscapableChar = char => (char === openTag || char === closeTag || char === BACKSLASH); | ||
const isEscapeChar = char => char === BACKSLASH; | ||
@@ -163,11 +166,6 @@ /** | ||
emitToken(createToken(TYPE_SPACE, str, row, col)); | ||
} else if (options.enableEscapeTags && currChar === BACKSLASH | ||
&& (nextChar === openTag || nextChar === closeTag)) { | ||
} else if (escapeTags && isEscapeChar(currChar) && isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); // skip the \ without emitting anything | ||
bufferGrabber.skip(); // skip past the [ or ] as well | ||
bufferGrabber.skip(); // skip past the [, ] or \ as well | ||
emitToken(createToken(TYPE_WORD, nextChar, row, col)); | ||
} else if (options.enableEscapeTags && currChar === BACKSLASH && nextChar === BACKSLASH) { | ||
bufferGrabber.skip(); // skip the first \ without emitting anything | ||
bufferGrabber.skip(); // skip past the second \ and emit it | ||
emitToken(createToken(TYPE_WORD, nextChar, row, col)); | ||
} else if (currChar === openTag) { | ||
@@ -206,5 +204,15 @@ bufferGrabber.skip(); // skip openTag | ||
} else if (isCharToken(currChar)) { | ||
const str = bufferGrabber.grabWhile(isCharToken); | ||
if (escapeTags && isEscapeChar(currChar) && !isEscapableChar(nextChar)) { | ||
bufferGrabber.skip(); | ||
emitToken(createToken(TYPE_WORD, currChar, row, col)); | ||
} else { | ||
const str = bufferGrabber.grabWhile((char) => { | ||
if (escapeTags) { | ||
return isCharToken(char) && !isEscapeChar(char); | ||
} | ||
return isCharToken(char); | ||
}); | ||
emitToken(createToken(TYPE_WORD, str, row, col)); | ||
emitToken(createToken(TYPE_WORD, str, row, col)); | ||
} | ||
} | ||
@@ -211,0 +219,0 @@ }; |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
147977
2914
Updated@bbob/plugin-helper@^2.5.2