New walk_tags to replace old bbcode_match func
This commit is contained in:
parent
96c0899240
commit
cf6fd2e35e
24
object.js
24
object.js
@ -61,7 +61,31 @@ var referenceObj = function()
|
|||||||
return refd;
|
return refd;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var LStack = function() {
|
||||||
|
this._first = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
LStack.prototype.add = function( obj )
|
||||||
|
{
|
||||||
|
var p = this._first;
|
||||||
|
this._first = { "o": obj, "n": p };
|
||||||
|
};
|
||||||
|
|
||||||
|
LStack.prototype.pop = function()
|
||||||
|
{
|
||||||
|
var g = this._first;
|
||||||
|
this._first = g.n;
|
||||||
|
return g.o;
|
||||||
|
};
|
||||||
|
|
||||||
|
LStack.prototype.curr = function() {
|
||||||
|
return this._first.o;
|
||||||
|
};
|
||||||
|
|
||||||
|
LStack.prototype.empty = function() { return !this._first; }
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
clone: cloneObj
|
clone: cloneObj
|
||||||
, refObj: referenceObj
|
, refObj: referenceObj
|
||||||
|
, LStack: LStack
|
||||||
};
|
};
|
||||||
|
114
string.js
114
string.js
@ -1,3 +1,10 @@
|
|||||||
|
var obju = require( "./object.js" );
|
||||||
|
var _newStackItem = function( t )
|
||||||
|
{
|
||||||
|
var o = { "name": t, "attrs": "", "cont": "" };
|
||||||
|
o[ "fd" ] = ( x ) => o.cont += x;
|
||||||
|
return o;
|
||||||
|
};
|
||||||
module.exports = {
|
module.exports = {
|
||||||
encodeHtml: function ( str, br )
|
encodeHtml: function ( str, br )
|
||||||
{
|
{
|
||||||
@ -19,4 +26,111 @@ module.exports = {
|
|||||||
|
|
||||||
return "http://" + str;
|
return "http://" + str;
|
||||||
}
|
}
|
||||||
|
, walk_tags: function( str, handler, _OP, _ED, _fineHandlers )
|
||||||
|
{
|
||||||
|
_fineHandlers ||= {};
|
||||||
|
|
||||||
|
var l = str && str.length;
|
||||||
|
var strOut = "";
|
||||||
|
|
||||||
|
var tokenStack = new (obju.LStack)();
|
||||||
|
|
||||||
|
var _fd_strOut = ( x ) => strOut += x;
|
||||||
|
var _fd = _fd_strOut;
|
||||||
|
|
||||||
|
var exitCurrentTag = () => {
|
||||||
|
tokenStack.pop();
|
||||||
|
_fd = tokenStack.empty() ? _fd_strOut : tokenStack.curr().fd;
|
||||||
|
};
|
||||||
|
|
||||||
|
var ctx = {
|
||||||
|
"exitCurrentTag": exitCurrentTag
|
||||||
|
, "stack": tokenStack
|
||||||
|
};
|
||||||
|
|
||||||
|
for( let i = 0; i < l; i ++ )
|
||||||
|
{
|
||||||
|
let c = str[i];
|
||||||
|
let t, _a, _n;
|
||||||
|
if( c === _OP )
|
||||||
|
{
|
||||||
|
t = str[ ++i ];
|
||||||
|
let closeTag = ( t === "/" );
|
||||||
|
|
||||||
|
for(
|
||||||
|
_a = str[ ++i ], _n = _a.charCodeAt(0);
|
||||||
|
// check alpha numeric
|
||||||
|
( 65 <= _n && _n <= 90 ) || ( 97 <= _n && _n <= 122 ) || ( 48 <= _n && _n <= 57 );
|
||||||
|
i ++, _a = str[i], _n = _a.charCodeAt(0)
|
||||||
|
) t += _a;
|
||||||
|
|
||||||
|
if( _a === _ED )
|
||||||
|
{
|
||||||
|
// Hits "</abcd>"
|
||||||
|
if( closeTag )
|
||||||
|
{
|
||||||
|
// Hits "<abcd...>...</abcd>"
|
||||||
|
if( t.substr( 1 ) === tokenStack.curr().name )
|
||||||
|
{
|
||||||
|
let st = tokenStack.pop();
|
||||||
|
_fd = tokenStack.empty() ? _fd_strOut : tokenStack.curr().fd;
|
||||||
|
_fd( handler( st.name, st.attrs, st.cont ) );
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// Hits "<abcd>...</efgh>"
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Error( `Syntax error: Unexpected closing ${_OP}${t}> after opened ${_OP}${tokenStack.curr().name}${_ED}` );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Hits "<abcd>"
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tokenStack.add( _newStackItem( t ) );
|
||||||
|
_fd = tokenStack.curr().fd;
|
||||||
|
|
||||||
|
_fineHandlers.TagOpen && _fineHandlers.TagOpen( ctx );
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Hits "<abc#" where _a is "#"
|
||||||
|
// Consume everything until we hit closing ">" or opening "<"
|
||||||
|
tokenStack.add( _newStackItem( t ) );
|
||||||
|
t = _a;
|
||||||
|
for(
|
||||||
|
_a = str[ ++i ];
|
||||||
|
!( _a.startsWith( _OP ) || _a.startsWith( _ED ) );
|
||||||
|
i ++, _a = str[i]
|
||||||
|
) t += _a;
|
||||||
|
|
||||||
|
// Hits "<abcd#...<"
|
||||||
|
if( _a === _OP )
|
||||||
|
{
|
||||||
|
// Write "<abcd#..." into _fd and starts over
|
||||||
|
// < : _OP
|
||||||
|
// abcd : tokenStack.pop().name
|
||||||
|
// #... : t
|
||||||
|
_fd( _OP + tokenStack.pop().name + t ); i --;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// Hits "<abcd#...>"
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Write #... into abcd's attrs
|
||||||
|
tokenStack.curr().attrs = t;
|
||||||
|
_fd = tokenStack.curr().fd;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_fd( c );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return strOut;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user