console.js
[app.Builder.js] / console.js
1 //<Script type="text/javascript">
2 /**
3  * 
4  * simple console wrapper - emulates what you would expect from console
5  * 
6  * in theory could be replaced with a 'in-line console'
7  * 
8  * provides 'dump' in addtion to 'log'
9  * 
10  */
11
12  
13 function log (v)  {
14         print(v);
15 }
16 function dump (ar) {
17         print(_dump(ar, 0));
18 }
19
20 function _dump(arr,level) {
21     var dumped_text = "";
22     level = level || 0;
23     
24     
25     //The padding given at the beginning of the line.
26     var level_padding = "";
27     
28     for(var j=0;j<level+1;j++) {
29         level_padding += "    ";
30     }
31     
32     if(level > 15) {
33         return  level_padding + "[ ... to deep ...]\n";
34     }
35     
36     if (typeof(arr) != 'object') { //Array/Hashes/Objects 
37         return "===>"+arr+"<===("+typeof(arr)+")";
38     }
39
40     for(var item in arr) {
41         var value = arr[item];
42         switch (typeof(value)) {
43             case 'object' : 
44                 dumped_text += level_padding + "'" + item + "' ...\n";
45                 dumped_text += _dump(value,level+1) + "\n";
46                 break;
47             
48             case 'function' : 
49                 dumped_text += level_padding + "'" + item + "' => FUNCTION \n";
50                 break;
51             
52             default: 
53                 dumped_text += level_padding + "'" + item + "' => \"" + value + "\"\n";
54                 break;
55         }
56     }
57         
58     return dumped_text;
59 }