// fixme - this needs a bitter location..
// they where in a string class before, but overriding String methods is not a good normally a good idea..
- rtrim : function (toTrim) {
- if (this.substr(this.length - toTrim.length) == toTrim) {
- return this.slice(0, this.length - toTrim.length);
+ rtrim : function (s,toTrim) {
+ if (s.substr(s.length - toTrim.length) == toTrim) {
+ return s.slice(0, s.length - toTrim.length);
}
- return this;
+ return s;
+ },
+ trim : function (s,toTrim) {
+ var out = s.ltrim(toTrim);
+ out = out.rtrim(toTrim);
+ return out;
},
- join : function () {
-
-
-
+ ltrim : function (s, toTrim) {
+ if (s.substr(0, toTrim.length) == toTrim) {
+ return s.slice(toTrim.length);
+ }
+ return s;
+ },
+
+ join : function () {
var out = "";
for (var i = 0; i < arguments.length; i++) {
if (i == 0) {
- out += arguments[i].rtrim(File.SEPARATOR);
+ out += this.rtrim(arguments[i], File.SEPARATOR);
}
else if (i == arguments.length - 1) {
- out += File.SEPARATOR + arguments[i].ltrim(File.SEPARATOR);
+ out += File.SEPARATOR + this.ltrim(arguments[i], File.SEPARATOR);
}
else {
- out += File.SEPARATOR + arguments[i].trim(File.SEPARATOR);
+ out += File.SEPARATOR + this.trim(arguments[i], File.SEPARATOR);
}
}
return out;
},
-
+
+ dirname : function(s)
+ {
+ var ar = s.split(File.SEPARATOR);
+ ar.pop();
+ return ar.join(File.SEPARATOR);
+ },
+ basename : function(s)
+ {
+ var ar = s.split(File.SEPARATOR);
+ return ar.pop();
+ },
+
read : function (path) {
var out = {};
GLib.file_get_contents(path, out, null, null);