e44a7e37b6
git-svn-id: https://semanticscuttle.svn.sourceforge.net/svnroot/semanticscuttle/trunk@151 b3834d28-1941-0410-a4f8-b48e95affb8f
42 lines
1.3 KiB
JavaScript
42 lines
1.3 KiB
JavaScript
if(!dojo._hasResource["dojox.string.tokenize"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
|
|
dojo._hasResource["dojox.string.tokenize"] = true;
|
|
dojo.provide("dojox.string.tokenize");
|
|
|
|
dojox.string.tokenize = function(/*String*/ str, /*RegExp*/ re, /*Function?*/ parseDelim, /*Object?*/ instance){
|
|
// summary:
|
|
// Split a string by a regular expression with the ability to capture the delimeters
|
|
// parseDelim:
|
|
// Each group (excluding the 0 group) is passed as a parameter. If the function returns
|
|
// a value, it's added to the list of tokens.
|
|
// instance:
|
|
// Used as the "this" instance when calling parseDelim
|
|
var tokens = [];
|
|
var match, content, lastIndex = 0;
|
|
while(match = re.exec(str)){
|
|
content = str.slice(lastIndex, re.lastIndex - match[0].length);
|
|
if(content.length){
|
|
tokens.push(content);
|
|
}
|
|
if(parseDelim){
|
|
if(dojo.isOpera){
|
|
var copy = match.slice(0);
|
|
while(copy.length < match.length){
|
|
copy.push(null);
|
|
}
|
|
match = copy;
|
|
}
|
|
var parsed = parseDelim.apply(instance, match.slice(1).concat(tokens.length));
|
|
if(typeof parsed != "undefined"){
|
|
tokens.push(parsed);
|
|
}
|
|
}
|
|
lastIndex = re.lastIndex;
|
|
}
|
|
content = str.slice(lastIndex);
|
|
if(content.length){
|
|
tokens.push(content);
|
|
}
|
|
return tokens;
|
|
}
|
|
|
|
}
|