substitute.js revision 52fb261595e30e96776f947f2ed7a00993ba45aa
// requires lang, dump
/**
* Does variable substitution on a string. It scans through the string
* looking for expressions enclosed in { } braces. If an expression
* is found, it is used a key on the object. If there is a space in
* the key, the first word is used for the key and the rest is provided
* to an optional function to be used to programatically determine the
* value (the extra information might be used for this decision). If
* the value for the key in the object, or what is returned from the
* function has a string value, number value, or object value, it is
* substituted for the bracket expression and it repeats. If this
* value is an object, it uses the Object's toString() if this has
* pairs.
*
* This method is included in the 'i18n' module. It is not included
* in the YUI module.
*
* @method substitute
* @param s {String} The string that will be modified.
* @param o {Object} An object containing the replacement values
* @param f {Function} An optional function that can be used to
* process each match. It receives the key,
* value, and any extra metadata included with
* the key inside of the braces.
* @return {String} the substituted string
*/
substitute = function (s, o, f) {
for (;;) {
i = s.lastIndexOf(LBRACE);
if (i < 0) {
break;
}
if (i + 1 >= j) {
break;
}
//Extract key and meta info
meta = null;
if (k > -1) {
}
// lookup the value
v = o[key];
// if a substitution function was provided, execute it
if (f) {
}
if (L.isObject(v)) {
if (L.isArray(v)) {
} else {
// look for the keyword 'dump', if found force obj dump
if (dump > -1) {
}
// use the toString if it is not the Object toString
// and the 'dump' meta info was not found
} else {
v = v.toString();
}
}
// This {block} has no replace string. Save it for later.
// break;
}
}
// restore saved {block}s
}
return s;
};
Y.substitute = substitute;
L.substitute = substitute;
}, "3.0.0");