rather use ''.slice than ''.substr

This commit is contained in:
rolux 2012-05-24 11:47:33 +02:00
parent f990f3b857
commit 1608664bb6
20 changed files with 69 additions and 71 deletions

View file

@ -355,7 +355,7 @@ Ox.load.Image = function(options, callback) {
while (str.length < cap) { while (str.length < cap) {
str += str.substr(4, len); str += str.substr(4, len);
} }
str = str.substr(0, Math.ceil(cap)); str = str.slice(0, Math.ceil(cap));
// Create an array of bit values // Create an array of bit values
bin = Ox.flatten(Ox.map(str.split(''), function(chr) { bin = Ox.flatten(Ox.map(str.split(''), function(chr) {
return Ox.range(8).map(function(i) { return Ox.range(8).map(function(i) {

View file

@ -30,7 +30,7 @@ Ox.SourceViewer = function(options, self) {
return match ? match[0].length : 0; return match ? match[0].length : 0;
})); }));
return '<pre>' + lines.map(function(line) { return '<pre>' + lines.map(function(line) {
return line.substr(indent); return line.slice(indent);
}).join('\n') + '</pre>'; }).join('\n') + '</pre>';
} }
] ]

View file

@ -336,10 +336,10 @@ Ox.URL = function(options) {
} }
if (['=', '!='].indexOf(condition.operator) > -1) { if (['=', '!='].indexOf(condition.operator) > -1) {
if (condition.value[0] == '*') { if (condition.value[0] == '*') {
condition.value = condition.value.substr(1); condition.value = condition.value.slice(1);
condition.operator = condition.operator.replace('=', '$') condition.operator = condition.operator.replace('=', '$')
} else if (condition.value[condition.value.length - 1] == '*') { } else if (condition.value[condition.value.length - 1] == '*') {
condition.value = condition.value.substr(0, condition.value.length - 1); condition.value = condition.value.slice(0, -1);
condition.operator = condition.operator.replace('=', '^') condition.operator = condition.operator.replace('=', '^')
} }
} }
@ -417,7 +417,7 @@ Ox.URL = function(options) {
return str.split(',').map(function(str) { return str.split(',').map(function(str) {
var hasOperator = /^[\+-]/.test(str); var hasOperator = /^[\+-]/.test(str);
return { return {
key: hasOperator ? str.substr(1) : str, key: hasOperator ? str.slice(1) : str,
operator: hasOperator operator: hasOperator
? str[0] ? str[0]
: Ox.getObjectById(self.options.sortKeys[state.type][ : Ox.getObjectById(self.options.sortKeys[state.type][

View file

@ -113,7 +113,7 @@ Ox.Button = function(options, self) {
that.attr({ that.attr({
src: Ox.UI.getImageURL( src: Ox.UI.getImageURL(
'symbol' + self.options.title[0].toUpperCase() 'symbol' + self.options.title[0].toUpperCase()
+ self.options.title.substr(1) + self.options.title.slice(1)
) )
}); });
} else { } else {

View file

@ -513,7 +513,7 @@ Ox.Input = function(options, self) {
} else if (/\./.test(value) && self.options.decimals) { } else if (/\./.test(value) && self.options.decimals) {
length = value.split('.')[1].length; length = value.split('.')[1].length;
if (length > self.options.decimals) { if (length > self.options.decimals) {
value = value.substr(0, value.indexOf('.') + 1 + self.options.decimals); value = value.slice(0, value.indexOf('.') + 1 + self.options.decimals);
cursor = [oldCursor[0] + 1, oldCursor[1] + 1]; cursor = [oldCursor[0] + 1, oldCursor[1] + 1];
} else if (length < self.options.decimals) { } else if (length < self.options.decimals) {
value += Ox.repeat('0', self.options.decimals - length); value += Ox.repeat('0', self.options.decimals - length);
@ -527,7 +527,7 @@ Ox.Input = function(options, self) {
} }
} }
while (/^0\d/.test(value)) { while (/^0\d/.test(value)) {
value = value.substr(1, value.length); value = value.slice(1);
} }
if (!regexp.test(value) || value < self.options.min || value > self.options.max) { if (!regexp.test(value) || value < self.options.min || value > self.options.max) {
value = oldValue; value = oldValue;
@ -725,7 +725,7 @@ Ox.Input = function(options, self) {
that.triggerEvent('insert', { that.triggerEvent('insert', {
end: input.selectionEnd, end: input.selectionEnd,
id: that.oxid, id: that.oxid,
selection: input.value.substring(input.selectionStart, input.selectionEnd), selection: input.value.slice(input.selectionStart, input.selectionEnd),
start: input.selectionStart, start: input.selectionStart,
value: input.value value: input.value
}); });
@ -734,7 +734,7 @@ Ox.Input = function(options, self) {
function keydown(event) { function keydown(event) {
var oldCursor = cursor(), var oldCursor = cursor(),
oldValue = self.options.value, oldValue = self.options.value,
newValue = oldValue.substr(0, oldCursor[0] - 1), newValue = oldValue.slice(0, oldCursor[0] - 1),
hasDeletedSelectedEnd = (event.keyCode == 8 || event.keyCode == 46) && hasDeletedSelectedEnd = (event.keyCode == 8 || event.keyCode == 46) &&
oldCursor[0] < oldCursor[1] && oldCursor[1] == oldValue.length; oldCursor[0] < oldCursor[1] && oldCursor[1] == oldValue.length;
if ( if (

View file

@ -190,9 +190,9 @@ Ox.InsertHTMLDialog = function(options, self) {
); );
self.options.callback({ self.options.callback({
position: self.options.start + value.length, position: self.options.start + value.length,
value: self.options.value.substr(0, self.options.start) value: self.options.value.slice(0, self.options.start)
+ value + value
+ self.options.value.substr(self.options.end) + self.options.value.slice(self.options.end)
}); });
that.close(); that.close();
} }

View file

@ -119,7 +119,7 @@ Ox.TimeInput = function(options, self) {
function getDate() { function getDate() {
return new Date('1970/01/01 ' + ( return new Date('1970/01/01 ' + (
self.options.milliseconds self.options.milliseconds
? self.options.value.substr(0, self.options.value.length - 4) ? self.options.value.slice(0, -4)
: self.options.value : self.options.value
)); ));
} }
@ -129,7 +129,7 @@ Ox.TimeInput = function(options, self) {
return { return {
ampm: Ox.formatDate(date, '%p'), ampm: Ox.formatDate(date, '%p'),
hours: Ox.formatDate(date, self.options.ampm ? '%I' : '%H'), hours: Ox.formatDate(date, self.options.ampm ? '%I' : '%H'),
milliseconds: self.options.milliseconds ? self.options.value.substr(-3) : '000', milliseconds: self.options.milliseconds ? self.options.value.slice(-3) : '000',
minutes: Ox.formatDate(date, '%M'), minutes: Ox.formatDate(date, '%M'),
seconds: Ox.formatDate(date, '%S') seconds: Ox.formatDate(date, '%S')
}; };

View file

@ -774,7 +774,7 @@ Ox.ListMap = function(options, self) {
country = Ox.getCountryByGeoname(place.geoname); country = Ox.getCountryByGeoname(place.geoname);
place.countryCode = country ? country.code : ''; place.countryCode = country ? country.code : '';
if (!self.isAsync) { if (!self.isAsync) {
place.id = self.selectedPlace.substr(1); // fixme: safe? place.id = self.selectedPlace.slice(1); // fixme: safe?
self.selectedPlace = place.id; self.selectedPlace = place.id;
self.options.places.push(place); self.options.places.push(place);
self.$list.options({ self.$list.options({

View file

@ -302,8 +302,9 @@ Ox.AnnotationPanel = function(options, self) {
insert({ insert({
end: element.selectionEnd, end: element.selectionEnd,
id: id, id: id,
selection: element.value selection: element.value.slice(
.substr(element.selectionStart, element.selectionEnd), element.selectionStart, element.selectionEnd
),
start: element.selectionStart, start: element.selectionStart,
value: element.value value: element.value
}); });

View file

@ -89,7 +89,7 @@ Ox.VideoElement = function(options, self) {
item.$videos = src.map(function(src, i) { item.$videos = src.map(function(src, i) {
// in all browsers except firefox, // in all browsers except firefox,
// loadedmetadata fires only once per src // loadedmetadata fires only once per src
if(Ox.parseURL(src).protocol.substr(0, 4) == 'http') { if (Ox.startsWith(Ox.parseURL(src).protocol, 'http')) {
src += '?' + Ox.uid(); src += '?' + Ox.uid();
} }
return $('<video>') return $('<video>')
@ -434,7 +434,7 @@ Ox.VideoElement = function(options, self) {
self.$video.each(function(video, i) { self.$video.each(function(video, i) {
if (i != self.currentPart) { if (i != self.currentPart) {
var src = self.options.src[i]; var src = self.options.src[i];
if(Ox.parseURL(src).protocol.substr(0, 4) == 'http') { if (Ox.startsWith(Ox.parseURL(src).protocol, 'http')) {
src += '?' + Ox.uid(); src += '?' + Ox.uid();
} }
video.src = src; video.src = src;
@ -443,7 +443,7 @@ Ox.VideoElement = function(options, self) {
} else { } else {
self.items[0].$videos.forEach(function($video, i) { self.items[0].$videos.forEach(function($video, i) {
var src = self.options.src[i]; var src = self.options.src[i];
if (Ox.parseURL(src).protocol.substr(0, 4) == 'http') { if (Ox.startsWith(Ox.parseURL(src).protocol, 'http')) {
src += '?' + Ox.uid(); src += '?' + Ox.uid();
} }
$video[0].src = src; $video[0].src = src;

View file

@ -309,7 +309,7 @@ Ox.Dialog = function(options, self) {
} }
function resizestart(event) { function resizestart(event) {
var edge = event.target.className.substr(17).toLowerCase(), var edge = event.target.className.slice(17).toLowerCase(),
offset = that.offset(); offset = that.offset();
self.drag = { self.drag = {
edge: edge, edge: edge,

View file

@ -462,8 +462,8 @@ Ox.range = function() {
var len; var len;
if (new RegExp('^' + article + ' ').test(sort[val])) { if (new RegExp('^' + article + ' ').test(sort[val])) {
len = article.length; len = article.length;
sort[val] = sort[val].substr(len + 1) + ', ' sort[val] = sort[val].slice(len + 1) + ', '
+ sort[val].substr(0, len); + sort[val].slice(0, len);
Ox.break(); Ox.break();
} }
}); });

View file

@ -119,4 +119,3 @@ Ox.toRGB = function(hex) {
return parseInt(hex.substr(i * 2, 2), 16); return parseInt(hex.substr(i * 2, 2), 16);
}); });
}; };

View file

@ -74,7 +74,7 @@ Ox.MONTHS = [
]; ];
//@ Ox.SHORT_MONTHS <[str]> Short names of months //@ Ox.SHORT_MONTHS <[str]> Short names of months
Ox.SHORT_MONTHS = Ox.MONTHS.map(function(val) { Ox.SHORT_MONTHS = Ox.MONTHS.map(function(val) {
return val.substr(0, 3); return val.slice(0, 3);
}); });
//@ Ox.PATH <str> Path of Ox.js //@ Ox.PATH <str> Path of Ox.js
Ox.PATH = Ox.toArray( Ox.PATH = Ox.toArray(
@ -127,5 +127,5 @@ Ox.WEEKDAYS = [
]; ];
//@ Ox.SHORT_WEEKDAYS <[str]> Short names of weekdays //@ Ox.SHORT_WEEKDAYS <[str]> Short names of weekdays
Ox.SHORT_WEEKDAYS = Ox.WEEKDAYS.map(function(val) { Ox.SHORT_WEEKDAYS = Ox.WEEKDAYS.map(function(val) {
return val.substr(0, 3); return val.slice(0, 3);
}); });

View file

@ -141,7 +141,7 @@ Ox.localStorage = function(namespace) {
ret = {}; ret = {};
Ox.forEach(localStorage, function(val, key) { Ox.forEach(localStorage, function(val, key) {
if (Ox.startsWith(key, namespace + '.')) { if (Ox.startsWith(key, namespace + '.')) {
ret[key.substr(namespace.length + 1)] = JSON.parse(val); ret[key.slice(namespace.length + 1)] = JSON.parse(val);
} }
}); });
} else if (arguments.length == 1 && typeof key == 'string') { } else if (arguments.length == 1 && typeof key == 'string') {
@ -214,7 +214,7 @@ Ox.Log = (function() {
if (!log.filterEnabled || log.filter.indexOf(args[0]) > -1) { if (!log.filterEnabled || log.filter.indexOf(args[0]) > -1) {
date = new Date(); date = new Date();
args.unshift( args.unshift(
Ox.formatDate(date, '%H:%M:%S.') + (+date).toString().substr(-3) Ox.formatDate(date, '%H:%M:%S.') + (+date).toString().slice(-3)
); );
window.console && window.console.log.apply(window.console, args); window.console && window.console.log.apply(window.console, args);
ret = args.join(' '); ret = args.join(' ');
@ -326,7 +326,7 @@ Ox.print = function() {
var args = Ox.toArray(arguments), var args = Ox.toArray(arguments),
date = new Date(); date = new Date();
args.unshift( args.unshift(
Ox.formatDate(date, '%H:%M:%S.') + (+date).toString().substr(-3)/*, Ox.formatDate(date, '%H:%M:%S.') + (+date).toString().slice(-3)/*,
(arguments.callee.caller && arguments.callee.caller.name) (arguments.callee.caller && arguments.callee.caller.name)
|| '(anonymous)'*/ || '(anonymous)'*/
); );

View file

@ -26,7 +26,7 @@ Ox.getDateInWeek = function(date, weekday, utc) {
var sourceWeekday = Ox.getISODay(date, utc), var sourceWeekday = Ox.getISODay(date, utc),
targetWeekday = Ox.isNumber(weekday) ? weekday targetWeekday = Ox.isNumber(weekday) ? weekday
: Ox.indexOf(Ox.WEEKDAYS, function(v) { : Ox.indexOf(Ox.WEEKDAYS, function(v) {
return v.substr(0, 3) == weekday.substr(0, 3); return v.slice(0, 3) == weekday.slice(0, 3);
}) + 1; }) + 1;
return Ox.setDate(date, Ox.getDate(date, utc) - sourceWeekday + targetWeekday, utc); return Ox.setDate(date, Ox.getDate(date, utc) - sourceWeekday + targetWeekday, utc);
} }
@ -72,7 +72,7 @@ Ox.getDaysInMonth = function(year, month) {
year = Ox.makeYear(year); year = Ox.makeYear(year);
month = Ox.isNumber(month) ? month month = Ox.isNumber(month) ? month
: Ox.indexOf(Ox.MONTHS, function(v) { : Ox.indexOf(Ox.MONTHS, function(v) {
return v.substr(0, 3) == month.substr(0, 3); return v.slice(0, 3) == month.slice(0, 3);
}) + 1; }) + 1;
return new Date(year, month, 0).getDate(); return new Date(year, month, 0).getDate();
} }

View file

@ -204,14 +204,14 @@
// bytes IHDR name), keep bytes 16 to 19 (width), discard bytes 20 to 29 // bytes IHDR name), keep bytes 16 to 19 (width), discard bytes 20 to 29
// (4 bytes height, 5 bytes flags), keep bytes 29 to 32 (IHDR checksum), // (4 bytes height, 5 bytes flags), keep bytes 29 to 32 (IHDR checksum),
// keep the rest (IDAT chunks), discard the last 12 bytes (IEND chunk). // keep the rest (IDAT chunks), discard the last 12 bytes (IEND chunk).
data = str.substr(16, 4) + str.substr(29, 4); data = str.slice(16, 20) + str.slice(29, 33);
idat = str.substr(33, str.length - 45); idat = str.slice(33, -45);
while (idat) { while (idat) {
// Each IDAT chunk is 4 bytes length, 4 bytes name, length bytes // Each IDAT chunk is 4 bytes length, 4 bytes name, length bytes
// data and 4 bytes checksum. We can discard the name parts. // data and 4 bytes checksum. We can discard the name parts.
len = idat.substr(0, 4); len = idat.slice(0, 4);
data += len + idat.substr(8, 4 + (len = Ox.decodeBase256(len))); data += len + idat.slice(8, 12 + (len = Ox.decodeBase256(len)));
idat = idat.substr(12 + len); idat = idat.slice(12 + len);
} }
callback && callback(data); callback && callback(data);
return data; return data;
@ -234,18 +234,18 @@
var image = new Image(), var image = new Image(),
// PNG file signature and IHDR chunk // PNG file signature and IHDR chunk
data = '\u0089PNG\r\n\u001A\n\u0000\u0000\u0000\u000DIHDR' data = '\u0089PNG\r\n\u001A\n\u0000\u0000\u0000\u000DIHDR'
+ str.substr(0, 4) + '\u0000\u0000\u0000\u0001' + str.slice(0, 4) + '\u0000\u0000\u0000\u0001'
+ '\u0008\u0006\u0000\u0000\u0000' + str.substr(4, 4), + '\u0008\u0006\u0000\u0000\u0000' + str.slice(4, 8),
// IDAT chunks // IDAT chunks
idat = str.substr(8), len; idat = str.slice(8), len;
function error() { function error() {
throw new RangeError('Deflate codec can\'t decode data.'); throw new RangeError('Deflate codec can\'t decode data.');
} }
while (idat) { while (idat) {
// Reinsert the IDAT chunk names // Reinsert the IDAT chunk names
len = idat.substr(0, 4); len = idat.slice(0, 4);
data += len + 'IDAT' + idat.substr(4, 4 + (len = Ox.decodeBase256(len))); data += len + 'IDAT' + idat.slice(4, 8 + (len = Ox.decodeBase256(len)));
idat = idat.substr(8 + len); idat = idat.slice(8 + len);
} }
// IEND chunk // IEND chunk
data += '\u0000\u0000\u0000\u0000IEND\u00AE\u0042\u0060\u0082'; data += '\u0000\u0000\u0000\u0000IEND\u00AE\u0042\u0060\u0082';
@ -259,7 +259,7 @@
try { try {
// Parse the first byte as number of bytes to chop at the end, // Parse the first byte as number of bytes to chop at the end,
// and the rest, without these bytes, as an UTF8-encoded string. // and the rest, without these bytes, as an UTF8-encoded string.
str = Ox.decodeUTF8(str.substr(1, str.length - 1 - str.charCodeAt(0))) str = Ox.decodeUTF8(str.slice(1, -str.CharCodeAt(0)));
} catch (e) { } catch (e) {
error(); error();
} }

View file

@ -153,7 +153,7 @@ Ox.formatDate = function(date, str, utc) {
['d', function(d) {return Ox.pad(Ox.getDate(d, utc), 2);}], ['d', function(d) {return Ox.pad(Ox.getDate(d, utc), 2);}],
['e', function(d) {return Ox.pad(Ox.getDate(d, utc), 2, ' ');}], ['e', function(d) {return Ox.pad(Ox.getDate(d, utc), 2, ' ');}],
['G', function(d) {return Ox.getISOYear(d, utc);}], ['G', function(d) {return Ox.getISOYear(d, utc);}],
['g', function(d) {return Ox.getISOYear(d, utc).toString().substr(-2);}], ['g', function(d) {return Ox.getISOYear(d, utc).toString().slice(-2);}],
['H', function(d) {return Ox.pad(Ox.getHours(d, utc), 2);}], ['H', function(d) {return Ox.pad(Ox.getHours(d, utc), 2);}],
['I', function(d) {return Ox.pad((Ox.getHours(d, utc) + 11) % 12 + 1, 2);}], ['I', function(d) {return Ox.pad((Ox.getHours(d, utc) + 11) % 12 + 1, 2);}],
['j', function(d) {return Ox.pad(Ox.getDayOfTheYear(d, utc), 3);}], ['j', function(d) {return Ox.pad(Ox.getDayOfTheYear(d, utc), 3);}],
@ -185,7 +185,7 @@ Ox.formatDate = function(date, str, utc) {
return Math.abs(y) + (y < 1000 ? ' ' + Ox.BCAD[y < 0 ? 0 : 1] : ''); return Math.abs(y) + (y < 1000 ? ' ' + Ox.BCAD[y < 0 ? 0 : 1] : '');
}], }],
['Y', function(d) {return Ox.getFullYear(d, utc);}], ['Y', function(d) {return Ox.getFullYear(d, utc);}],
['y', function(d) {return Ox.getFullYear(d, utc).toString().substr(-2);}], ['y', function(d) {return Ox.getFullYear(d, utc).toString().slice(-2);}],
['Z', function(d) {return d.toString().split('(')[1].replace(')', '');}], ['Z', function(d) {return d.toString().split('(')[1].replace(')', '');}],
['z', function(d) {return Ox.getTimezoneOffsetString(d);}], ['z', function(d) {return Ox.getTimezoneOffsetString(d);}],
['n', function() {return '\n';}], ['n', function() {return '\n';}],
@ -496,8 +496,8 @@ Ox.formatNumber = function(num, dec) {
str = Ox.isUndefined(dec) ? abs.toString() : abs.toFixed(dec), str = Ox.isUndefined(dec) ? abs.toString() : abs.toFixed(dec),
spl = str.split('.'); spl = str.split('.');
while (spl[0]) { while (spl[0]) {
arr.unshift(spl[0].substr(-3)); arr.unshift(spl[0].slice(-3));
spl[0] = spl[0].substr(0, spl[0].length - 3); spl[0] = spl[0].slice(0, -3);
} }
spl[0] = arr.join(','); spl[0] = arr.join(',');
return (num < 0 ? '-' : '') + spl.join('.'); return (num < 0 ? '-' : '') + spl.join('.');

View file

@ -76,7 +76,7 @@ Ox.doc = (function() {
// or if the second last char is a single or double quote // or if the second last char is a single or double quote
return matches && ( return matches && (
matches[2].indexOf('/') == -1 || matches[2].indexOf('/') == -1 ||
'\'"'.indexOf(matches[2].substr(-2, 1)) > -1 '\'"'.indexOf(matches[2].slice(-2, -1)) > -1
) ? Ox.extend({ ) ? Ox.extend({
name: parseName(matches[1].trim()), name: parseName(matches[1].trim()),
summary: matches[3].trim() summary: matches[3].trim()
@ -163,7 +163,7 @@ Ox.doc = (function() {
// main item // main item
// include leading whitespace // include leading whitespace
item.source = parseTokens(tokens[i]); item.source = parseTokens(tokens[i]);
item.line = source.substr(0, item.source[0].offset) item.line = source.slice(0, item.source[0].offset)
.split('\n').length; .split('\n').length;
items.push(item); items.push(item);
} else { } else {
@ -186,7 +186,7 @@ Ox.doc = (function() {
// fixme: we cannot properly handle tests where a string contains '\n ' // fixme: we cannot properly handle tests where a string contains '\n '
var lines = decodeLinebreaks(str).split('\n '); var lines = decodeLinebreaks(str).split('\n ');
return { return {
statement: lines[0].substr(2), statement: lines[0].slice(2),
result: lines[1].trim() result: lines[1].trim()
}; };
} }
@ -258,7 +258,7 @@ Ox.doc = (function() {
split, split,
type; type;
// only split by ':' if there is no default string value // only split by ':' if there is no default string value
if ('\'"'.indexOf(str.substr(-2, 1)) == -1) { if ('\'"'.indexOf(str.slice(-2, -1)) == -1) {
split = str.split(':'); split = str.split(':');
str = split[0]; str = split[0];
if (split.length == 2) { if (split.length == 2) {
@ -637,7 +637,7 @@ Ox.tokenize = (function() {
identifier: function() { identifier: function() {
var str; var str;
while ((identifier + number).indexOf(source[++cursor]) > -1) {} while ((identifier + number).indexOf(source[++cursor]) > -1) {}
str = source.substring(start, cursor); str = source.slice(start, cursor);
Ox.forEach(word, function(value, key) { Ox.forEach(word, function(value, key) {
if (value.indexOf(str) > -1) { if (value.indexOf(str) > -1) {
type = key; type = key;

View file

@ -48,7 +48,7 @@ Ox.ends = Ox.endsWith = function(str, sub) {
// fixme: rename to ends // fixme: rename to ends
str = str.toString(); str = str.toString();
sub = sub.toString(); sub = sub.toString();
return str.substr(str.length - sub.length) == sub; return str.slice(str.length - sub.length) == sub;
}; };
/*@ /*@
@ -107,7 +107,7 @@ Ox.highlightHTML = function(html, str, classname, tags) {
isEntity = true; isEntity = true;
} else if (!isTag && chr == '<') { } else if (!isTag && chr == '<') {
Ox.forEach(tags, function(tag) { Ox.forEach(tags, function(tag) {
if (html.substr(i + 1).match(new RegExp('^/?' + tag + '\\W'))) { if (html.slice(i + 1).match(new RegExp('^/?' + tag + '\\W'))) {
isTag = true; isTag = true;
Ox.break(); Ox.break();
} }
@ -138,10 +138,10 @@ Ox.highlightHTML = function(html, str, classname, tags) {
}); });
positions.forEach(function(position) { positions.forEach(function(position) {
var match = '<span class="' + classname + '">' var match = '<span class="' + classname + '">'
+ html.substr(position[0], position[1] - position[0]) + html.slice(position[0], position[1])
.replace(/(<.*?>)/g, '</span>$1<span class="' + classname + '">') .replace(/(<.*?>)/g, '</span>$1<span class="' + classname + '">')
+ '</span>'; + '</span>';
html = html.substr(0, position[0]) + match + html.substr(position[1]); html = html.slice(0, position[0]) + match + html.slice(position[1]);
}); });
return html; return html;
} }
@ -180,13 +180,11 @@ Ox.pad = function(str, len, pad) {
// fixme: slighly obscure signature // fixme: slighly obscure signature
// fixme: weird for negative numbers // fixme: weird for negative numbers
var pos = len / (len = Math.abs(len)); var pos = len / (len = Math.abs(len));
str = str.toString().substr(0, len); str = str.toString().slice(0, len);
pad = Ox.repeat(pad || '0', len - str.length); pad = Ox.repeat(pad || '0', len - str.length);
str = pos == 1 ? pad + str : str + pad; return pos == 1
str = pos == 1 ? ? (pad + str).slice(-len)
str.substr(str.length - len, str.length) : : (str + pad).slice(0, len);
str.substr(0, len);
return str;
}; };
/*@ /*@
@ -209,7 +207,7 @@ Ox.parsePath = function(str) {
return { return {
pathname: matches[1] || '', pathname: matches[1] || '',
filename: matches[2] || '', filename: matches[2] || '',
extension: matches[3] ? matches[3].substr(1) : '' extension: matches[3] ? matches[3].slice(1) : ''
}; };
} }
@ -422,7 +420,7 @@ Ox.starts = Ox.startsWith = function(str, sub) {
// fixme: rename to starts // fixme: rename to starts
str = str.toString(); str = str.toString();
sub = sub.toString(); sub = sub.toString();
return str.substr(0, sub.length) == sub; return str.slice(0, sub.length) == sub;
}; };
/*@ /*@
@ -482,10 +480,10 @@ Ox.toTitleCase <f> Returns a string with capitalized words
@*/ @*/
Ox.toTitleCase = function(str) { Ox.toTitleCase = function(str) {
return str.split(' ').map(function(val) { return str.split(' ').map(function(val) {
var sub = val.substr(1), var sub = val.slice(1),
low = sub.toLowerCase(); low = sub.toLowerCase();
if (sub == low) { if (sub == low) {
val = val.substr(0, 1).toUpperCase() + low; val = val.slice(0, 1).toUpperCase() + low;
} }
return val; return val;
}).join(' '); }).join(' ');
@ -533,13 +531,13 @@ Ox.truncate = function(str, len, pad, pos) {
left, right; left, right;
if (strlen > len) { if (strlen > len) {
if (pos == 'left') { if (pos == 'left') {
str = pad + str.substr(padlen + strlen - len); str = pad + str.slice(padlen + strlen - len);
} else if (pos == 'center') { } else if (pos == 'center') {
left = Math.ceil((len - padlen) / 2); left = Math.ceil((len - padlen) / 2);
right = Math.floor((len - padlen) / 2); right = Math.floor((len - padlen) / 2);
str = str.substr(0, left) + pad + str.substr(-right); str = str.slice(0, left) + pad + str.slice(-right);
} else if (pos == 'right') { } else if (pos == 'right') {
str = str.substr(0, len - padlen) + pad; str = str.slice(0, len - padlen) + pad;
} }
} }
return str; return str;
@ -628,7 +626,7 @@ Ox.wordwrap = function(str, len, sep, bal, spa) {
} else { } else {
// word is longer than line // word is longer than line
chr = len - lines[lines.length - 1].length; chr = len - lines[lines.length - 1].length;
lines[lines.length - 1] += word.substr(0, chr); lines[lines.length - 1] += word.slice(0, chr);
Ox.loop(chr, word.length, len, function(pos) { Ox.loop(chr, word.length, len, function(pos) {
lines.push(word.substr(pos, len)); lines.push(word.substr(pos, len));
}); });