/**
* String variable substitution and string formatting.
* If included, the substitute method is added to the YUI instance.
*
* @module substitute
*/
/**
* The following methods are added to the YUI instance
* @class YUI~substitute
*/
/**
Does {placeholder} substitution on a string. The object passed as the
second parameter provides values to replace the {placeholder}s.
{placeholder} token names must match property names of the object. For
example
`var greeting = Y.substitute("Hello, {who}!", { who: "World" });`
{placeholder} tokens that are undefined on the object map will be left in
tact (leaving unsightly "{placeholder}"s in the output string).
If a function is passed as a third argument, it will be called for each
{placeholder} found. The {placeholder} name is passed as the first value
and the value from the object map is passed as the second. If the
{placeholder} contains a space, the first token will be used to identify
the object map property and the remainder will be passed as a third
argument to the function. See below for an example.
If the value in the object map for a given {placeholder} is an object and
the `dump` module is loaded, the replacement value will be the string
result of calling `Y.dump(...)` with the object as input. Include a
numeric second token in the {placeholder} to configure the depth of the call
to `Y.dump(...)`, e.g. "{someObject 2}". See the
@method substitute
@param {string} s The string that will be modified.
@param {object} o An object containing the replacement values.
@param {function} f 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.
@param {boolean} recurse if true, the replacement will be recursive,
letting you have replacement tokens in replacement text.
The default is false.
@return {string} the substituted string.
@example
function getAttrVal(key, value, name) {
// Return a string describing the named attribute and its value if
// the first token is @. Otherwise, return the value from the
// replacement object.
if (key === "@") {
value += name + " Value: " + myObject.get(name);
}
return value;
}
// Assuming myObject.set('foo', 'flowers'),
// => "Attr: foo Value: flowers"
var attrVal = Y.substitute("{@ foo}", { "@": "Attr: " }, getAttrVal);
**/
substitute = function(s, o, f, recurse) {
for (;;) {
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 (!Y.dump) {
v = v.toString();
} else {
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
dump > -1) {
} else {
v = v.toString();
}
}
}
} else if (L.isUndefined(v)) {
// This {block} has no replace string. Save it for later.
// break;
}
if (!recurse) {
lidx = i - 1;
}
}
// restore saved {block}s and escaped braces
return s
})
;
};
Y.substitute = substitute;
L.substitute = substitute;