1 //<Script type="text/javascript">
3 console = imports.console;
4 XObject = imports.XObject.XObject;
6 Lang = imports.Builder.Provider.File.Lang.Lang;
8 File = imports.File.File;
11 Base = XObject.define(
15 XObject.extend(this, cfg);
21 name : false, // is the JS name of the file.
22 path : '', // is the full path to the file.
23 parent : false, // JS parent.
25 title : false, // a title.. ?? nickname.. ??? -
26 project: false, // name...
27 //Project : false, // link to container project!
29 items : false, // the tree of nodes.
31 cn : false, // array used by project tree.
38 var write = this.toJsonArray()
39 print("WRITE: " + this.path);// + "\n" + JSON.stringify(write));
40 File.write(this.path, JSON.stringify(write));
45 * { success : , failure : , scope : }
51 getTree : function( o ) {
52 console.log("File.getTree tree called on base object?!?!");
54 toJsonArray : function()
58 ['id', 'name', 'parent', 'title', 'path', 'items', 'project'].forEach( function(k) {
68 return this.path.split('/').pop();
71 getTitleTip: function()
74 return '<b>' + this.title + '</b> ' + this.path;
80 this.cn.sort(function(a,b) {
81 return a.path > b.path;// ? 1 : -1;
84 // should be in palete provider really..
86 guessName : function(ar) // turns the object into full name.
88 // eg. xns: Roo, xtype: XXX -> Roo.xxx
89 if (typeof( ar['|xns'] ) == 'undefined' || typeof( ar['xtype'] ) == 'undefined') {
93 return ar['|xns'] +'.' + ar['xtype'];
100 toSourceStdClass: function()
102 var cfg = this.items[0]
103 var fcfg = XObject.extend({ }, this.items[0]);
104 delete fcfg['*class'];
105 delete fcfg['*extends'];
106 delete fcfg['*static'];
107 delete fcfg['|constructor'];
109 var hasExtends = (typeof(cfg['*extends']) != 'undefined') && cfg['*extends'].length;
110 var hasConstructor = (typeof(cfg['|constructor']) != 'undefined');
111 var isStatic = (typeof(cfg['*static']) == '*static');
116 newline = hasConstructor ?
119 cfg['//constructor'] + "\n" +
120 cfg['*class'] + " = " + cfg['|constructor'] + "\n\n"+
121 "Roo.extend(" + cfg['*class'] + ":, " + cfg['*extends'] + ", " :
123 cfg['//*class'] + "\n" +
124 cfg['*class'] + " = new " + cfg['*extends'] + "(" ;
131 newline = hasConstructor ?
133 cfg['//constructor'] + "\n" +
134 cfg['*class'] + " = " + cfg['|constructor'] + "\n\n"+
135 'Roo.apply( ' + cfg['*class'] + ".prototype , " :
137 cfg['//*class'] + "\n" +
138 cfg['*class'] + " = ";
141 endline = hasConstructor ? ');' : ';';
144 return this.outputHeader() +
146 this.objectToJsString(fcfg,1) +
155 copyTo: function(path, cb)
158 this.loadItems(function() {
168 * munge JSON tree into Javascript code.
170 * FIXME: + or / prefixes to properties hide it from renderer.
171 * FIXME: '*props' - not supported by this.. ?? - upto rendering code..
172 * FIXME: needs to understand what properties might be translatable (eg. double quotes)
174 * @arg {object} obj the object or array to munge..
175 * @arg {boolean} isListener - is the array being sent a listener..
176 * @arg {string} pad - the padding to indent with.
180 mungeToString: function(obj, isListener, pad)
185 isListener = isListener || false;
187 // am I munging a object or array...
188 if (obj.constructor.toString() === Array.toString()) {
189 for (var i= 0; i < obj.length; i++) {
203 typeof(obj['|xns']) != 'undefined' &&
204 typeof(obj['xtype']) != 'undefined'
206 this.mungeXtype(obj['|xns'] + '.' + obj['xtype'], els);
207 //els.push('xtype: '+ obj['|xns'] + '.' + obj['xtype']);
208 skip.push('|xns','xtype');
212 if (!isArray && obj.items && obj.items.length) {
215 obj.items.forEach(function(pl) {
216 if (typeof(pl['*prop']) == 'undefined') {
221 var prop = pl['*prop'] + '';
223 if (!prop.match(/\[\]$/)) {
224 // it's a standard prop..
229 // it's an array type..
230 obj[prop] = obj[prop] || [];
232 if (keys.indexOf(prop) < -1) {
239 obj.items = newitems;
240 if (!obj.items.length) {
254 keys.forEach(function(i) {
256 if (!isArray && skip.indexOf(i) > -1) { // things we do not write..
260 // set the key to be quoted with singel quotes..
261 var leftv = i[0] == '|' ? i.substring(1) : i;
262 if (Lang.isKeyword(leftv) || Lang.isBuiltin(leftv)) {
263 left = "'" + leftv + "'";
264 } else if (leftv.match(/[^A-Z_]+/i)) { // not plain a-z... - quoted.
265 var val = JSON.stringify(leftv);
266 left = "'" + val.substring(1, val.length-1).replace(/'/, "\\'") + "'";
274 // change the lines...
275 var str= ('' + obj[i]).replace(/^\s+|\s+$/g,"");
276 var lines = str.split("\n");
277 if (lines.length > 1) {
278 str = lines.join("\n" + pad);
280 els.push(left + str);
286 //var left = isArray ? '' : (JSON.stringify(i) + " : " )
289 // does not hapepnd with arrays..
290 if (typeof(el) == 'string' && !obj[i].length) { //skip empty.
293 // this needs to go...
294 //if (typeof(el) == 'string' && obj[i].match(new RegExp("Gtk.main" + "_quit"))) { // we can not handle this very well..
298 var str= ('' + obj[i]).replace(/^\s+|\s+$/g,"");;
299 var lines = str.split("\n");
300 if (lines.length > 1) {
301 str = lines.join("\n" + pad);
304 els.push(left + str);
311 if (typeof(el) == 'object') {
313 // we can skip empty items lists and empty listeners..
314 //if (!isArray && i == 'items' && !el.length) {
319 els.push(left + _this.mungeToString(el, i == 'listeners', pad + ' '));
324 els.push(left + JSON.stringify(obj[i]));
328 var spad = pad.substring(0, pad.length-4);
329 return (isArray ? '[' : '{') + "\n" +
330 pad + els.join(",\n" + pad ) +
331 "\n" + spad + (isArray ? ']' : '}');