fixed bug; #7238: t3editor should not depend on MochiKit-Javascript-Framework
authorIngo Renner <ingo.renner@typo3.org>
Tue, 22 Jan 2008 17:21:13 +0000 (17:21 +0000)
committerIngo Renner <ingo.renner@typo3.org>
Tue, 22 Jan 2008 17:21:13 +0000 (17:21 +0000)
git-svn-id: https://svn.typo3.org/TYPO3v4/Core/trunk@2947 709f56b5-9817-0410-a4d7-c38de5d9e867

ChangeLog
typo3/sysext/t3editor/class.tx_t3editor.php
typo3/sysext/t3editor/ext_emconf.php
typo3/sysext/t3editor/jslib/Mochi.js [deleted file]
typo3/sysext/t3editor/jslib/parsetyposcript.js
typo3/sysext/t3editor/jslib/select.js
typo3/sysext/t3editor/jslib/stringstream.js
typo3/sysext/t3editor/jslib/t3editor.js

index 588f5b3..bba30d8 100755 (executable)
--- a/ChangeLog
+++ b/ChangeLog
@@ -2,6 +2,7 @@
 
        * added feature: #7223: update prototype and scriptaculous to their most recent versions
        * fixed bug: #7237: There is no way to get loaded interface
+       * fixed bug; #7238: t3editor should not depend on MochiKit-Javascript-Framework
 
 2008-01-21  Benjamin Mack  <mack@xnos.org>
 
index d67cbf7..8399f1e 100755 (executable)
@@ -127,8 +127,7 @@ class tx_t3editor {
                                'var PATH_t3e = "'.$GLOBALS['BACK_PATH']. t3lib_extmgm::extRelPath('t3editor').'"; '.
                                '</script>';
 
-                       $code.= '<script src="'.$path_t3e.'/jslib/Mochi.js" type="text/javascript"></script>'.
-                               '<script src="'.$path_t3e.'/jslib/util.js" type="text/javascript"></script>'.
+                       $code.= '<script src="'.$path_t3e.'/jslib/util.js" type="text/javascript"></script>'.
                                '<script src="'.$path_t3e.'/jslib/select.js" type="text/javascript"></script>'.
                                '<script src="'.$path_t3e.'/jslib/stringstream.js" type="text/javascript"></script>'.
                                '<script src="'.$path_t3e.'/jslib/parsetyposcript.js" type="text/javascript"></script>'.
index c9ca185..1b618c1 100755 (executable)
@@ -12,7 +12,7 @@
 
 $EM_CONF[$_EXTKEY] = array(
        'title' => 'Editor with syntax highlighting',
-       'description' => 'JavaScript-driven editor with syntax highlighting for TS, HTML, CSS and more. Based on CodeEditor.',
+       'description' => 'JavaScript-driven editor with syntax highlighting for TS and more. Based on CodeMirror.',
        'category' => 'be',
        'shy' => 0,
        'dependencies' => '',
@@ -32,7 +32,7 @@ $EM_CONF[$_EXTKEY] = array(
        'author_company' => '',
        'CGLcompliance' => '',
        'CGLcompliance_note' => '',
-       'version' => '0.0.5',
+       'version' => '0.0.6',
        '_md5_values_when_last_written' => 'a:14:{s:21:"class.tx_t3editor.php";s:4:"bb07";s:12:"ext_icon.gif";s:4:"4cef";s:16:"css/t3editor.css";s:4:"d4f1";s:23:"icons/loader_eeeeee.gif";s:4:"83a4";s:13:"jslib/LICENSE";s:4:"d835";s:14:"jslib/Mochi.js";s:4:"872d";s:24:"jslib/parsejavascript.js";s:4:"5377";s:24:"jslib/parsetyposcript.js";s:4:"7815";s:15:"jslib/select.js";s:4:"6725";s:21:"jslib/stringstream.js";s:4:"e6a5";s:17:"jslib/t3editor.js";s:4:"656c";s:27:"jslib/tokenizejavascript.js";s:4:"1c7a";s:27:"jslib/tokenizetyposcript.js";s:4:"c232";s:13:"jslib/util.js";s:4:"7620";}',
        'constraints' => array(
                'depends' => array(
diff --git a/typo3/sysext/t3editor/jslib/Mochi.js b/typo3/sysext/t3editor/jslib/Mochi.js
deleted file mode 100644 (file)
index 33e7c2a..0000000
+++ /dev/null
@@ -1,3808 +0,0 @@
-/***
-
-    MochiKit.MochiKit 1.4 : PACKED VERSION
-
-    THIS FILE IS AUTOMATICALLY GENERATED.  If creating patches, please
-    diff against the source tree, not this file.
-
-    See <http://mochikit.com/> for documentation, downloads, license, etc.
-
-    (c) 2005 Bob Ippolito.  All rights Reserved.
-
-***/
-
-if(typeof (dojo)!="undefined"){
-dojo.provide("MochiKit.Base");
-}
-if(typeof (MochiKit)=="undefined"){
-MochiKit={};
-}
-if(typeof (MochiKit.Base)=="undefined"){
-MochiKit.Base={};
-}
-if(typeof (MochiKit.__export__)=="undefined"){
-MochiKit.__export__=(MochiKit.__compat__||(typeof (JSAN)=="undefined"&&typeof (dojo)=="undefined"));
-}
-MochiKit.Base.VERSION="1.4";
-MochiKit.Base.NAME="MochiKit.Base";
-MochiKit.Base.update=function(_1,_2){
-if(_1===null){
-_1={};
-}
-for(var i=1;i<arguments.length;i++){
-var o=arguments[i];
-if(typeof (o)!="undefined"&&o!==null){
-for(var k in o){
-_1[k]=o[k];
-}
-}
-}
-return _1;
-};
-MochiKit.Base.update(MochiKit.Base,{__repr__:function(){
-return "["+this.NAME+" "+this.VERSION+"]";
-},toString:function(){
-return this.__repr__();
-},camelize:function(_6){
-var _7=_6.split("-");
-var cc=_7[0];
-for(var i=1;i<_7.length;i++){
-cc+=_7[i].charAt(0).toUpperCase()+_7[i].substring(1);
-}
-return cc;
-},counter:function(n){
-if(arguments.length===0){
-n=1;
-}
-return function(){
-return n++;
-};
-},clone:function(_b){
-var me=arguments.callee;
-if(arguments.length==1){
-me.prototype=_b;
-return new me();
-}
-},_flattenArray:function(_d,_e){
-for(var i=0;i<_e.length;i++){
-var o=_e[i];
-if(o instanceof Array){
-arguments.callee(_d,o);
-}else{
-_d.push(o);
-}
-}
-return _d;
-},flattenArray:function(lst){
-return MochiKit.Base._flattenArray([],lst);
-},flattenArguments:function(lst){
-var res=[];
-var m=MochiKit.Base;
-var _15=m.extend(null,arguments);
-while(_15.length){
-var o=_15.shift();
-if(o&&typeof (o)=="object"&&typeof (o.length)=="number"){
-for(var i=o.length-1;i>=0;i--){
-_15.unshift(o[i]);
-}
-}else{
-res.push(o);
-}
-}
-return res;
-},extend:function(_18,obj,_1a){
-if(!_1a){
-_1a=0;
-}
-if(obj){
-var l=obj.length;
-if(typeof (l)!="number"){
-if(typeof (MochiKit.Iter)!="undefined"){
-obj=MochiKit.Iter.list(obj);
-l=obj.length;
-}else{
-throw new TypeError("Argument not an array-like and MochiKit.Iter not present");
-}
-}
-if(!_18){
-_18=[];
-}
-for(var i=_1a;i<l;i++){
-_18.push(obj[i]);
-}
-}
-return _18;
-},updatetree:function(_1d,obj){
-if(_1d===null){
-_1d={};
-}
-for(var i=1;i<arguments.length;i++){
-var o=arguments[i];
-if(typeof (o)!="undefined"&&o!==null){
-for(var k in o){
-var v=o[k];
-if(typeof (_1d[k])=="object"&&typeof (v)=="object"){
-arguments.callee(_1d[k],v);
-}else{
-_1d[k]=v;
-}
-}
-}
-}
-return _1d;
-},setdefault:function(_23,obj){
-if(_23===null){
-_23={};
-}
-for(var i=1;i<arguments.length;i++){
-var o=arguments[i];
-for(var k in o){
-if(!(k in _23)){
-_23[k]=o[k];
-}
-}
-}
-return _23;
-},keys:function(obj){
-var _29=[];
-for(var _2a in obj){
-_29.push(_2a);
-}
-return _29;
-},values:function(obj){
-var _2c=[];
-for(var _2d in obj){
-_2c.push(obj[_2d]);
-}
-return _2c;
-},items:function(obj){
-var _2f=[];
-var e;
-for(var _31 in obj){
-var v;
-try{
-v=obj[_31];
-}
-catch(e){
-continue;
-}
-_2f.push([_31,v]);
-}
-return _2f;
-},_newNamedError:function(_33,_34,_35){
-_35.prototype=new MochiKit.Base.NamedError(_33.NAME+"."+_34);
-_33[_34]=_35;
-},operator:{truth:function(a){
-return !!a;
-},lognot:function(a){
-return !a;
-},identity:function(a){
-return a;
-},not:function(a){
-return ~a;
-},neg:function(a){
-return -a;
-},add:function(a,b){
-return a+b;
-},sub:function(a,b){
-return a-b;
-},div:function(a,b){
-return a/b;
-},mod:function(a,b){
-return a%b;
-},mul:function(a,b){
-return a*b;
-},and:function(a,b){
-return a&b;
-},or:function(a,b){
-return a|b;
-},xor:function(a,b){
-return a^b;
-},lshift:function(a,b){
-return a<<b;
-},rshift:function(a,b){
-return a>>b;
-},zrshift:function(a,b){
-return a>>>b;
-},eq:function(a,b){
-return a==b;
-},ne:function(a,b){
-return a!=b;
-},gt:function(a,b){
-return a>b;
-},ge:function(a,b){
-return a>=b;
-},lt:function(a,b){
-return a<b;
-},le:function(a,b){
-return a<=b;
-},seq:function(a,b){
-return a===b;
-},sne:function(a,b){
-return a!==b;
-},ceq:function(a,b){
-return MochiKit.Base.compare(a,b)===0;
-},cne:function(a,b){
-return MochiKit.Base.compare(a,b)!==0;
-},cgt:function(a,b){
-return MochiKit.Base.compare(a,b)==1;
-},cge:function(a,b){
-return MochiKit.Base.compare(a,b)!=-1;
-},clt:function(a,b){
-return MochiKit.Base.compare(a,b)==-1;
-},cle:function(a,b){
-return MochiKit.Base.compare(a,b)!=1;
-},logand:function(a,b){
-return a&&b;
-},logor:function(a,b){
-return a||b;
-},contains:function(a,b){
-return b in a;
-}},forwardCall:function(_73){
-return function(){
-return this[_73].apply(this,arguments);
-};
-},itemgetter:function(_74){
-return function(arg){
-return arg[_74];
-};
-},typeMatcher:function(){
-var _76={};
-for(var i=0;i<arguments.length;i++){
-var typ=arguments[i];
-_76[typ]=typ;
-}
-return function(){
-for(var i=0;i<arguments.length;i++){
-if(!(typeof (arguments[i]) in _76)){
-return false;
-}
-}
-return true;
-};
-},isNull:function(){
-for(var i=0;i<arguments.length;i++){
-if(arguments[i]!==null){
-return false;
-}
-}
-return true;
-},isUndefinedOrNull:function(){
-for(var i=0;i<arguments.length;i++){
-var o=arguments[i];
-if(!(typeof (o)=="undefined"||o===null)){
-return false;
-}
-}
-return true;
-},isEmpty:function(obj){
-return !MochiKit.Base.isNotEmpty.apply(this,arguments);
-},isNotEmpty:function(obj){
-for(var i=0;i<arguments.length;i++){
-var o=arguments[i];
-if(!(o&&o.length)){
-return false;
-}
-}
-return true;
-},isArrayLike:function(){
-for(var i=0;i<arguments.length;i++){
-var o=arguments[i];
-var typ=typeof (o);
-if((typ!="object"&&!(typ=="function"&&typeof (o.item)=="function"))||o===null||typeof (o.length)!="number"||o.nodeType===3){
-return false;
-}
-}
-return true;
-},isDateLike:function(){
-for(var i=0;i<arguments.length;i++){
-var o=arguments[i];
-if(typeof (o)!="object"||o===null||typeof (o.getTime)!="function"){
-return false;
-}
-}
-return true;
-},xmap:function(fn){
-if(fn===null){
-return MochiKit.Base.extend(null,arguments,1);
-}
-var _87=[];
-for(var i=1;i<arguments.length;i++){
-_87.push(fn(arguments[i]));
-}
-return _87;
-},map:function(fn,lst){
-var m=MochiKit.Base;
-var itr=MochiKit.Iter;
-var _8d=m.isArrayLike;
-if(arguments.length<=2){
-if(!_8d(lst)){
-if(itr){
-lst=itr.list(lst);
-if(fn===null){
-return lst;
-}
-}else{
-throw new TypeError("Argument not an array-like and MochiKit.Iter not present");
-}
-}
-if(fn===null){
-return m.extend(null,lst);
-}
-var _8e=[];
-for(var i=0;i<lst.length;i++){
-_8e.push(fn(lst[i]));
-}
-return _8e;
-}else{
-if(fn===null){
-fn=Array;
-}
-var _90=null;
-for(i=1;i<arguments.length;i++){
-if(!_8d(arguments[i])){
-if(itr){
-return itr.list(itr.imap.apply(null,arguments));
-}else{
-throw new TypeError("Argument not an array-like and MochiKit.Iter not present");
-}
-}
-var l=arguments[i].length;
-if(_90===null||_90>l){
-_90=l;
-}
-}
-_8e=[];
-for(i=0;i<_90;i++){
-var _92=[];
-for(var j=1;j<arguments.length;j++){
-_92.push(arguments[j][i]);
-}
-_8e.push(fn.apply(this,_92));
-}
-return _8e;
-}
-},xfilter:function(fn){
-var _95=[];
-if(fn===null){
-fn=MochiKit.Base.operator.truth;
-}
-for(var i=1;i<arguments.length;i++){
-var o=arguments[i];
-if(fn(o)){
-_95.push(o);
-}
-}
-return _95;
-},filter:function(fn,lst,_9a){
-var _9b=[];
-var m=MochiKit.Base;
-if(!m.isArrayLike(lst)){
-if(MochiKit.Iter){
-lst=MochiKit.Iter.list(lst);
-}else{
-throw new TypeError("Argument not an array-like and MochiKit.Iter not present");
-}
-}
-if(fn===null){
-fn=m.operator.truth;
-}
-if(typeof (Array.prototype.filter)=="function"){
-return Array.prototype.filter.call(lst,fn,_9a);
-}else{
-if(typeof (_9a)=="undefined"||_9a===null){
-for(var i=0;i<lst.length;i++){
-var o=lst[i];
-if(fn(o)){
-_9b.push(o);
-}
-}
-}else{
-for(i=0;i<lst.length;i++){
-o=lst[i];
-if(fn.call(_9a,o)){
-_9b.push(o);
-}
-}
-}
-}
-return _9b;
-},_wrapDumbFunction:function(_9f){
-return function(){
-switch(arguments.length){
-case 0:
-return _9f();
-case 1:
-return _9f(arguments[0]);
-case 2:
-return _9f(arguments[0],arguments[1]);
-case 3:
-return _9f(arguments[0],arguments[1],arguments[2]);
-}
-var _a0=[];
-for(var i=0;i<arguments.length;i++){
-_a0.push("arguments["+i+"]");
-}
-return eval("(func("+_a0.join(",")+"))");
-};
-},methodcaller:function(_a2){
-var _a3=MochiKit.Base.extend(null,arguments,1);
-if(typeof (_a2)=="function"){
-return function(obj){
-return _a2.apply(obj,_a3);
-};
-}else{
-return function(obj){
-return obj[_a2].apply(obj,_a3);
-};
-}
-},method:function(_a6,_a7){
-var m=MochiKit.Base;
-return m.bind.apply(this,m.extend([_a7,_a6],arguments,2));
-},compose:function(f1,f2){
-var _ab=[];
-var m=MochiKit.Base;
-if(arguments.length===0){
-throw new TypeError("compose() requires at least one argument");
-}
-for(var i=0;i<arguments.length;i++){
-var fn=arguments[i];
-if(typeof (fn)!="function"){
-throw new TypeError(m.repr(fn)+" is not a function");
-}
-_ab.push(fn);
-}
-return function(){
-var _af=arguments;
-for(var i=_ab.length-1;i>=0;i--){
-_af=[_ab[i].apply(this,_af)];
-}
-return _af[0];
-};
-},bind:function(_b1,_b2){
-if(typeof (_b1)=="string"){
-_b1=_b2[_b1];
-}
-var _b3=_b1.im_func;
-var _b4=_b1.im_preargs;
-var _b5=_b1.im_self;
-var m=MochiKit.Base;
-if(typeof (_b1)=="function"&&typeof (_b1.apply)=="undefined"){
-_b1=m._wrapDumbFunction(_b1);
-}
-if(typeof (_b3)!="function"){
-_b3=_b1;
-}
-if(typeof (_b2)!="undefined"){
-_b5=_b2;
-}
-if(typeof (_b4)=="undefined"){
-_b4=[];
-}else{
-_b4=_b4.slice();
-}
-m.extend(_b4,arguments,2);
-var _b7=function(){
-var _b8=arguments;
-var me=arguments.callee;
-if(me.im_preargs.length>0){
-_b8=m.concat(me.im_preargs,_b8);
-}
-var _ba=me.im_self;
-if(!_ba){
-_ba=this;
-}
-return me.im_func.apply(_ba,_b8);
-};
-_b7.im_self=_b5;
-_b7.im_func=_b3;
-_b7.im_preargs=_b4;
-return _b7;
-},bindMethods:function(_bb){
-var _bc=MochiKit.Base.bind;
-for(var k in _bb){
-var _be=_bb[k];
-if(typeof (_be)=="function"){
-_bb[k]=_bc(_be,_bb);
-}
-}
-},registerComparator:function(_bf,_c0,_c1,_c2){
-MochiKit.Base.comparatorRegistry.register(_bf,_c0,_c1,_c2);
-},_primitives:{"boolean":true,"string":true,"number":true},compare:function(a,b){
-if(a==b){
-return 0;
-}
-var _c5=(typeof (a)=="undefined"||a===null);
-var _c6=(typeof (b)=="undefined"||b===null);
-if(_c5&&_c6){
-return 0;
-}else{
-if(_c5){
-return -1;
-}else{
-if(_c6){
-return 1;
-}
-}
-}
-var m=MochiKit.Base;
-var _c8=m._primitives;
-if(!(typeof (a) in _c8&&typeof (b) in _c8)){
-try{
-return m.comparatorRegistry.match(a,b);
-}
-catch(e){
-if(e!=m.NotFound){
-throw e;
-}
-}
-}
-if(a<b){
-return -1;
-}else{
-if(a>b){
-return 1;
-}
-}
-var _c9=m.repr;
-throw new TypeError(_c9(a)+" and "+_c9(b)+" can not be compared");
-},compareDateLike:function(a,b){
-return MochiKit.Base.compare(a.getTime(),b.getTime());
-},compareArrayLike:function(a,b){
-var _ce=MochiKit.Base.compare;
-var _cf=a.length;
-var _d0=0;
-if(_cf>b.length){
-_d0=1;
-_cf=b.length;
-}else{
-if(_cf<b.length){
-_d0=-1;
-}
-}
-for(var i=0;i<_cf;i++){
-var cmp=_ce(a[i],b[i]);
-if(cmp){
-return cmp;
-}
-}
-return _d0;
-},registerRepr:function(_d3,_d4,_d5,_d6){
-MochiKit.Base.reprRegistry.register(_d3,_d4,_d5,_d6);
-},repr:function(o){
-if(typeof (o)=="undefined"){
-return "undefined";
-}else{
-if(o===null){
-return "null";
-}
-}
-try{
-if(typeof (o.__repr__)=="function"){
-return o.__repr__();
-}else{
-if(typeof (o.repr)=="function"&&o.repr!=arguments.callee){
-return o.repr();
-}
-}
-return MochiKit.Base.reprRegistry.match(o);
-}
-catch(e){
-if(typeof (o.NAME)=="string"&&(o.toString==Function.prototype.toString||o.toString==Object.prototype.toString)){
-return o.NAME;
-}
-}
-try{
-var _d8=(o+"");
-}
-catch(e){
-return "["+typeof (o)+"]";
-}
-if(typeof (o)=="function"){
-o=_d8.replace(/^\s+/,"");
-var idx=o.indexOf("{");
-if(idx!=-1){
-o=o.substr(0,idx)+"{...}";
-}
-}
-return _d8;
-},reprArrayLike:function(o){
-var m=MochiKit.Base;
-return "["+m.map(m.repr,o).join(", ")+"]";
-},reprString:function(o){
-return ("\""+o.replace(/(["\\])/g,"\\$1")+"\"").replace(/[\f]/g,"\\f").replace(/[\b]/g,"\\b").replace(/[\n]/g,"\\n").replace(/[\t]/g,"\\t").replace(/[\r]/g,"\\r");
-},reprNumber:function(o){
-return o+"";
-},registerJSON:function(_de,_df,_e0,_e1){
-MochiKit.Base.jsonRegistry.register(_de,_df,_e0,_e1);
-},evalJSON:function(){
-return eval("("+MochiKit.Base._filterJSON(arguments[0])+")");
-},_filterJSON:function(s){
-var m=s.match(/^\s*\/\*(.*)\*\/\s*$/);
-if(m){
-return m[1];
-}
-return s;
-},serializeJSON:function(o){
-var _e5=typeof (o);
-if(_e5=="number"||_e5=="boolean"){
-return o+"";
-}else{
-if(o===null){
-return "null";
-}
-}
-var m=MochiKit.Base;
-var _e7=m.reprString;
-if(_e5=="string"){
-return _e7(o);
-}
-var me=arguments.callee;
-var _e9;
-if(typeof (o.__json__)=="function"){
-_e9=o.__json__();
-if(o!==_e9){
-return me(_e9);
-}
-}
-if(typeof (o.json)=="function"){
-_e9=o.json();
-if(o!==_e9){
-return me(_e9);
-}
-}
-if(_e5!="function"&&typeof (o.length)=="number"){
-var res=[];
-for(var i=0;i<o.length;i++){
-var val=me(o[i]);
-if(typeof (val)!="string"){
-val="undefined";
-}
-res.push(val);
-}
-return "["+res.join(", ")+"]";
-}
-try{
-_e9=m.jsonRegistry.match(o);
-if(o!==_e9){
-return me(_e9);
-}
-}
-catch(e){
-if(e!=m.NotFound){
-throw e;
-}
-}
-if(_e5=="undefined"){
-throw new TypeError("undefined can not be serialized as JSON");
-}
-if(_e5=="function"){
-return null;
-}
-res=[];
-for(var k in o){
-var _ee;
-if(typeof (k)=="number"){
-_ee="\""+k+"\"";
-}else{
-if(typeof (k)=="string"){
-_ee=_e7(k);
-}else{
-continue;
-}
-}
-val=me(o[k]);
-if(typeof (val)!="string"){
-continue;
-}
-res.push(_ee+":"+val);
-}
-return "{"+res.join(", ")+"}";
-},objEqual:function(a,b){
-return (MochiKit.Base.compare(a,b)===0);
-},arrayEqual:function(_f1,arr){
-if(_f1.length!=arr.length){
-return false;
-}
-return (MochiKit.Base.compare(_f1,arr)===0);
-},concat:function(){
-var _f3=[];
-var _f4=MochiKit.Base.extend;
-for(var i=0;i<arguments.length;i++){
-_f4(_f3,arguments[i]);
-}
-return _f3;
-},keyComparator:function(key){
-var m=MochiKit.Base;
-var _f8=m.compare;
-if(arguments.length==1){
-return function(a,b){
-return _f8(a[key],b[key]);
-};
-}
-var _fb=m.extend(null,arguments);
-return function(a,b){
-var _fe=0;
-for(var i=0;(_fe===0)&&(i<_fb.length);i++){
-var key=_fb[i];
-_fe=_f8(a[key],b[key]);
-}
-return _fe;
-};
-},reverseKeyComparator:function(key){
-var _102=MochiKit.Base.keyComparator.apply(this,arguments);
-return function(a,b){
-return _102(b,a);
-};
-},partial:function(func){
-var m=MochiKit.Base;
-return m.bind.apply(this,m.extend([func,undefined],arguments,1));
-},listMinMax:function(_107,lst){
-if(lst.length===0){
-return null;
-}
-var cur=lst[0];
-var _10a=MochiKit.Base.compare;
-for(var i=1;i<lst.length;i++){
-var o=lst[i];
-if(_10a(o,cur)==_107){
-cur=o;
-}
-}
-return cur;
-},objMax:function(){
-return MochiKit.Base.listMinMax(1,arguments);
-},objMin:function(){
-return MochiKit.Base.listMinMax(-1,arguments);
-},findIdentical:function(lst,_10e,_10f,end){
-if(typeof (end)=="undefined"||end===null){
-end=lst.length;
-}
-if(typeof (_10f)=="undefined"||_10f===null){
-_10f=0;
-}
-for(var i=_10f;i<end;i++){
-if(lst[i]===_10e){
-return i;
-}
-}
-return -1;
-},mean:function(){
-var sum=0;
-var m=MochiKit.Base;
-var args=m.extend(null,arguments);
-var _115=args.length;
-while(args.length){
-var o=args.shift();
-if(o&&typeof (o)=="object"&&typeof (o.length)=="number"){
-_115+=o.length-1;
-for(var i=o.length-1;i>=0;i--){
-sum+=o[i];
-}
-}else{
-sum+=o;
-}
-}
-if(_115<=0){
-throw new TypeError("mean() requires at least one argument");
-}
-return sum/_115;
-},median:function(){
-var data=MochiKit.Base.flattenArguments(arguments);
-if(data.length===0){
-throw new TypeError("median() requires at least one argument");
-}
-data.sort(compare);
-if(data.length%2==0){
-var _119=data.length/2;
-return (data[_119]+data[_119-1])/2;
-}else{
-return data[(data.length-1)/2];
-}
-},findValue:function(lst,_11b,_11c,end){
-if(typeof (end)=="undefined"||end===null){
-end=lst.length;
-}
-if(typeof (_11c)=="undefined"||_11c===null){
-_11c=0;
-}
-var cmp=MochiKit.Base.compare;
-for(var i=_11c;i<end;i++){
-if(cmp(lst[i],_11b)===0){
-return i;
-}
-}
-return -1;
-},nodeWalk:function(node,_121){
-var _122=[node];
-var _123=MochiKit.Base.extend;
-while(_122.length){
-var res=_121(_122.shift());
-if(res){
-_123(_122,res);
-}
-}
-},nameFunctions:function(_125){
-var base=_125.NAME;
-if(typeof (base)=="undefined"){
-base="";
-}else{
-base=base+".";
-}
-for(var name in _125){
-var o=_125[name];
-if(typeof (o)=="function"&&typeof (o.NAME)=="undefined"){
-try{
-o.NAME=base+name;
-}
-catch(e){
-}
-}
-}
-},queryString:function(_129,_12a){
-if(typeof (MochiKit.DOM)!="undefined"&&arguments.length==1&&(typeof (_129)=="string"||(typeof (_129.nodeType)!="undefined"&&_129.nodeType>0))){
-var kv=MochiKit.DOM.formContents(_129);
-_129=kv[0];
-_12a=kv[1];
-}else{
-if(arguments.length==1){
-if(typeof (_129.length)=="number"&&_129.length==2){
-return arguments.callee(_129[0],_129[1]);
-}
-var o=_129;
-_129=[];
-_12a=[];
-for(var k in o){
-var v=o[k];
-if(typeof (v)=="function"){
-continue;
-}else{
-if(typeof (v)!="string"&&typeof (v.length)=="number"){
-for(var i=0;i<v.length;i++){
-_129.push(k);
-_12a.push(v[i]);
-}
-}else{
-_129.push(k);
-_12a.push(v);
-}
-}
-}
-}
-}
-var rval=[];
-var len=Math.min(_129.length,_12a.length);
-var _132=MochiKit.Base.urlEncode;
-for(var i=0;i<len;i++){
-v=_12a[i];
-if(typeof (v)!="undefined"&&v!==null){
-rval.push(_132(_129[i])+"="+_132(v));
-}
-}
-return rval.join("&");
-},parseQueryString:function(_133,_134){
-var qstr=(_133.charAt(0)=="?")?_133.substring(1):_133;
-var _136=qstr.replace(/\+/g,"%20").split(/(\&amp\;|\&\#38\;|\&#x26;|\&)/);
-var o={};
-var _138;
-if(typeof (decodeURIComponent)!="undefined"){
-_138=decodeURIComponent;
-}else{
-_138=unescape;
-}
-if(_134){
-for(var i=0;i<_136.length;i++){
-var pair=_136[i].split("=");
-var name=_138(pair.shift());
-if(!name){
-continue;
-}
-var arr=o[name];
-if(!(arr instanceof Array)){
-arr=[];
-o[name]=arr;
-}
-arr.push(_138(pair.join("=")));
-}
-}else{
-for(i=0;i<_136.length;i++){
-pair=_136[i].split("=");
-var name=pair.shift();
-if(!name){
-continue;
-}
-o[_138(name)]=_138(pair.join("="));
-}
-}
-return o;
-}});
-MochiKit.Base.AdapterRegistry=function(){
-this.pairs=[];
-};
-MochiKit.Base.AdapterRegistry.prototype={register:function(name,_13e,wrap,_140){
-if(_140){
-this.pairs.unshift([name,_13e,wrap]);
-}else{
-this.pairs.push([name,_13e,wrap]);
-}
-},match:function(){
-for(var i=0;i<this.pairs.length;i++){
-var pair=this.pairs[i];
-if(pair[1].apply(this,arguments)){
-return pair[2].apply(this,arguments);
-}
-}
-throw MochiKit.Base.NotFound;
-},unregister:function(name){
-for(var i=0;i<this.pairs.length;i++){
-var pair=this.pairs[i];
-if(pair[0]==name){
-this.pairs.splice(i,1);
-return true;
-}
-}
-return false;
-}};
-MochiKit.Base.EXPORT=["flattenArray","noop","camelize","counter","clone","extend","update","updatetree","setdefault","keys","values","items","NamedError","operator","forwardCall","itemgetter","typeMatcher","isCallable","isUndefined","isUndefinedOrNull","isNull","isEmpty","isNotEmpty","isArrayLike","isDateLike","xmap","map","xfilter","filter","methodcaller","compose","bind","bindMethods","NotFound","AdapterRegistry","registerComparator","compare","registerRepr","repr","objEqual","arrayEqual","concat","keyComparator","reverseKeyComparator","partial","merge","listMinMax","listMax","listMin","objMax","objMin","nodeWalk","zip","urlEncode","queryString","serializeJSON","registerJSON","evalJSON","parseQueryString","findValue","findIdentical","flattenArguments","method","average","mean","median"];
-MochiKit.Base.EXPORT_OK=["nameFunctions","comparatorRegistry","reprRegistry","jsonRegistry","compareDateLike","compareArrayLike","reprArrayLike","reprString","reprNumber"];
-MochiKit.Base._exportSymbols=function(_146,_147){
-if(!MochiKit.__export__){
-return;
-}
-var all=_147.EXPORT_TAGS[":all"];
-for(var i=0;i<all.length;i++){
-_146[all[i]]=_147[all[i]];
-}
-};
-MochiKit.Base.__new__=function(){
-var m=this;
-m.noop=m.operator.identity;
-m.forward=m.forwardCall;
-m.find=m.findValue;
-if(typeof (encodeURIComponent)!="undefined"){
-m.urlEncode=function(_14b){
-return encodeURIComponent(_14b).replace(/\'/g,"%27");
-};
-}else{
-m.urlEncode=function(_14c){
-return escape(_14c).replace(/\+/g,"%2B").replace(/\"/g,"%22").rval.replace(/\'/g,"%27");
-};
-}
-m.NamedError=function(name){
-this.message=name;
-this.name=name;
-};
-m.NamedError.prototype=new Error();
-m.update(m.NamedError.prototype,{repr:function(){
-if(this.message&&this.message!=this.name){
-return this.name+"("+m.repr(this.message)+")";
-}else{
-return this.name+"()";
-}
-},toString:m.forwardCall("repr")});
-m.NotFound=new m.NamedError("MochiKit.Base.NotFound");
-m.listMax=m.partial(m.listMinMax,1);
-m.listMin=m.partial(m.listMinMax,-1);
-m.isCallable=m.typeMatcher("function");
-m.isUndefined=m.typeMatcher("undefined");
-m.merge=m.partial(m.update,null);
-m.zip=m.partial(m.map,null);
-m.average=m.mean;
-m.comparatorRegistry=new m.AdapterRegistry();
-m.registerComparator("dateLike",m.isDateLike,m.compareDateLike);
-m.registerComparator("arrayLike",m.isArrayLike,m.compareArrayLike);
-m.reprRegistry=new m.AdapterRegistry();
-m.registerRepr("arrayLike",m.isArrayLike,m.reprArrayLike);
-m.registerRepr("string",m.typeMatcher("string"),m.reprString);
-m.registerRepr("numbers",m.typeMatcher("number","boolean"),m.reprNumber);
-m.jsonRegistry=new m.AdapterRegistry();
-var all=m.concat(m.EXPORT,m.EXPORT_OK);
-m.EXPORT_TAGS={":common":m.concat(m.EXPORT_OK),":all":all};
-m.nameFunctions(this);
-};
-MochiKit.Base.__new__();
-if(MochiKit.__export__){
-compare=MochiKit.Base.compare;
-compose=MochiKit.Base.compose;
-serializeJSON=MochiKit.Base.serializeJSON;
-}
-MochiKit.Base._exportSymbols(this,MochiKit.Base);
-if(typeof (dojo)!="undefined"){
-dojo.provide("MochiKit.DOM");
-dojo.require("MochiKit.Base");
-}
-if(typeof (JSAN)!="undefined"){
-JSAN.use("MochiKit.Base",[]);
-}
-try{
-if(typeof (MochiKit.Base)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.DOM depends on MochiKit.Base!";
-}
-if(typeof (MochiKit.DOM)=="undefined"){
-MochiKit.DOM={};
-}
-MochiKit.DOM.NAME="MochiKit.DOM";
-MochiKit.DOM.VERSION="1.4";
-MochiKit.DOM.__repr__=function(){
-return "["+this.NAME+" "+this.VERSION+"]";
-};
-MochiKit.DOM.toString=function(){
-return this.__repr__();
-};
-MochiKit.DOM.EXPORT=["removeEmptyTextNodes","formContents","currentWindow","currentDocument","withWindow","withDocument","registerDOMConverter","coerceToDOM","createDOM","createDOMFunc","isChildNode","getNodeAttribute","removeNodeAttribute","setNodeAttribute","updateNodeAttributes","appendChildNodes","insertSiblingNodesAfter","insertSiblingNodesBefore","replaceChildNodes","removeElement","swapDOM","BUTTON","TT","PRE","H1","H2","H3","BR","CANVAS","HR","LABEL","TEXTAREA","FORM","STRONG","SELECT","OPTION","OPTGROUP","LEGEND","FIELDSET","P","UL","OL","LI","TD","TR","THEAD","TBODY","TFOOT","TABLE","TH","INPUT","SPAN","A","DIV","IMG","getElement","$","getElementsByTagAndClassName","addToCallStack","addLoadEvent","focusOnLoad","setElementClass","toggleElementClass","addElementClass","removeElementClass","swapElementClass","hasElementClass","escapeHTML","toHTML","emitHTML","scrapeText","isParent","getFirstParentByTagAndClassName","makeClipping","undoClipping","makePositioned","undoPositioned","getFirstElementByTagAndClassName"];
-MochiKit.DOM.EXPORT_OK=["domConverters"];
-MochiKit.DOM.DEPRECATED=[["computedStyle","MochiKit.Style.getStyle","1.4"],["elementDimensions","MochiKit.Style.getElementDimensions","1.4"],["elementPosition","MochiKit.Style.getElementPosition","1.4"],["hideElement","MochiKit.Style.hideElement","1.4"],["setElementDimensions","MochiKit.Style.setElementDimensions","1.4"],["setElementPosition","MochiKit.Style.setElementPosition","1.4"],["setDisplayForElement","MochiKit.Style.setDisplayForElement","1.4"],["setOpacity","MochiKit.Style.setOpacity","1.4"],["showElement","MochiKit.Style.showElement","1.4"],["Coordinates","MochiKit.Style.Coordinates","1.4"],["Dimensions","MochiKit.Style.Dimensions","1.4"]];
-MochiKit.DOM.getViewportDimensions=new Function(""+"if (!MochiKit[\"Style\"]) {"+"    throw new Error(\"This function has been deprecated and depends on MochiKit.Style.\");"+"}"+"return MochiKit.Style.getViewportDimensions.apply(this, arguments);");
-MochiKit.Base.update(MochiKit.DOM,{currentWindow:function(){
-return MochiKit.DOM._window;
-},currentDocument:function(){
-return MochiKit.DOM._document;
-},withWindow:function(win,func){
-var self=MochiKit.DOM;
-var _152=self._document;
-var _153=self._window;
-var rval;
-try{
-self._window=win;
-self._document=win.document;
-rval=func();
-}
-catch(e){
-self._window=_153;
-self._document=_152;
-throw e;
-}
-self._window=_153;
-self._document=_152;
-return rval;
-},formContents:function(elem){
-var _156=[];
-var _157=[];
-var m=MochiKit.Base;
-var self=MochiKit.DOM;
-if(typeof (elem)=="undefined"||elem===null){
-elem=self._document.body;
-}else{
-elem=self.getElement(elem);
-}
-m.nodeWalk(elem,function(elem){
-var name=elem.name;
-if(m.isNotEmpty(name)){
-var _15c=elem.tagName.toUpperCase();
-if(_15c==="INPUT"&&(elem.type=="radio"||elem.type=="checkbox")&&!elem.checked){
-return null;
-}
-if(_15c==="SELECT"){
-if(elem.type=="select-one"){
-if(elem.selectedIndex>=0){
-var opt=elem.options[elem.selectedIndex];
-var v=opt.value;
-if(!v){
-var h=opt.outerHTML;
-if(h&&!h.match(/^[^>]+\svalue\s*=/i)){
-v=opt.text;
-}
-}
-_156.push(name);
-_157.push(v);
-return null;
-}
-_156.push(name);
-_157.push("");
-return null;
-}else{
-var opts=elem.options;
-if(!opts.length){
-_156.push(name);
-_157.push("");
-return null;
-}
-for(var i=0;i<opts.length;i++){
-var opt=opts[i];
-if(!opt.selected){
-continue;
-}
-var v=opt.value;
-if(!v){
-var h=opt.outerHTML;
-if(h&&!h.match(/^[^>]+\svalue\s*=/i)){
-v=opt.text;
-}
-}
-_156.push(name);
-_157.push(v);
-}
-return null;
-}
-}
-if(_15c==="FORM"||_15c==="P"||_15c==="SPAN"||_15c==="DIV"){
-return elem.childNodes;
-}
-_156.push(name);
-_157.push(elem.value||"");
-return null;
-}
-return elem.childNodes;
-});
-return [_156,_157];
-},withDocument:function(doc,func){
-var self=MochiKit.DOM;
-var _165=self._document;
-var rval;
-try{
-self._document=doc;
-rval=func();
-}
-catch(e){
-self._document=_165;
-throw e;
-}
-self._document=_165;
-return rval;
-},registerDOMConverter:function(name,_168,wrap,_16a){
-MochiKit.DOM.domConverters.register(name,_168,wrap,_16a);
-},coerceToDOM:function(node,ctx){
-var m=MochiKit.Base;
-var im=MochiKit.Iter;
-var self=MochiKit.DOM;
-if(im){
-var iter=im.iter;
-var _171=im.repeat;
-var map=m.map;
-}
-var _173=self.domConverters;
-var _174=arguments.callee;
-var _175=m.NotFound;
-while(true){
-if(typeof (node)=="undefined"||node===null){
-return null;
-}
-if(typeof (node)=="function"&&typeof (node.length)=="number"&&!(node instanceof Function)){
-node=im.list(node);
-}
-if(typeof (node.nodeType)!="undefined"&&node.nodeType>0){
-return node;
-}
-if(typeof (node)=="number"||typeof (node)=="boolean"){
-node=node.toString();
-}
-if(typeof (node)=="string"){
-return self._document.createTextNode(node);
-}
-if(typeof (node.__dom__)=="function"){
-node=node.__dom__(ctx);
-continue;
-}
-if(typeof (node.dom)=="function"){
-node=node.dom(ctx);
-continue;
-}
-if(typeof (node)=="function"){
-node=node.apply(ctx,[ctx]);
-continue;
-}
-if(im){
-var _176=null;
-try{
-_176=iter(node);
-}
-catch(e){
-}
-if(_176){
-return map(_174,_176,_171(ctx));
-}
-}
-try{
-node=_173.match(node,ctx);
-continue;
-}
-catch(e){
-if(e!=_175){
-throw e;
-}
-}
-return self._document.createTextNode(node.toString());
-}
-return undefined;
-},isChildNode:function(node,_178){
-var self=MochiKit.DOM;
-if(typeof (node)=="string"){
-node=self.getElement(node);
-}
-if(typeof (_178)=="string"){
-_178=self.getElement(_178);
-}
-if(node===_178){
-return true;
-}
-while(node&&node.tagName.toUpperCase()!="BODY"){
-node=node.parentNode;
-if(node===_178){
-return true;
-}
-}
-return false;
-},setNodeAttribute:function(node,attr,_17c){
-var o={};
-o[attr]=_17c;
-try{
-return MochiKit.DOM.updateNodeAttributes(node,o);
-}
-catch(e){
-}
-return null;
-},getNodeAttribute:function(node,attr){
-var self=MochiKit.DOM;
-var _181=self.attributeArray.renames[attr];
-node=self.getElement(node);
-try{
-if(_181){
-return node[_181];
-}
-return node.getAttribute(attr);
-}
-catch(e){
-}
-return null;
-},removeNodeAttribute:function(node,attr){
-var self=MochiKit.DOM;
-var _185=self.attributeArray.renames[attr];
-node=self.getElement(node);
-try{
-if(_185){
-return node[_185];
-}
-return node.removeAttribute(attr);
-}
-catch(e){
-}
-return null;
-},updateNodeAttributes:function(node,_187){
-var elem=node;
-var self=MochiKit.DOM;
-if(typeof (node)=="string"){
-elem=self.getElement(node);
-}
-if(_187){
-var _18a=MochiKit.Base.updatetree;
-if(self.attributeArray.compliant){
-for(var k in _187){
-var v=_187[k];
-if(typeof (v)=="object"&&typeof (elem[k])=="object"){
-if(k=="style"&&MochiKit.Style){
-MochiKit.Style.setStyle(elem,v);
-}else{
-_18a(elem[k],v);
-}
-}else{
-if(k.substring(0,2)=="on"){
-if(typeof (v)=="string"){
-v=new Function(v);
-}
-elem[k]=v;
-}else{
-elem.setAttribute(k,v);
-}
-}
-}
-}else{
-var _18d=self.attributeArray.renames;
-for(var k in _187){
-v=_187[k];
-var _18e=_18d[k];
-if(k=="style"&&typeof (v)=="string"){
-elem.style.cssText=v;
-}else{
-if(typeof (_18e)=="string"){
-elem[_18e]=v;
-}else{
-if(typeof (elem[k])=="object"&&typeof (v)=="object"){
-if(k=="style"&&MochiKit.Style){
-MochiKit.Style.setStyle(elem,v);
-}else{
-_18a(elem[k],v);
-}
-}else{
-if(k.substring(0,2)=="on"){
-if(typeof (v)=="string"){
-v=new Function(v);
-}
-elem[k]=v;
-}else{
-elem.setAttribute(k,v);
-}
-}
-}
-}
-}
-}
-}
-return elem;
-},appendChildNodes:function(node){
-var elem=node;
-var self=MochiKit.DOM;
-if(typeof (node)=="string"){
-elem=self.getElement(node);
-}
-var _192=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)];
-var _193=MochiKit.Base.concat;
-while(_192.length){
-var n=_192.shift();
-if(typeof (n)=="undefined"||n===null){
-}else{
-if(typeof (n.nodeType)=="number"){
-elem.appendChild(n);
-}else{
-_192=_193(n,_192);
-}
-}
-}
-return elem;
-},insertSiblingNodesBefore:function(node){
-var elem=node;
-var self=MochiKit.DOM;
-if(typeof (node)=="string"){
-elem=self.getElement(node);
-}
-var _198=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)];
-var _199=elem.parentNode;
-var _19a=MochiKit.Base.concat;
-while(_198.length){
-var n=_198.shift();
-if(typeof (n)=="undefined"||n===null){
-}else{
-if(typeof (n.nodeType)=="number"){
-_199.insertBefore(n,elem);
-}else{
-_198=_19a(n,_198);
-}
-}
-}
-return _199;
-},insertSiblingNodesAfter:function(node){
-var elem=node;
-var self=MochiKit.DOM;
-if(typeof (node)=="string"){
-elem=self.getElement(node);
-}
-var _19f=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)];
-if(elem.nextSibling){
-return self.insertSiblingNodesBefore(elem.nextSibling,_19f);
-}else{
-return self.appendChildNodes(elem.parentNode,_19f);
-}
-},replaceChildNodes:function(node){
-var elem=node;
-var self=MochiKit.DOM;
-if(typeof (node)=="string"){
-elem=self.getElement(node);
-arguments[0]=elem;
-}
-var _1a3;
-while((_1a3=elem.firstChild)){
-elem.removeChild(_1a3);
-}
-if(arguments.length<2){
-return elem;
-}else{
-return self.appendChildNodes.apply(this,arguments);
-}
-},createDOM:function(name,_1a5){
-var elem;
-var self=MochiKit.DOM;
-var m=MochiKit.Base;
-if(typeof (_1a5)=="string"||typeof (_1a5)=="number"){
-var args=m.extend([name,null],arguments,1);
-return arguments.callee.apply(this,args);
-}
-if(typeof (name)=="string"){
-var _1aa=self._xhtml;
-if(_1a5&&!self.attributeArray.compliant){
-var _1ab="";
-if("name" in _1a5){
-_1ab+=" name=\""+self.escapeHTML(_1a5.name)+"\"";
-}
-if(name=="input"&&"type" in _1a5){
-_1ab+=" type=\""+self.escapeHTML(_1a5.type)+"\"";
-}
-if(_1ab){
-name="<"+name+_1ab+">";
-_1aa=false;
-}
-}
-var d=self._document;
-if(_1aa&&d===document){
-elem=d.createElementNS("http://www.w3.org/1999/xhtml",name);
-}else{
-elem=d.createElement(name);
-}
-}else{
-elem=name;
-}
-if(_1a5){
-self.updateNodeAttributes(elem,_1a5);
-}
-if(arguments.length<=2){
-return elem;
-}else{
-var args=m.extend([elem],arguments,2);
-return self.appendChildNodes.apply(this,args);
-}
-},createDOMFunc:function(){
-var m=MochiKit.Base;
-return m.partial.apply(this,m.extend([MochiKit.DOM.createDOM],arguments));
-},removeElement:function(elem){
-var e=MochiKit.DOM.getElement(elem);
-e.parentNode.removeChild(e);
-return e;
-},swapDOM:function(dest,src){
-var self=MochiKit.DOM;
-dest=self.getElement(dest);
-var _1b3=dest.parentNode;
-if(src){
-src=self.getElement(src);
-_1b3.replaceChild(src,dest);
-}else{
-_1b3.removeChild(dest);
-}
-return src;
-},getElement:function(id){
-var self=MochiKit.DOM;
-if(arguments.length==1){
-return ((typeof (id)=="string")?self._document.getElementById(id):id);
-}else{
-return MochiKit.Base.map(self.getElement,arguments);
-}
-},getElementsByTagAndClassName:function(_1b6,_1b7,_1b8){
-var self=MochiKit.DOM;
-if(typeof (_1b6)=="undefined"||_1b6===null){
-_1b6="*";
-}
-if(typeof (_1b8)=="undefined"||_1b8===null){
-_1b8=self._document;
-}
-_1b8=self.getElement(_1b8);
-var _1ba=(_1b8.getElementsByTagName(_1b6)||self._document.all);
-if(typeof (_1b7)=="undefined"||_1b7===null){
-return MochiKit.Base.extend(null,_1ba);
-}
-var _1bb=[];
-for(var i=0;i<_1ba.length;i++){
-var _1bd=_1ba[i];
-var cls=_1bd.className;
-if(!cls){
-continue;
-}
-var _1bf=cls.split(" ");
-for(var j=0;j<_1bf.length;j++){
-if(_1bf[j]==_1b7){
-_1bb.push(_1bd);
-break;
-}
-}
-}
-return _1bb;
-},_newCallStack:function(path,once){
-var rval=function(){
-var _1c4=arguments.callee.callStack;
-for(var i=0;i<_1c4.length;i++){
-if(_1c4[i].apply(this,arguments)===false){
-break;
-}
-}
-if(once){
-try{
-this[path]=null;
-}
-catch(e){
-}
-}
-};
-rval.callStack=[];
-return rval;
-},addToCallStack:function(_1c6,path,func,once){
-var self=MochiKit.DOM;
-var _1cb=_1c6[path];
-var _1cc=_1cb;
-if(!(typeof (_1cb)=="function"&&typeof (_1cb.callStack)=="object"&&_1cb.callStack!==null)){
-_1cc=self._newCallStack(path,once);
-if(typeof (_1cb)=="function"){
-_1cc.callStack.push(_1cb);
-}
-_1c6[path]=_1cc;
-}
-_1cc.callStack.push(func);
-},addLoadEvent:function(func){
-var self=MochiKit.DOM;
-self.addToCallStack(self._window,"onload",func,true);
-},focusOnLoad:function(_1cf){
-var self=MochiKit.DOM;
-self.addLoadEvent(function(){
-_1cf=self.getElement(_1cf);
-if(_1cf){
-_1cf.focus();
-}
-});
-},setElementClass:function(_1d1,_1d2){
-var self=MochiKit.DOM;
-var obj=self.getElement(_1d1);
-if(self.attributeArray.compliant){
-obj.setAttribute("class",_1d2);
-}else{
-obj.setAttribute("className",_1d2);
-}
-},toggleElementClass:function(_1d5){
-var self=MochiKit.DOM;
-for(var i=1;i<arguments.length;i++){
-var obj=self.getElement(arguments[i]);
-if(!self.addElementClass(obj,_1d5)){
-self.removeElementClass(obj,_1d5);
-}
-}
-},addElementClass:function(_1d9,_1da){
-var self=MochiKit.DOM;
-var obj=self.getElement(_1d9);
-var cls=obj.className;
-if(cls==undefined||cls.length===0){
-self.setElementClass(obj,_1da);
-return true;
-}
-if(cls==_1da){
-return false;
-}
-var _1de=cls.split(" ");
-for(var i=0;i<_1de.length;i++){
-if(_1de[i]==_1da){
-return false;
-}
-}
-self.setElementClass(obj,cls+" "+_1da);
-return true;
-},removeElementClass:function(_1e0,_1e1){
-var self=MochiKit.DOM;
-var obj=self.getElement(_1e0);
-var cls=obj.className;
-if(cls==undefined||cls.length===0){
-return false;
-}
-if(cls==_1e1){
-self.setElementClass(obj,"");
-return true;
-}
-var _1e5=cls.split(" ");
-for(var i=0;i<_1e5.length;i++){
-if(_1e5[i]==_1e1){
-_1e5.splice(i,1);
-self.setElementClass(obj,_1e5.join(" "));
-return true;
-}
-}
-return false;
-},swapElementClass:function(_1e7,_1e8,_1e9){
-var obj=MochiKit.DOM.getElement(_1e7);
-var res=MochiKit.DOM.removeElementClass(obj,_1e8);
-if(res){
-MochiKit.DOM.addElementClass(obj,_1e9);
-}
-return res;
-},hasElementClass:function(_1ec,_1ed){
-var obj=MochiKit.DOM.getElement(_1ec);
-var cls=obj.className;
-if(!cls){
-return false;
-}
-var _1f0=cls.split(" ");
-for(var i=1;i<arguments.length;i++){
-var good=false;
-for(var j=0;j<_1f0.length;j++){
-if(_1f0[j]==arguments[i]){
-good=true;
-break;
-}
-}
-if(!good){
-return false;
-}
-}
-return true;
-},escapeHTML:function(s){
-return s.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/</g,"&lt;").replace(/>/g,"&gt;");
-},toHTML:function(dom){
-return MochiKit.DOM.emitHTML(dom).join("");
-},emitHTML:function(dom,lst){
-if(typeof (lst)=="undefined"||lst===null){
-lst=[];
-}
-var _1f8=[dom];
-var self=MochiKit.DOM;
-var _1fa=self.escapeHTML;
-var _1fb=self.attributeArray;
-while(_1f8.length){
-dom=_1f8.pop();
-if(typeof (dom)=="string"){
-lst.push(dom);
-}else{
-if(dom.nodeType==1){
-lst.push("<"+dom.tagName.toLowerCase());
-var _1fc=[];
-var _1fd=_1fb(dom);
-for(var i=0;i<_1fd.length;i++){
-var a=_1fd[i];
-_1fc.push([" ",a.name,"=\"",_1fa(a.value),"\""]);
-}
-_1fc.sort();
-for(i=0;i<_1fc.length;i++){
-var _200=_1fc[i];
-for(var j=0;j<_200.length;j++){
-lst.push(_200[j]);
-}
-}
-if(dom.hasChildNodes()){
-lst.push(">");
-_1f8.push("</"+dom.tagName.toLowerCase()+">");
-var _202=dom.childNodes;
-for(i=_202.length-1;i>=0;i--){
-_1f8.push(_202[i]);
-}
-}else{
-lst.push("/>");
-}
-}else{
-if(dom.nodeType==3){
-lst.push(_1fa(dom.nodeValue));
-}
-}
-}
-}
-return lst;
-},scrapeText:function(node,_204){
-var rval=[];
-(function(node){
-var cn=node.childNodes;
-if(cn){
-for(var i=0;i<cn.length;i++){
-arguments.callee.call(this,cn[i]);
-}
-}
-var _209=node.nodeValue;
-if(typeof (_209)=="string"){
-rval.push(_209);
-}
-})(MochiKit.DOM.getElement(node));
-if(_204){
-return rval;
-}else{
-return rval.join("");
-}
-},removeEmptyTextNodes:function(_20a){
-_20a=MochiKit.DOM.getElement(_20a);
-for(var i=0;i<_20a.childNodes.length;i++){
-var node=_20a.childNodes[i];
-if(node.nodeType==3&&!/\S/.test(node.nodeValue)){
-node.parentNode.removeChild(node);
-}
-}
-},makeClipping:function(_20d){
-_20d=MochiKit.DOM.getElement(_20d);
-var _20e=_20d.style.overflow;
-if((MochiKit.Style.getStyle(_20d,"overflow")||"visible")!="hidden"){
-_20d.style.overflow="hidden";
-}
-return _20e;
-},undoClipping:function(_20f,_210){
-_20f=MochiKit.DOM.getElement(_20f);
-if(!_210){
-return;
-}
-_20f.style.overflow=_210;
-},makePositioned:function(_211){
-_211=MochiKit.DOM.getElement(_211);
-var pos=MochiKit.Style.getStyle(_211,"position");
-if(pos=="static"||!pos){
-_211.style.position="relative";
-if(/Opera/.test(navigator.userAgent)){
-_211.style.top=0;
-_211.style.left=0;
-}
-}
-},undoPositioned:function(_213){
-_213=MochiKit.DOM.getElement(_213);
-if(_213.style.position=="relative"){
-_213.style.position=_213.style.top=_213.style.left=_213.style.bottom=_213.style.right="";
-}
-},getFirstElementByTagAndClassName:function(_214,_215,_216){
-var self=MochiKit.DOM;
-if(typeof (_214)=="undefined"||_214===null){
-_214="*";
-}
-if(typeof (_216)=="undefined"||_216===null){
-_216=self._document;
-}
-_216=self.getElement(_216);
-var _218=(_216.getElementsByTagName(_214)||self._document.all);
-if(typeof (_215)=="undefined"||_215===null){
-return _218[0];
-}
-for(var i=0;i<_218.length;i++){
-var _21a=_218[i];
-var _21b=_21a.className.split(" ");
-for(var j=0;j<_21b.length;j++){
-if(_21b[j]==_215){
-return _21a;
-}
-}
-}
-},getFirstParentByTagAndClassName:function(elem,_21e,_21f){
-var self=MochiKit.DOM;
-elem=self.getElement(elem);
-if(typeof (_21e)=="undefined"||_21e===null){
-_21e="*";
-}else{
-_21e=_21e.toUpperCase();
-}
-if(typeof (_21f)=="undefined"||_21f===null){
-_21f=null;
-}
-var _221="";
-var _222="";
-while(elem&&elem.tagName){
-elem=elem.parentNode;
-if(_21e=="*"&&_21f===null){
-return elem;
-}
-_221=elem.className.split(" ");
-_222=elem.tagName.toUpperCase();
-if(_21f===null&&_21e==_222){
-return elem;
-}else{
-if(_21f!==null){
-for(var i=0;i<_221.length;i++){
-if(_21e=="*"&&_221[i]==_21f){
-return elem;
-}else{
-if(_21e==_222&&_221[i]==_21f){
-return elem;
-}
-}
-}
-}
-}
-}
-return elem;
-},isParent:function(_224,_225){
-if(!_224.parentNode||_224==_225){
-return false;
-}
-if(_224.parentNode==_225){
-return true;
-}
-return MochiKit.DOM.isParent(_224.parentNode,_225);
-},__new__:function(win){
-var m=MochiKit.Base;
-if(typeof (document)!="undefined"){
-this._document=document;
-var _228="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
-this._xhtml=(document.documentElement&&document.createElementNS&&document.documentElement.namespaceURI===_228);
-}else{
-if(MochiKit.MockDOM){
-this._document=MochiKit.MockDOM.document;
-}
-}
-this._window=win;
-this.domConverters=new m.AdapterRegistry();
-var _229=this._document.createElement("span");
-var _22a;
-if(_229&&_229.attributes&&_229.attributes.length>0){
-var _22b=m.filter;
-_22a=function(node){
-return _22b(_22a.ignoreAttrFilter,node.attributes);
-};
-_22a.ignoreAttr={};
-var _22d=_229.attributes;
-var _22e=_22a.ignoreAttr;
-for(var i=0;i<_22d.length;i++){
-var a=_22d[i];
-_22e[a.name]=a.value;
-}
-_22a.ignoreAttrFilter=function(a){
-return (_22a.ignoreAttr[a.name]!=a.value);
-};
-_22a.compliant=false;
-_22a.renames={"class":"className","checked":"defaultChecked","usemap":"useMap","for":"htmlFor","readonly":"readOnly","colspan":"colSpan","bgcolor":"bgColor","cellspacing":"cellSpacing","cellpadding":"cellPadding"};
-}else{
-_22a=function(node){
-return node.attributes;
-};
-_22a.compliant=true;
-_22a.renames={};
-}
-this.attributeArray=_22a;
-var _233=function(_234,arr){
-var _236=arr[1].split(".");
-var str="";
-var obj={};
-str+="if (!MochiKit."+_236[1]+") { throw new Error(\"";
-str+="This function has been deprecated and depends on MochiKit.";
-str+=_236[1]+".\");}";
-str+="return MochiKit."+_236[1]+"."+arr[0];
-str+=".apply(this, arguments);";
-obj[_236[2]]=new Function(str);
-MochiKit.Base.update(MochiKit[_234],obj);
-};
-for(var i;i<MochiKit.DOM.DEPRECATED.length;i++){
-_233("DOM",MochiKit.DOM.DEPRECATED[i]);
-}
-var _239=this.createDOMFunc;
-this.UL=_239("ul");
-this.OL=_239("ol");
-this.LI=_239("li");
-this.TD=_239("td");
-this.TR=_239("tr");
-this.TBODY=_239("tbody");
-this.THEAD=_239("thead");
-this.TFOOT=_239("tfoot");
-this.TABLE=_239("table");
-this.TH=_239("th");
-this.INPUT=_239("input");
-this.SPAN=_239("span");
-this.A=_239("a");
-this.DIV=_239("div");
-this.IMG=_239("img");
-this.BUTTON=_239("button");
-this.TT=_239("tt");
-this.PRE=_239("pre");
-this.H1=_239("h1");
-this.H2=_239("h2");
-this.H3=_239("h3");
-this.BR=_239("br");
-this.HR=_239("hr");
-this.LABEL=_239("label");
-this.TEXTAREA=_239("textarea");
-this.FORM=_239("form");
-this.P=_239("p");
-this.SELECT=_239("select");
-this.OPTION=_239("option");
-this.OPTGROUP=_239("optgroup");
-this.LEGEND=_239("legend");
-this.FIELDSET=_239("fieldset");
-this.STRONG=_239("strong");
-this.CANVAS=_239("canvas");
-this.$=this.getElement;
-this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)};
-m.nameFunctions(this);
-}});
-MochiKit.DOM.__new__(((typeof (window)=="undefined")?this:window));
-if(MochiKit.__export__){
-withWindow=MochiKit.DOM.withWindow;
-withDocument=MochiKit.DOM.withDocument;
-}
-MochiKit.Base._exportSymbols(this,MochiKit.DOM);
-if(typeof (dojo)!="undefined"){
-dojo.provide("MochiKit.Style");
-dojo.require("MochiKit.Base");
-dojo.require("MochiKit.DOM");
-}
-if(typeof (JSAN)!="undefined"){
-JSAN.use("MochiKit.Base",[]);
-JSAN.use("MochiKit.DOM",[]);
-}
-try{
-if(typeof (MochiKit.Base)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Style depends on MochiKit.Base!";
-}
-try{
-if(typeof (MochiKit.DOM)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Style depends on MochiKit.DOM!";
-}
-if(typeof (MochiKit.Style)=="undefined"){
-MochiKit.Style={};
-}
-MochiKit.Style.NAME="MochiKit.Style";
-MochiKit.Style.VERSION="1.4";
-MochiKit.Style.__repr__=function(){
-return "["+this.NAME+" "+this.VERSION+"]";
-};
-MochiKit.Style.toString=function(){
-return this.__repr__();
-};
-MochiKit.Style.EXPORT_OK=[];
-MochiKit.Style.EXPORT=["setStyle","setOpacity","getStyle","getElementDimensions","elementDimensions","setElementDimensions","getElementPosition","elementPosition","setElementPosition","setDisplayForElement","hideElement","showElement","getViewportDimensions","getViewportPosition","Dimensions","Coordinates"];
-MochiKit.Style.Dimensions=function(w,h){
-this.w=w;
-this.h=h;
-};
-MochiKit.Style.Dimensions.prototype.__repr__=function(){
-var repr=MochiKit.Base.repr;
-return "{w: "+repr(this.w)+", h: "+repr(this.h)+"}";
-};
-MochiKit.Style.Dimensions.prototype.toString=function(){
-return this.__repr__();
-};
-MochiKit.Style.Coordinates=function(x,y){
-this.x=x;
-this.y=y;
-};
-MochiKit.Style.Coordinates.prototype.__repr__=function(){
-var repr=MochiKit.Base.repr;
-return "{x: "+repr(this.x)+", y: "+repr(this.y)+"}";
-};
-MochiKit.Style.Coordinates.prototype.toString=function(){
-return this.__repr__();
-};
-MochiKit.Base.update(MochiKit.Style,{getStyle:function(elem,_241){
-var dom=MochiKit.DOM;
-var d=dom._document;
-elem=dom.getElement(elem);
-_241=MochiKit.Base.camelize(_241);
-if(!elem||elem==d){
-return undefined;
-}
-if(_241=="opacity"&&elem.filters){
-var _244=(MochiKit.Style.getStyle(elem,"filter")||"").match(/alpha\(opacity=(.*)\)/);
-if(_244&&_244[1]){
-return parseFloat(_244[1])/100;
-}
-return 1;
-}
-var _245=elem.style?elem.style[_241]:null;
-if(!_245){
-if(d.defaultView&&d.defaultView.getComputedStyle){
-var css=d.defaultView.getComputedStyle(elem,null);
-_241=_241.replace(/([A-Z])/g,"-$1").toLowerCase();
-_245=css?css.getPropertyValue(_241):null;
-}else{
-if(elem.currentStyle){
-_245=elem.currentStyle[_241];
-}
-}
-}
-if(_241=="opacity"){
-_245=parseFloat(_245);
-}
-if(/Opera/.test(navigator.userAgent)&&(MochiKit.Base.find(["left","top","right","bottom"],_241)!=-1)){
-if(MochiKit.Style.getStyle(elem,"position")=="static"){
-_245="auto";
-}
-}
-return _245=="auto"?null:_245;
-},setStyle:function(elem,_248){
-elem=MochiKit.DOM.getElement(elem);
-for(var name in _248){
-if(name=="opacity"){
-MochiKit.Style.setOpacity(elem,_248[name]);
-}else{
-elem.style[MochiKit.Base.camelize(name)]=_248[name];
-}
-}
-},setOpacity:function(elem,o){
-elem=MochiKit.DOM.getElement(elem);
-var self=MochiKit.Style;
-if(o==1){
-var _24d=/Gecko/.test(navigator.userAgent)&&!(/Konqueror|AppleWebKit|KHTML/.test(navigator.userAgent));
-elem.style["opacity"]=_24d?0.999999:1;
-if(/MSIE/.test(navigator.userAgent)){
-elem.style["filter"]=self.getStyle(elem,"filter").replace(/alpha\([^\)]*\)/gi,"");
-}
-}else{
-if(o<0.00001){
-o=0;
-}
-elem.style["opacity"]=o;
-if(/MSIE/.test(navigator.userAgent)){
-elem.style["filter"]=self.getStyle(elem,"filter").replace(/alpha\([^\)]*\)/gi,"")+"alpha(opacity="+o*100+")";
-}
-}
-},getElementPosition:function(elem,_24f){
-var self=MochiKit.Style;
-var dom=MochiKit.DOM;
-elem=dom.getElement(elem);
-if(!elem||(!(elem.x&&elem.y)&&(!elem.parentNode===null||self.getStyle(elem,"display")=="none"))){
-return undefined;
-}
-var c=new self.Coordinates(0,0);
-var box=null;
-var _254=null;
-var d=MochiKit.DOM._document;
-var de=d.documentElement;
-var b=d.body;
-if(!elem.parentNode&&elem.x&&elem.y){
-c.x+=elem.x||0;
-c.y+=elem.y||0;
-}else{
-if(elem.getBoundingClientRect){
-box=elem.getBoundingClientRect();
-c.x+=box.left+(de.scrollLeft||b.scrollLeft)-(de.clientLeft||0);
-c.y+=box.top+(de.scrollTop||b.scrollTop)-(de.clientTop||0);
-}else{
-if(elem.offsetParent){
-c.x+=elem.offsetLeft;
-c.y+=elem.offsetTop;
-_254=elem.offsetParent;
-if(_254!=elem){
-while(_254){
-c.x+=_254.offsetLeft;
-c.y+=_254.offsetTop;
-_254=_254.offsetParent;
-}
-}
-var ua=navigator.userAgent.toLowerCase();
-if((typeof (opera)!="undefined"&&parseFloat(opera.version())<9)||(ua.indexOf("AppleWebKit")!=-1&&self.getStyle(elem,"position")=="absolute")){
-c.x-=b.offsetLeft;
-c.y-=b.offsetTop;
-}
-}
-}
-}
-if(typeof (_24f)!="undefined"){
-_24f=arguments.callee(_24f);
-if(_24f){
-c.x-=(_24f.x||0);
-c.y-=(_24f.y||0);
-}
-}
-if(elem.parentNode){
-_254=elem.parentNode;
-}else{
-_254=null;
-}
-while(_254){
-var _259=_254.tagName.toUpperCase();
-if(_259==="BODY"||_259==="HTML"){
-break;
-}
-var disp=self.getStyle(_254,"display");
-if(disp!="inline"&&disp!="table-row"){
-c.x-=_254.scrollLeft;
-c.y-=_254.scrollTop;
-}
-if(_254.parentNode){
-_254=_254.parentNode;
-}else{
-_254=null;
-}
-}
-return c;
-},setElementPosition:function(elem,_25c,_25d){
-elem=MochiKit.DOM.getElement(elem);
-if(typeof (_25d)=="undefined"){
-_25d="px";
-}
-var _25e={};
-var _25f=MochiKit.Base.isUndefinedOrNull;
-if(!_25f(_25c.x)){
-_25e["left"]=_25c.x+_25d;
-}
-if(!_25f(_25c.y)){
-_25e["top"]=_25c.y+_25d;
-}
-MochiKit.DOM.updateNodeAttributes(elem,{"style":_25e});
-},getElementDimensions:function(elem){
-var self=MochiKit.Style;
-var dom=MochiKit.DOM;
-if(typeof (elem.w)=="number"||typeof (elem.h)=="number"){
-return new self.Dimensions(elem.w||0,elem.h||0);
-}
-elem=dom.getElement(elem);
-if(!elem){
-return undefined;
-}
-var disp=self.getStyle(elem,"display");
-if(disp!="none"&&disp!==""&&typeof (disp)!="undefined"){
-return new self.Dimensions(elem.offsetWidth||0,elem.offsetHeight||0);
-}
-var s=elem.style;
-var _265=s.visibility;
-var _266=s.position;
-s.visibility="hidden";
-s.position="absolute";
-s.display="";
-var _267=elem.offsetWidth;
-var _268=elem.offsetHeight;
-s.display="none";
-s.position=_266;
-s.visibility=_265;
-return new self.Dimensions(_267,_268);
-},setElementDimensions:function(elem,_26a,_26b){
-elem=MochiKit.DOM.getElement(elem);
-if(typeof (_26b)=="undefined"){
-_26b="px";
-}
-var _26c={};
-var _26d=MochiKit.Base.isUndefinedOrNull;
-if(!_26d(_26a.w)){
-_26c["width"]=_26a.w+_26b;
-}
-if(!_26d(_26a.h)){
-_26c["height"]=_26a.h+_26b;
-}
-MochiKit.DOM.updateNodeAttributes(elem,{"style":_26c});
-},setDisplayForElement:function(_26e,_26f){
-var _270=MochiKit.Base.extend(null,arguments,1);
-var _271=MochiKit.DOM.getElement;
-for(var i=0;i<_270.length;i++){
-_26f=_271(_270[i]);
-if(_26f){
-_26f.style.display=_26e;
-}
-}
-},getViewportDimensions:function(){
-var d=new MochiKit.Style.Dimensions();
-var w=MochiKit.DOM._window;
-var b=MochiKit.DOM._document.body;
-if(w.innerWidth){
-d.w=w.innerWidth;
-d.h=w.innerHeight;
-}else{
-if(b.parentElement.clientWidth){
-d.w=b.parentElement.clientWidth;
-d.h=b.parentElement.clientHeight;
-}else{
-if(b&&b.clientWidth){
-d.w=b.clientWidth;
-d.h=b.clientHeight;
-}
-}
-}
-return d;
-},getViewportPosition:function(){
-var c=new MochiKit.Style.Coordinates(0,0);
-var d=MochiKit.DOM._document;
-var de=d.documentElement;
-var db=d.body;
-if(de&&(de.scrollTop||de.scrollLeft)){
-c.x=de.scrollLeft;
-c.y=de.scrollTop;
-}else{
-if(db){
-c.x=db.scrollLeft;
-c.y=db.scrollTop;
-}
-}
-return c;
-},__new__:function(){
-var m=MochiKit.Base;
-this.elementPosition=this.getElementPosition;
-this.elementDimensions=this.getElementDimensions;
-this.hideElement=m.partial(this.setDisplayForElement,"none");
-this.showElement=m.partial(this.setDisplayForElement,"block");
-this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)};
-m.nameFunctions(this);
-}});
-MochiKit.Style.__new__();
-MochiKit.Base._exportSymbols(this,MochiKit.Style);
-if(typeof (dojo)!="undefined"){
-dojo.provide("MochiKit.Signal");
-dojo.require("MochiKit.Base");
-dojo.require("MochiKit.DOM");
-dojo.require("MochiKit.Style");
-}
-if(typeof (JSAN)!="undefined"){
-JSAN.use("MochiKit.Base",[]);
-JSAN.use("MochiKit.DOM",[]);
-JSAN.use("MochiKit.Style",[]);
-}
-try{
-if(typeof (MochiKit.Base)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Signal depends on MochiKit.Base!";
-}
-try{
-if(typeof (MochiKit.DOM)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Signal depends on MochiKit.DOM!";
-}
-try{
-if(typeof (MochiKit.Style)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Signal depends on MochiKit.Style!";
-}
-if(typeof (MochiKit.Signal)=="undefined"){
-MochiKit.Signal={};
-}
-MochiKit.Signal.NAME="MochiKit.Signal";
-MochiKit.Signal.VERSION="1.4";
-MochiKit.Signal._observers=[];
-MochiKit.Signal.Event=function(src,e){
-this._event=e||window.event;
-this._src=src;
-};
-MochiKit.Base.update(MochiKit.Signal.Event.prototype,{__repr__:function(){
-var repr=MochiKit.Base.repr;
-var str="{event(): "+repr(this.event())+", src(): "+repr(this.src())+", type(): "+repr(this.type())+", target(): "+repr(this.target());
-if(this.type()&&this.type().indexOf("key")===0||this.type().indexOf("mouse")===0||this.type().indexOf("click")!=-1||this.type()=="contextmenu"){
-str+=", modifier(): "+"{alt: "+repr(this.modifier().alt)+", ctrl: "+repr(this.modifier().ctrl)+", meta: "+repr(this.modifier().meta)+", shift: "+repr(this.modifier().shift)+", any: "+repr(this.modifier().any)+"}";
-}
-if(this.type()&&this.type().indexOf("key")===0){
-str+=", key(): {code: "+repr(this.key().code)+", string: "+repr(this.key().string)+"}";
-}
-if(this.type()&&(this.type().indexOf("mouse")===0||this.type().indexOf("click")!=-1||this.type()=="contextmenu")){
-str+=", mouse(): {page: "+repr(this.mouse().page)+", client: "+repr(this.mouse().client);
-if(this.type()!="mousemove"){
-str+=", button: {left: "+repr(this.mouse().button.left)+", middle: "+repr(this.mouse().button.middle)+", right: "+repr(this.mouse().button.right)+"}}";
-}else{
-str+="}";
-}
-}
-if(this.type()=="mouseover"||this.type()=="mouseout"){
-str+=", relatedTarget(): "+repr(this.relatedTarget());
-}
-str+="}";
-return str;
-},toString:function(){
-return this.__repr__();
-},src:function(){
-return this._src;
-},event:function(){
-return this._event;
-},type:function(){
-return this._event.type||undefined;
-},target:function(){
-return this._event.target||this._event.srcElement;
-},_relatedTarget:null,relatedTarget:function(){
-if(this._relatedTarget!==null){
-return this._relatedTarget;
-}
-var elem=null;
-if(this.type()=="mouseover"){
-elem=(this._event.relatedTarget||this._event.fromElement);
-}else{
-if(this.type()=="mouseout"){
-elem=(this._event.relatedTarget||this._event.toElement);
-}
-}
-if(elem!==null){
-this._relatedTarget=elem;
-return elem;
-}
-return undefined;
-},_modifier:null,modifier:function(){
-if(this._modifier!==null){
-return this._modifier;
-}
-var m={};
-m.alt=this._event.altKey;
-m.ctrl=this._event.ctrlKey;
-m.meta=this._event.metaKey||false;
-m.shift=this._event.shiftKey;
-m.any=m.alt||m.ctrl||m.shift||m.meta;
-this._modifier=m;
-return m;
-},_key:null,key:function(){
-if(this._key!==null){
-return this._key;
-}
-var k={};
-if(this.type()&&this.type().indexOf("key")===0){
-if(this.type()=="keydown"||this.type()=="keyup"){
-k.code=this._event.keyCode;
-k.string=(MochiKit.Signal._specialKeys[k.code]||"KEY_UNKNOWN");
-this._key=k;
-return k;
-}else{
-if(this.type()=="keypress"){
-k.code=0;
-k.string="";
-if(typeof (this._event.charCode)!="undefined"&&this._event.charCode!==0&&!MochiKit.Signal._specialMacKeys[this._event.charCode]){
-k.code=this._event.charCode;
-k.string=String.fromCharCode(k.code);
-}else{
-if(this._event.keyCode&&typeof (this._event.charCode)=="undefined"){
-k.code=this._event.keyCode;
-k.string=String.fromCharCode(k.code);
-}
-}
-this._key=k;
-return k;
-}
-}
-}
-return undefined;
-},_mouse:null,mouse:function(){
-if(this._mouse!==null){
-return this._mouse;
-}
-var m={};
-var e=this._event;
-if(this.type()&&(this.type().indexOf("mouse")===0||this.type().indexOf("click")!=-1||this.type()=="contextmenu")){
-m.client=new MochiKit.Style.Coordinates(0,0);
-if(e.clientX||e.clientY){
-m.client.x=(!e.clientX||e.clientX<0)?0:e.clientX;
-m.client.y=(!e.clientY||e.clientY<0)?0:e.clientY;
-}
-m.page=new MochiKit.Style.Coordinates(0,0);
-if(e.pageX||e.pageY){
-m.page.x=(!e.pageX||e.pageX<0)?0:e.pageX;
-m.page.y=(!e.pageY||e.pageY<0)?0:e.pageY;
-}else{
-var de=MochiKit.DOM._document.documentElement;
-var b=MochiKit.DOM._document.body;
-m.page.x=e.clientX+(de.scrollLeft||b.scrollLeft)-(de.clientLeft||0);
-m.page.y=e.clientY+(de.scrollTop||b.scrollTop)-(de.clientTop||0);
-}
-if(this.type()!="mousemove"){
-m.button={};
-m.button.left=false;
-m.button.right=false;
-m.button.middle=false;
-if(e.which){
-m.button.left=(e.which==1);
-m.button.middle=(e.which==2);
-m.button.right=(e.which==3);
-}else{
-m.button.left=!!(e.button&1);
-m.button.right=!!(e.button&2);
-m.button.middle=!!(e.button&4);
-}
-}
-this._mouse=m;
-return m;
-}
-return undefined;
-},stop:function(){
-this.stopPropagation();
-this.preventDefault();
-},stopPropagation:function(){
-if(this._event.stopPropagation){
-this._event.stopPropagation();
-}else{
-this._event.cancelBubble=true;
-}
-},preventDefault:function(){
-if(this._event.preventDefault){
-this._event.preventDefault();
-}else{
-if(this._confirmUnload===null){
-this._event.returnValue=false;
-}
-}
-},_confirmUnload:null,confirmUnload:function(msg){
-if(this.type()=="beforeunload"){
-this._confirmUnload=msg;
-this._event.returnValue=msg;
-}
-}});
-MochiKit.Signal._specialMacKeys={3:"KEY_ENTER",63289:"KEY_NUM_PAD_CLEAR",63276:"KEY_PAGE_UP",63277:"KEY_PAGE_DOWN",63275:"KEY_END",63273:"KEY_HOME",63234:"KEY_ARROW_LEFT",63232:"KEY_ARROW_UP",63235:"KEY_ARROW_RIGHT",63233:"KEY_ARROW_DOWN",63302:"KEY_INSERT",63272:"KEY_DELETE"};
-(function(){
-var _287=MochiKit.Signal._specialMacKeys;
-for(i=63236;i<=63242;i++){
-_287[i]="KEY_F"+(i-63236+1);
-}
-})();
-MochiKit.Signal._specialKeys={8:"KEY_BACKSPACE",9:"KEY_TAB",12:"KEY_NUM_PAD_CLEAR",13:"KEY_ENTER",16:"KEY_SHIFT",17:"KEY_CTRL",18:"KEY_ALT",19:"KEY_PAUSE",20:"KEY_CAPS_LOCK",27:"KEY_ESCAPE",32:"KEY_SPACEBAR",33:"KEY_PAGE_UP",34:"KEY_PAGE_DOWN",35:"KEY_END",36:"KEY_HOME",37:"KEY_ARROW_LEFT",38:"KEY_ARROW_UP",39:"KEY_ARROW_RIGHT",40:"KEY_ARROW_DOWN",44:"KEY_PRINT_SCREEN",45:"KEY_INSERT",46:"KEY_DELETE",59:"KEY_SEMICOLON",91:"KEY_WINDOWS_LEFT",92:"KEY_WINDOWS_RIGHT",93:"KEY_SELECT",106:"KEY_NUM_PAD_ASTERISK",107:"KEY_NUM_PAD_PLUS_SIGN",109:"KEY_NUM_PAD_HYPHEN-MINUS",110:"KEY_NUM_PAD_FULL_STOP",111:"KEY_NUM_PAD_SOLIDUS",144:"KEY_NUM_LOCK",145:"KEY_SCROLL_LOCK",186:"KEY_SEMICOLON",187:"KEY_EQUALS_SIGN",188:"KEY_COMMA",189:"KEY_HYPHEN-MINUS",190:"KEY_FULL_STOP",191:"KEY_SOLIDUS",192:"KEY_GRAVE_ACCENT",219:"KEY_LEFT_SQUARE_BRACKET",220:"KEY_REVERSE_SOLIDUS",221:"KEY_RIGHT_SQUARE_BRACKET",222:"KEY_APOSTROPHE"};
-(function(){
-var _288=MochiKit.Signal._specialKeys;
-for(var i=48;i<=57;i++){
-_288[i]="KEY_"+(i-48);
-}
-for(i=65;i<=90;i++){
-_288[i]="KEY_"+String.fromCharCode(i);
-}
-for(i=96;i<=105;i++){
-_288[i]="KEY_NUM_PAD_"+(i-96);
-}
-for(i=112;i<=123;i++){
-_288[i]="KEY_F"+(i-112+1);
-}
-})();
-MochiKit.Signal.Ident=function(_28a){
-this.source=_28a.source;
-this.signal=_28a.signal;
-this.listener=_28a.listener;
-this.isDOM=_28a.isDOM;
-this.objOrFunc=_28a.objOrFunc;
-this.funcOrStr=_28a.funcOrStr;
-this.connected=_28a.connected;
-};
-MochiKit.Signal.Ident.prototype={};
-MochiKit.Base.update(MochiKit.Signal,{__repr__:function(){
-return "["+this.NAME+" "+this.VERSION+"]";
-},toString:function(){
-return this.__repr__();
-},_unloadCache:function(){
-var self=MochiKit.Signal;
-var _28c=self._observers;
-for(var i=0;i<_28c.length;i++){
-if(_28c[i].signal!=="onload"&&_28c[i].signal!=="onunload"){
-self._disconnect(_28c[i]);
-}
-}
-},_listener:function(src,sig,func,obj,_292){
-var self=MochiKit.Signal;
-var E=self.Event;
-if(!_292){
-return MochiKit.Base.bind(func,obj);
-}
-obj=obj||src;
-if(typeof (func)=="string"){
-if(sig==="onload"||sig==="onunload"){
-return function(_295){
-obj[func].apply(obj,[new E(src,_295)]);
-var _296=new MochiKit.Signal.Ident({source:src,signal:sig,objOrFunc:obj,funcOrStr:func});
-MochiKit.Signal._disconnect(_296);
-};
-}else{
-return function(_297){
-obj[func].apply(obj,[new E(src,_297)]);
-};
-}
-}else{
-if(sig==="onload"||sig==="onunload"){
-return function(_298){
-func.apply(obj,[new E(src,_298)]);
-MochiKit.Signal.disconnect(src,sig,func);
-var _299=new MochiKit.Signal.Ident({source:src,signal:sig,objOrFunc:func});
-MochiKit.Signal._disconnect(_299);
-};
-}else{
-return function(_29a){
-func.apply(obj,[new E(src,_29a)]);
-};
-}
-}
-},_browserAlreadyHasMouseEnterAndLeave:function(){
-return /MSIE/.test(navigator.userAgent);
-},_mouseEnterListener:function(src,sig,func,obj){
-var E=MochiKit.Signal.Event;
-return function(_2a0){
-var e=new E(src,_2a0);
-try{
-e.relatedTarget().nodeName;
-}
-catch(err){
-return;
-}
-e.stop();
-if(MochiKit.DOM.isChildNode(e.relatedTarget(),src)){
-return;
-}
-e.type=function(){
-return sig;
-};
-if(typeof (func)=="string"){
-return obj[func].apply(obj,[e]);
-}else{
-return func.apply(obj,[e]);
-}
-};
-},_getDestPair:function(_2a2,_2a3){
-var obj=null;
-var func=null;
-if(typeof (_2a3)!="undefined"){
-obj=_2a2;
-func=_2a3;
-if(typeof (_2a3)=="string"){
-if(typeof (_2a2[_2a3])!="function"){
-throw new Error("'funcOrStr' must be a function on 'objOrFunc'");
-}
-}else{
-if(typeof (_2a3)!="function"){
-throw new Error("'funcOrStr' must be a function or string");
-}
-}
-}else{
-if(typeof (_2a2)!="function"){
-throw new Error("'objOrFunc' must be a function if 'funcOrStr' is not given");
-}else{
-func=_2a2;
-}
-}
-return [obj,func];
-},connect:function(src,sig,_2a8,_2a9){
-src=MochiKit.DOM.getElement(src);
-var self=MochiKit.Signal;
-if(typeof (sig)!="string"){
-throw new Error("'sig' must be a string");
-}
-var _2ab=self._getDestPair(_2a8,_2a9);
-var obj=_2ab[0];
-var func=_2ab[1];
-if(typeof (obj)=="undefined"||obj===null){
-obj=src;
-}
-var _2ae=!!(src.addEventListener||src.attachEvent);
-if(_2ae&&(sig==="onmouseenter"||sig==="onmouseleave")&&!self._browserAlreadyHasMouseEnterAndLeave()){
-var _2af=self._mouseEnterListener(src,sig.substr(2),func,obj);
-if(sig==="onmouseenter"){
-sig="onmouseover";
-}else{
-sig="onmouseout";
-}
-}else{
-var _2af=self._listener(src,sig,func,obj,_2ae);
-}
-if(src.addEventListener){
-src.addEventListener(sig.substr(2),_2af,false);
-}else{
-if(src.attachEvent){
-src.attachEvent(sig,_2af);
-}
-}
-var _2b0=new MochiKit.Signal.Ident({source:src,signal:sig,listener:_2af,isDOM:_2ae,objOrFunc:_2a8,funcOrStr:_2a9,connected:true});
-self._observers.push(_2b0);
-if(!_2ae&&typeof (src.__connect__)=="function"){
-var args=MochiKit.Base.extend([_2b0],arguments,1);
-src.__connect__.apply(src,args);
-}
-return _2b0;
-},_disconnect:function(_2b2){
-if(!_2b2.connected){
-return;
-}
-_2b2.connected=false;
-if(!_2b2.isDOM){
-return;
-}
-var src=_2b2.source;
-var sig=_2b2.signal;
-var _2b5=_2b2.listener;
-if(src.removeEventListener){
-src.removeEventListener(sig.substr(2),_2b5,false);
-}else{
-if(src.detachEvent){
-src.detachEvent(sig,_2b5);
-}else{
-throw new Error("'src' must be a DOM element");
-}
-}
-},disconnect:function(_2b6){
-var self=MochiKit.Signal;
-var _2b8=self._observers;
-var m=MochiKit.Base;
-if(arguments.length>1){
-var src=MochiKit.DOM.getElement(arguments[0]);
-var sig=arguments[1];
-var obj=arguments[2];
-var func=arguments[3];
-for(var i=_2b8.length-1;i>=0;i--){
-var o=_2b8[i];
-if(o.source===src&&o.signal===sig&&o.objOrFunc===obj&&o.funcOrStr===func){
-self._disconnect(o);
-if(!self._lock){
-_2b8.splice(i,1);
-}else{
-self._dirty=true;
-}
-return true;
-}
-}
-}else{
-var idx=m.findIdentical(_2b8,_2b6);
-if(idx>=0){
-self._disconnect(_2b6);
-if(!self._lock){
-_2b8.splice(idx,1);
-}else{
-self._dirty=true;
-}
-return true;
-}
-}
-return false;
-},disconnectAllTo:function(_2c1,_2c2){
-var self=MochiKit.Signal;
-var _2c4=self._observers;
-var _2c5=self._disconnect;
-var _2c6=self._lock;
-var _2c7=self._dirty;
-if(typeof (_2c2)==="undefined"){
-_2c2=null;
-}
-for(var i=_2c4.length-1;i>=0;i--){
-var _2c9=_2c4[i];
-if(_2c9.objOrFunc===_2c1&&(_2c2===null||_2c9.funcOrStr===_2c2)){
-_2c5(_2c9);
-if(_2c6){
-_2c7=true;
-}else{
-_2c4.splice(i,1);
-}
-}
-}
-self._dirty=_2c7;
-},disconnectAll:function(src,sig){
-src=MochiKit.DOM.getElement(src);
-var m=MochiKit.Base;
-var _2cd=m.flattenArguments(m.extend(null,arguments,1));
-var self=MochiKit.Signal;
-var _2cf=self._disconnect;
-var _2d0=self._observers;
-var i,_2d2;
-var _2d3=self._lock;
-var _2d4=self._dirty;
-if(_2cd.length===0){
-for(i=_2d0.length-1;i>=0;i--){
-_2d2=_2d0[i];
-if(_2d2.source===src){
-_2cf(_2d2);
-if(!_2d3){
-_2d0.splice(i,1);
-}else{
-_2d4=true;
-}
-}
-}
-}else{
-var sigs={};
-for(i=0;i<_2cd.length;i++){
-sigs[_2cd[i]]=true;
-}
-for(i=_2d0.length-1;i>=0;i--){
-_2d2=_2d0[i];
-if(_2d2.source===src&&_2d2.signal in sigs){
-_2cf(_2d2);
-if(!_2d3){
-_2d0.splice(i,1);
-}else{
-_2d4=true;
-}
-}
-}
-}
-self._dirty=_2d4;
-},signal:function(src,sig){
-var self=MochiKit.Signal;
-var _2d9=self._observers;
-src=MochiKit.DOM.getElement(src);
-var args=MochiKit.Base.extend(null,arguments,2);
-var _2db=[];
-self._lock=true;
-for(var i=0;i<_2d9.length;i++){
-var _2dd=_2d9[i];
-if(_2dd.source===src&&_2dd.signal===sig&&_2dd.connected){
-try{
-_2dd.listener.apply(src,args);
-}
-catch(e){
-_2db.push(e);
-}
-}
-}
-self._lock=false;
-if(self._dirty){
-self._dirty=false;
-for(var i=_2d9.length-1;i>=0;i--){
-if(!_2d9[i].connected){
-_2d9.splice(i,1);
-}
-}
-}
-if(_2db.length==1){
-throw _2db[0];
-}else{
-if(_2db.length>1){
-var e=new Error("Multiple errors thrown in handling 'sig', see errors property");
-e.errors=_2db;
-throw e;
-}
-}
-}});
-MochiKit.Signal.EXPORT_OK=[];
-MochiKit.Signal.EXPORT=["connect","disconnect","signal","disconnectAll","disconnectAllTo"];
-MochiKit.Signal.__new__=function(win){
-var m=MochiKit.Base;
-this._document=document;
-this._window=win;
-this._lock=false;
-this._dirty=false;
-try{
-this.connect(window,"onunload",this._unloadCache);
-}
-catch(e){
-}
-this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)};
-m.nameFunctions(this);
-};
-MochiKit.Signal.__new__(this);
-if(MochiKit.__export__){
-connect=MochiKit.Signal.connect;
-disconnect=MochiKit.Signal.disconnect;
-disconnectAll=MochiKit.Signal.disconnectAll;
-signal=MochiKit.Signal.signal;
-}
-MochiKit.Base._exportSymbols(this,MochiKit.Signal);
-if(typeof (dojo)!="undefined"){
-dojo.provide("MochiKit.Iter");
-dojo.require("MochiKit.Base");
-}
-if(typeof (JSAN)!="undefined"){
-JSAN.use("MochiKit.Base",[]);
-}
-try{
-if(typeof (MochiKit.Base)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Iter depends on MochiKit.Base!";
-}
-if(typeof (MochiKit.Iter)=="undefined"){
-MochiKit.Iter={};
-}
-MochiKit.Iter.NAME="MochiKit.Iter";
-MochiKit.Iter.VERSION="1.4";
-MochiKit.Base.update(MochiKit.Iter,{__repr__:function(){
-return "["+this.NAME+" "+this.VERSION+"]";
-},toString:function(){
-return this.__repr__();
-},registerIteratorFactory:function(name,_2e2,_2e3,_2e4){
-MochiKit.Iter.iteratorRegistry.register(name,_2e2,_2e3,_2e4);
-},iter:function(_2e5,_2e6){
-var self=MochiKit.Iter;
-if(arguments.length==2){
-return self.takewhile(function(a){
-return a!=_2e6;
-},_2e5);
-}
-if(typeof (_2e5.next)=="function"){
-return _2e5;
-}else{
-if(typeof (_2e5.iter)=="function"){
-return _2e5.iter();
-}
-}
-try{
-return self.iteratorRegistry.match(_2e5);
-}
-catch(e){
-var m=MochiKit.Base;
-if(e==m.NotFound){
-e=new TypeError(typeof (_2e5)+": "+m.repr(_2e5)+" is not iterable");
-}
-throw e;
-}
-},count:function(n){
-if(!n){
-n=0;
-}
-var m=MochiKit.Base;
-return {repr:function(){
-return "count("+n+")";
-},toString:m.forwardCall("repr"),next:m.counter(n)};
-},cycle:function(p){
-var self=MochiKit.Iter;
-var m=MochiKit.Base;
-var lst=[];
-var _2f0=self.iter(p);
-return {repr:function(){
-return "cycle(...)";
-},toString:m.forwardCall("repr"),next:function(){
-try{
-var rval=_2f0.next();
-lst.push(rval);
-return rval;
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-if(lst.length===0){
-this.next=function(){
-throw self.StopIteration;
-};
-}else{
-var i=-1;
-this.next=function(){
-i=(i+1)%lst.length;
-return lst[i];
-};
-}
-return this.next();
-}
-}};
-},repeat:function(elem,n){
-var m=MochiKit.Base;
-if(typeof (n)=="undefined"){
-return {repr:function(){
-return "repeat("+m.repr(elem)+")";
-},toString:m.forwardCall("repr"),next:function(){
-return elem;
-}};
-}
-return {repr:function(){
-return "repeat("+m.repr(elem)+", "+n+")";
-},toString:m.forwardCall("repr"),next:function(){
-if(n<=0){
-throw MochiKit.Iter.StopIteration;
-}
-n-=1;
-return elem;
-}};
-},next:function(_2f6){
-return _2f6.next();
-},izip:function(p,q){
-var m=MochiKit.Base;
-var self=MochiKit.Iter;
-var next=self.next;
-var _2fc=m.map(self.iter,arguments);
-return {repr:function(){
-return "izip(...)";
-},toString:m.forwardCall("repr"),next:function(){
-return m.map(next,_2fc);
-}};
-},ifilter:function(pred,seq){
-var m=MochiKit.Base;
-seq=MochiKit.Iter.iter(seq);
-if(pred===null){
-pred=m.operator.truth;
-}
-return {repr:function(){
-return "ifilter(...)";
-},toString:m.forwardCall("repr"),next:function(){
-while(true){
-var rval=seq.next();
-if(pred(rval)){
-return rval;
-}
-}
-return undefined;
-}};
-},ifilterfalse:function(pred,seq){
-var m=MochiKit.Base;
-seq=MochiKit.Iter.iter(seq);
-if(pred===null){
-pred=m.operator.truth;
-}
-return {repr:function(){
-return "ifilterfalse(...)";
-},toString:m.forwardCall("repr"),next:function(){
-while(true){
-var rval=seq.next();
-if(!pred(rval)){
-return rval;
-}
-}
-return undefined;
-}};
-},islice:function(seq){
-var self=MochiKit.Iter;
-var m=MochiKit.Base;
-seq=self.iter(seq);
-var _308=0;
-var stop=0;
-var step=1;
-var i=-1;
-if(arguments.length==2){
-stop=arguments[1];
-}else{
-if(arguments.length==3){
-_308=arguments[1];
-stop=arguments[2];
-}else{
-_308=arguments[1];
-stop=arguments[2];
-step=arguments[3];
-}
-}
-return {repr:function(){
-return "islice("+["...",_308,stop,step].join(", ")+")";
-},toString:m.forwardCall("repr"),next:function(){
-var rval;
-while(i<_308){
-rval=seq.next();
-i++;
-}
-if(_308>=stop){
-throw self.StopIteration;
-}
-_308+=step;
-return rval;
-}};
-},imap:function(fun,p,q){
-var m=MochiKit.Base;
-var self=MochiKit.Iter;
-var _312=m.map(self.iter,m.extend(null,arguments,1));
-var map=m.map;
-var next=self.next;
-return {repr:function(){
-return "imap(...)";
-},toString:m.forwardCall("repr"),next:function(){
-return fun.apply(this,map(next,_312));
-}};
-},applymap:function(fun,seq,self){
-seq=MochiKit.Iter.iter(seq);
-var m=MochiKit.Base;
-return {repr:function(){
-return "applymap(...)";
-},toString:m.forwardCall("repr"),next:function(){
-return fun.apply(self,seq.next());
-}};
-},chain:function(p,q){
-var self=MochiKit.Iter;
-var m=MochiKit.Base;
-if(arguments.length==1){
-return self.iter(arguments[0]);
-}
-var _31d=m.map(self.iter,arguments);
-return {repr:function(){
-return "chain(...)";
-},toString:m.forwardCall("repr"),next:function(){
-while(_31d.length>1){
-try{
-return _31d[0].next();
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-_31d.shift();
-}
-}
-if(_31d.length==1){
-var arg=_31d.shift();
-this.next=m.bind("next",arg);
-return this.next();
-}
-throw self.StopIteration;
-}};
-},takewhile:function(pred,seq){
-var self=MochiKit.Iter;
-seq=self.iter(seq);
-return {repr:function(){
-return "takewhile(...)";
-},toString:MochiKit.Base.forwardCall("repr"),next:function(){
-var rval=seq.next();
-if(!pred(rval)){
-this.next=function(){
-throw self.StopIteration;
-};
-this.next();
-}
-return rval;
-}};
-},dropwhile:function(pred,seq){
-seq=MochiKit.Iter.iter(seq);
-var m=MochiKit.Base;
-var bind=m.bind;
-return {"repr":function(){
-return "dropwhile(...)";
-},"toString":m.forwardCall("repr"),"next":function(){
-while(true){
-var rval=seq.next();
-if(!pred(rval)){
-break;
-}
-}
-this.next=bind("next",seq);
-return rval;
-}};
-},_tee:function(_328,sync,_32a){
-sync.pos[_328]=-1;
-var m=MochiKit.Base;
-var _32c=m.listMin;
-return {repr:function(){
-return "tee("+_328+", ...)";
-},toString:m.forwardCall("repr"),next:function(){
-var rval;
-var i=sync.pos[_328];
-if(i==sync.max){
-rval=_32a.next();
-sync.deque.push(rval);
-sync.max+=1;
-sync.pos[_328]+=1;
-}else{
-rval=sync.deque[i-sync.min];
-sync.pos[_328]+=1;
-if(i==sync.min&&_32c(sync.pos)!=sync.min){
-sync.min+=1;
-sync.deque.shift();
-}
-}
-return rval;
-}};
-},tee:function(_32f,n){
-var rval=[];
-var sync={"pos":[],"deque":[],"max":-1,"min":-1};
-if(arguments.length==1||typeof (n)=="undefined"||n===null){
-n=2;
-}
-var self=MochiKit.Iter;
-_32f=self.iter(_32f);
-var _tee=self._tee;
-for(var i=0;i<n;i++){
-rval.push(_tee(i,sync,_32f));
-}
-return rval;
-},list:function(_336){
-var rval;
-if(_336 instanceof Array){
-return _336.slice();
-}
-if(typeof (_336)=="function"&&!(_336 instanceof Function)&&typeof (_336.length)=="number"){
-rval=[];
-for(var i=0;i<_336.length;i++){
-rval.push(_336[i]);
-}
-return rval;
-}
-var self=MochiKit.Iter;
-_336=self.iter(_336);
-var rval=[];
-try{
-while(true){
-rval.push(_336.next());
-}
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-return rval;
-}
-return undefined;
-},reduce:function(fn,_33b,_33c){
-var i=0;
-var x=_33c;
-var self=MochiKit.Iter;
-_33b=self.iter(_33b);
-if(arguments.length<3){
-try{
-x=_33b.next();
-}
-catch(e){
-if(e==self.StopIteration){
-e=new TypeError("reduce() of empty sequence with no initial value");
-}
-throw e;
-}
-i++;
-}
-try{
-while(true){
-x=fn(x,_33b.next());
-}
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-}
-return x;
-},range:function(){
-var _340=0;
-var stop=0;
-var step=1;
-if(arguments.length==1){
-stop=arguments[0];
-}else{
-if(arguments.length==2){
-_340=arguments[0];
-stop=arguments[1];
-}else{
-if(arguments.length==3){
-_340=arguments[0];
-stop=arguments[1];
-step=arguments[2];
-}else{
-throw new TypeError("range() takes 1, 2, or 3 arguments!");
-}
-}
-}
-if(step===0){
-throw new TypeError("range() step must not be 0");
-}
-return {next:function(){
-if((step>0&&_340>=stop)||(step<0&&_340<=stop)){
-throw MochiKit.Iter.StopIteration;
-}
-var rval=_340;
-_340+=step;
-return rval;
-},repr:function(){
-return "range("+[_340,stop,step].join(", ")+")";
-},toString:MochiKit.Base.forwardCall("repr")};
-},sum:function(_344,_345){
-if(typeof (_345)=="undefined"||_345===null){
-_345=0;
-}
-var x=_345;
-var self=MochiKit.Iter;
-_344=self.iter(_344);
-try{
-while(true){
-x+=_344.next();
-}
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-}
-return x;
-},exhaust:function(_348){
-var self=MochiKit.Iter;
-_348=self.iter(_348);
-try{
-while(true){
-_348.next();
-}
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-}
-},forEach:function(_34a,func,self){
-var m=MochiKit.Base;
-if(arguments.length>2){
-func=m.bind(func,self);
-}
-if(m.isArrayLike(_34a)){
-try{
-for(var i=0;i<_34a.length;i++){
-func(_34a[i]);
-}
-}
-catch(e){
-if(e!=MochiKit.Iter.StopIteration){
-throw e;
-}
-}
-}else{
-self=MochiKit.Iter;
-self.exhaust(self.imap(func,_34a));
-}
-},every:function(_34f,func){
-var self=MochiKit.Iter;
-try{
-self.ifilterfalse(func,_34f).next();
-return false;
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-return true;
-}
-},sorted:function(_352,cmp){
-var rval=MochiKit.Iter.list(_352);
-if(arguments.length==1){
-cmp=MochiKit.Base.compare;
-}
-rval.sort(cmp);
-return rval;
-},reversed:function(_355){
-var rval=MochiKit.Iter.list(_355);
-rval.reverse();
-return rval;
-},some:function(_357,func){
-var self=MochiKit.Iter;
-try{
-self.ifilter(func,_357).next();
-return true;
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-return false;
-}
-},iextend:function(lst,_35b){
-if(MochiKit.Base.isArrayLike(_35b)){
-for(var i=0;i<_35b.length;i++){
-lst.push(_35b[i]);
-}
-}else{
-var self=MochiKit.Iter;
-_35b=self.iter(_35b);
-try{
-while(true){
-lst.push(_35b.next());
-}
-}
-catch(e){
-if(e!=self.StopIteration){
-throw e;
-}
-}
-}
-return lst;
-},groupby:function(_35e,_35f){
-var m=MochiKit.Base;
-var self=MochiKit.Iter;
-if(arguments.length<2){
-_35f=m.operator.identity;
-}
-_35e=self.iter(_35e);
-var pk=undefined;
-var k=undefined;
-var v;
-function fetch(){
-v=_35e.next();
-k=_35f(v);
-}
-function eat(){
-var ret=v;
-v=undefined;
-return ret;
-}
-var _366=true;
-var _367=m.compare;
-return {repr:function(){
-return "groupby(...)";
-},next:function(){
-while(_367(k,pk)===0){
-fetch();
-if(_366){
-_366=false;
-break;
-}
-}
-pk=k;
-return [k,{next:function(){
-if(v==undefined){
-fetch();
-}
-if(_367(k,pk)!==0){
-throw self.StopIteration;
-}
-return eat();
-}}];
-}};
-},groupby_as_array:function(_368,_369){
-var m=MochiKit.Base;
-var self=MochiKit.Iter;
-if(arguments.length<2){
-_369=m.operator.identity;
-}
-_368=self.iter(_368);
-var _36c=[];
-var _36d=true;
-var _36e;
-var _36f=m.compare;
-while(true){
-try{
-var _370=_368.next();
-var key=_369(_370);
-}
-catch(e){
-if(e==self.StopIteration){
-break;
-}
-throw e;
-}
-if(_36d||_36f(key,_36e)!==0){
-var _372=[];
-_36c.push([key,_372]);
-}
-_372.push(_370);
-_36d=false;
-_36e=key;
-}
-return _36c;
-},arrayLikeIter:function(_373){
-var i=0;
-return {repr:function(){
-return "arrayLikeIter(...)";
-},toString:MochiKit.Base.forwardCall("repr"),next:function(){
-if(i>=_373.length){
-throw MochiKit.Iter.StopIteration;
-}
-return _373[i++];
-}};
-},hasIterateNext:function(_375){
-return (_375&&typeof (_375.iterateNext)=="function");
-},iterateNextIter:function(_376){
-return {repr:function(){
-return "iterateNextIter(...)";
-},toString:MochiKit.Base.forwardCall("repr"),next:function(){
-var rval=_376.iterateNext();
-if(rval===null||rval===undefined){
-throw MochiKit.Iter.StopIteration;
-}
-return rval;
-}};
-}});
-MochiKit.Iter.EXPORT_OK=["iteratorRegistry","arrayLikeIter","hasIterateNext","iterateNextIter",];
-MochiKit.Iter.EXPORT=["StopIteration","registerIteratorFactory","iter","count","cycle","repeat","next","izip","ifilter","ifilterfalse","islice","imap","applymap","chain","takewhile","dropwhile","tee","list","reduce","range","sum","exhaust","forEach","every","sorted","reversed","some","iextend","groupby","groupby_as_array"];
-MochiKit.Iter.__new__=function(){
-var m=MochiKit.Base;
-if(typeof (StopIteration)!="undefined"){
-this.StopIteration=StopIteration;
-}else{
-this.StopIteration=new m.NamedError("StopIteration");
-}
-this.iteratorRegistry=new m.AdapterRegistry();
-this.registerIteratorFactory("arrayLike",m.isArrayLike,this.arrayLikeIter);
-this.registerIteratorFactory("iterateNext",this.hasIterateNext,this.iterateNextIter);
-this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)};
-m.nameFunctions(this);
-};
-MochiKit.Iter.__new__();
-if(MochiKit.__export__){
-reduce=MochiKit.Iter.reduce;
-}
-MochiKit.Base._exportSymbols(this,MochiKit.Iter);
-if(typeof (dojo)!="undefined"){
-dojo.provide("MochiKit.Async");
-dojo.require("MochiKit.Base");
-}
-if(typeof (JSAN)!="undefined"){
-JSAN.use("MochiKit.Base",[]);
-}
-try{
-if(typeof (MochiKit.Base)=="undefined"){
-throw "";
-}
-}
-catch(e){
-throw "MochiKit.Async depends on MochiKit.Base!";
-}
-if(typeof (MochiKit.Async)=="undefined"){
-MochiKit.Async={};
-}
-MochiKit.Async.NAME="MochiKit.Async";
-MochiKit.Async.VERSION="1.4";
-MochiKit.Async.__repr__=function(){
-return "["+this.NAME+" "+this.VERSION+"]";
-};
-MochiKit.Async.toString=function(){
-return this.__repr__();
-};
-MochiKit.Async.Deferred=function(_379){
-this.chain=[];
-this.id=this._nextId();
-this.fired=-1;
-this.paused=0;
-this.results=[null,null];
-this.canceller=_379;
-this.silentlyCancelled=false;
-this.chained=false;
-};
-MochiKit.Async.Deferred.prototype={repr:function(){
-var _37a;
-if(this.fired==-1){
-_37a="unfired";
-}else{
-if(this.fired===0){
-_37a="success";
-}else{
-_37a="error";
-}
-}
-return "Deferred("+this.id+", "+_37a+")";
-},toString:MochiKit.Base.forwardCall("repr"),_nextId:MochiKit.Base.counter(),cancel:function(){
-var self=MochiKit.Async;
-if(this.fired==-1){
-if(this.canceller){
-this.canceller(this);
-}else{
-this.silentlyCancelled=true;
-}
-if(this.fired==-1){
-this.errback(new self.CancelledError(this));
-}
-}else{
-if((this.fired===0)&&(this.results[0] instanceof self.Deferred)){
-this.results[0].cancel();
-}
-}
-},_resback:function(res){
-this.fired=((res instanceof Error)?1:0);
-this.results[this.fired]=res;
-this._fire();
-},_check:function(){
-if(this.fired!=-1){
-if(!this.silentlyCancelled){
-throw new MochiKit.Async.AlreadyCalledError(this);
-}
-this.silentlyCancelled=false;
-return;
-}
-},callback:function(res){
-this._check();
-if(res instanceof MochiKit.Async.Deferred){
-throw new Error("Deferred instances can only be chained if they are the result of a callback");
-}
-this._resback(res);
-},errback:function(res){
-this._check();
-var self=MochiKit.Async;
-if(res instanceof self.Deferred){
-throw new Error("Deferred instances can only be chained if they are the result of a callback");
-}
-if(!(res instanceof Error)){
-res=new self.GenericError(res);
-}
-this._resback(res);
-},addBoth:function(fn){
-if(arguments.length>1){
-fn=MochiKit.Base.partial.apply(null,arguments);
-}
-return this.addCallbacks(fn,fn);
-},addCallback:function(fn){
-if(arguments.length>1){
-fn=MochiKit.Base.partial.apply(null,arguments);
-}
-return this.addCallbacks(fn,null);
-},addErrback:function(fn){
-if(arguments.length>1){
-fn=MochiKit.Base.partial.apply(null,arguments);
-}
-return this.addCallbacks(null,fn);
-},addCallbacks:function(cb,eb){
-if(this.chained){
-throw new Error("Chained Deferreds can not be re-used");
-}
-this.chain.push([cb,eb]);
-if(this.fired>=0){
-this._fire();
-}
-return this;
-},_fire:function(){
-var _385=this.chain;
-var _386=this.fired;
-var res=this.results[_386];
-var self=this;
-var cb=null;
-while(_385.length>0&&this.paused===0){
-var pair=_385.shift();
-var f=pair[_386];
-if(f===null){
-continue;
-}
-try{
-res=f(res);
-_386=((res instanceof Error)?1:0);
-if(res instanceof MochiKit.Async.Deferred){
-cb=function(res){
-self._resback(res);
-self.paused--;
-if((self.paused===0)&&(self.fired>=0)){
-self._fire();
-}
-};
-this.paused++;
-}
-}
-catch(err){
-_386=1;
-if(!(err instanceof Error)){
-err=new MochiKit.Async.GenericError(err);
-}
-res=err;
-}
-}
-this.fired=_386;
-this.results[_386]=res;
-if(cb&&this.paused){
-res.addBoth(cb);
-res.chained=true;
-}
-}};
-MochiKit.Base.update(MochiKit.Async,{evalJSONRequest:function(req){
-return MochiKit.Base.evalJSON(req.responseText);
-},succeed:function(_38e){
-var d=new MochiKit.Async.Deferred();
-d.callback.apply(d,arguments);
-return d;
-},fail:function(_390){
-var d=new MochiKit.Async.Deferred();
-d.errback.apply(d,arguments);
-return d;
-},getXMLHttpRequest:function(){
-var self=arguments.callee;
-if(!self.XMLHttpRequest){
-var _393=[function(){
-return new XMLHttpRequest();
-},function(){
-return new ActiveXObject("Msxml2.XMLHTTP");
-},function(){
-return new ActiveXObject("Microsoft.XMLHTTP");
-},function(){
-return new ActiveXObject("Msxml2.XMLHTTP.4.0");
-},function(){
-throw new MochiKit.Async.BrowserComplianceError("Browser does not support XMLHttpRequest");
-}];
-for(var i=0;i<_393.length;i++){
-var func=_393[i];
-try{
-self.XMLHttpRequest=func;
-return func();
-}
-catch(e){
-}
-}
-}
-return self.XMLHttpRequest();
-},_xhr_onreadystatechange:function(d){
-var m=MochiKit.Base;
-if(this.readyState==4){
-try{
-this.onreadystatechange=null;
-}
-catch(e){
-try{
-this.onreadystatechange=m.noop;
-}
-catch(e){
-}
-}
-var _398=null;
-try{
-_398=this.status;
-if(!_398&&m.isNotEmpty(this.responseText)){
-_398=304;
-}
-}
-catch(e){
-}
-if(_398==200||_398==201||_398==204||_398==304||_398==1223){
-d.callback(this);
-}else{
-var err=new MochiKit.Async.XMLHttpRequestError(this,"Request failed");
-if(err.number){
-d.errback(err);
-}else{
-d.errback(err);
-}
-}
-}
-},_xhr_canceller:function(req){
-try{
-req.onreadystatechange=null;
-}
-catch(e){
-try{
-req.onreadystatechange=MochiKit.Base.noop;
-}
-catch(e){
-}
-}
-req.abort();
-},sendXMLHttpRequest:function(req,_39c){
-if(typeof (_39c)=="undefined"||_39c===null){
-_39c="";
-}
-var m=MochiKit.Base;
-var self=MochiKit.Async;
-var d=new self.Deferred(m.partial(self._xhr_canceller,req));
-try{
-req.onreadystatechange=m.bind(self._xhr_onreadystatechange,req,d);
-req.send(_39c);
-}
-catch(e){
-try{
-req.onreadystatechange=null;
-}
-catch(ignore){
-}
-d.errback(e);
-}
-return d;
-},doXHR:function(url,opts){
-var self=MochiKit.Async;
-return self.callLater(0,self._doXHR,url,opts);
-},_doXHR:function(url,opts){
-var m=MochiKit.Base;
-opts=m.update({method:"GET",sendContent:""},opts);
-var self=MochiKit.Async;
-var req=self.getXMLHttpRequest();
-if(opts.queryString){
-var qs=m.queryString(opts.queryString);
-if(qs){
-url+="?"+qs;
-}
-}
-if("username" in opts){
-req.open(opts.method,url,true,opts.username,opts.password);
-}else{
-req.open(opts.method,url,true);
-}
-if(req.overrideMimeType&&opts.mimeType){
-req.overrideMimeType(opts.mimeType);
-}
-if(opts.headers){
-var _3a9=opts.headers;
-if(!m.isArrayLike(_3a9)){
-_3a9=m.items(_3a9);
-}
-for(var i=0;i<_3a9.length;i++){
-var _3ab=_3a9[i];
-var name=_3ab[0];
-var _3ad=_3ab[1];
-req.setRequestHeader(name,_3ad);
-}
-}
-return self.sendXMLHttpRequest(req,opts.sendContent);
-},_buildURL:function(url){
-if(arguments.length>1){
-var m=MochiKit.Base;
-var qs=m.queryString.apply(null,m.extend(null,arguments,1));
-if(qs){
-return url+"?"+qs;
-}
-}
-return url;
-},doSimpleXMLHttpRequest:function(url){
-var self=MochiKit.Async;
-url=self._buildURL.apply(self,arguments);
-return self.doXHR(url);
-},loadJSONDoc:function(url){
-var self=MochiKit.Async;
-url=self._buildURL.apply(self,arguments);
-var d=self.doXHR(url,{"mimeType":"text/plain","headers":[["Accept","application/json"]]});
-d=d.addCallback(self.evalJSONRequest);
-return d;
-},wait:function(_3b6,_3b7){
-var d=new MochiKit.Async.Deferred();
-var m=MochiKit.Base;
-if(typeof (_3b7)!="undefined"){
-d.addCallback(function(){
-return _3b7;
-});
-}
-var _3ba=setTimeout(m.bind("callback",d),Math.floor(_3b6*1000));
-d.canceller=function(){
-try{
-clearTimeout(_3ba);
-}
-catch(e){
-}
-};
-return d;
-},callLater:function(_3bb,func){
-var m=MochiKit.Base;
-var _3be=m.partial.apply(m,m.extend(null,arguments,1));
-return MochiKit.Async.wait(_3bb).addCallback(function(res){
-return _3be();
-});
-}});
-MochiKit.Async.DeferredLock=function(){
-this.waiting=[];
-this.locked=false;
-this.id=this._nextId();
-};
-MochiKit.Async.DeferredLock.prototype={__class__:MochiKit.Async.DeferredLock,acquire:function(){
-var d=new MochiKit.Async.Deferred();
-if(this.locked){
-this.waiting.push(d);
-}else{
-this.locked=true;
-d.callback(this);
-}
-return d;
-},release:function(){
-if(!this.locked){
-throw TypeError("Tried to release an unlocked DeferredLock");
-}
-this.locked=false;
-if(this.waiting.length>0){
-this.locked=true;
-this.waiting.shift().callback(this);
-}
-},_nextId:MochiKit.Base.counter(),repr:function(){
-var _3c1;
-if(this.locked){
-_3c1="locked, "+this.waiting.length+" waiting";
-}else{
-_3c1="unlocked";
-}
-return "DeferredLock("+this.id+", "+_3c1+")";
-},toString:MochiKit.Base.forwardCall("repr")};
-MochiKit.Async.DeferredList=function(list,_3c3,_3c4,_3c5,_3c6){
-MochiKit.Async.Deferred.apply(this,[_3c6]);
-this.list=list;
-var _3c7=[];
-this.resultList=_3c7;
-this.finishedCount=0;
-this.fireOnOneCallback=_3c3;
-this.fireOnOneErrback=_3c4;
-this.consumeErrors=_3c5;
-var cb=MochiKit.Base.bind(this._cbDeferred,this);
-for(var i=0;i<list.length;i++){
-var d=list[i];
-_3c7.push(undefined);
-d.addCallback(cb,i,true);
-d.addErrback(cb,i,false);
-}
-if(list.length===0&&!_3c3){
-this.callback(this.resultList);
-}
-};
-MochiKit.Async.DeferredList.prototype=new MochiKit.Async.Deferred();
-MochiKit.Async.DeferredList.prototype._cbDeferred=function(_3cb,_3cc,_3cd){
-this.resultList[_3cb]=[_3cc,_3cd];
-this.finishedCount+=1;
-if(this.fired==-1){
-if(_3cc&&this.fireOnOneCallback){
-this.callback([_3cb,_3cd]);
-}else{
-if(!_3cc&&this.fireOnOneErrback){
-this.errback(_3cd);
-}else{
-if(this.finishedCount==this.list.length){
-this.callback(this.resultList);
-}
-}
-}
-}
-if(!_3cc&&this.consumeErrors){
-_3cd=null;
-}
-return _3cd;
-};
-MochiKit.Async.gatherResults=function(_3ce){
-var d=new MochiKit.Async.DeferredList(_3ce,false,true,false);
-d.addCallback(function(_3d0){
-var ret=[];
-for(var i=0;i<_3d0.length;i++){
-ret.push(_3d0[i][1]);
-}
-return ret;
-});
-return d;
-};
-MochiKit.Async.maybeDeferred=function(func){
-var self=MochiKit.Async;
-var _3d5;
-try{
-var r=func.apply(null,MochiKit.Base.extend([],arguments,1));
-if(r instanceof self.Deferred){
-_3d5=r;
-}else{
-if(r instanceof Error){
-_3d5=self.fail(r);
-}else{
-_3d5=self.succeed(r);
-}
-}
-}
-catch(e){
-_3d5=self.fail(e);
-}
-return _3d5;
-};
-MochiKit.Async.EXPORT=["AlreadyCalledError","CancelledError","BrowserComplianceError","GenericError","XMLHttpRequestError","Deferred","succeed","fail","getXMLHttpRequest","doSimpleXMLHttpRequest","loadJSONDoc","wait","callLater","sendXMLHttpRequest","DeferredLock","DeferredList","gatherResults","maybeDeferred","doXHR"];
-MochiKit.Async.EXPORT_OK=["evalJSONRequest"];
-MochiKit.Async.__new__=function(){
-var m=MochiKit.Base;
-var ne=m.partial(m._newNamedError,this);
-ne("AlreadyCalledError",function(_3d9){
-this.deferred=_3d9;
-});
-ne("CancelledError",function(_3da){
-this.deferred=_3da;
-});
-ne("BrowserComplianceError",function(msg){
-this.message=msg;
-});
-ne("GenericError",function(msg){
-this.message=msg;
-});
-ne("XMLHttpRequestError",function(req,msg){
-this.req=req;
-this.message=msg;
-try{
-this.number=req.status;
-}
-catch(e){
-}
-});
-this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)};
-m.nameFunctions(this);
-};
-MochiKit.Async.__new__();
-MochiKit.Base._exportSymbols(this,MochiKit.Async);
-
-
index 035f5e5..6f15b37 100755 (executable)
@@ -34,7 +34,7 @@
 // parentheses, etc, and know when you are inside a string or comment.
 var parseTypoScript = function() {
   // Token types that can be considered to be atoms.
-  var atomicTypes = setObject("atom", "number", "variable", "string", "regexp");  
+  var atomicTypes = {"atom": true, "number": true, "variable": true, "string": true, "regexp": true};
 
   // Constructor for the lexical context objects.
   function TSLexical(indented, column, type, align, prev) {
index 68369c2..2cf957c 100755 (executable)
@@ -324,7 +324,7 @@ var select = {};
       var selection = window.getSelection();
       if (selection && selection.rangeCount > 0) {
        var range = selection.getRangeAt(0);
-       var br = withDocument(window.document, BR);
+       var br = window.document.createElement('br');
        range.insertNode(br);
        range.setEndAfter(br);
        range.collapse(false);
index 35c3956..3052e57 100644 (file)
@@ -36,7 +36,7 @@ function singleStringStream(string) {
 // is applied to the result of traverseDOM (see codemirror.js), and
 // the resulting stream is fed to the parser.
 function multiStringStream(source){
-  source = iter(source);
+  // source = iter(source);
   var current = "", pos = 0;
   var peeked = null, accum = "";
   var result = {peek: peek, next: next, get: get};
index a7fee02..a358790 100755 (executable)
@@ -84,24 +84,36 @@ var t3eOptions = window.t3eOptions || {};
 //   tries to colour in one shot. Setting this too high will cause the
 //   code to 'freeze' the browser for noticeable intervals.
 // passDelay gives the amount of milliseconds between colouring passes
-setdefault(t3eOptions,
-           {safeKeys: setObject("KEY_ARROW_UP", "KEY_ARROW_DOWN", "KEY_ARROW_LEFT", "KEY_ARROW_RIGHT", "KEY_END", "KEY_HOME",
-                                "KEY_PAGE_UP", "KEY_PAGE_DOWN", "KEY_SHIFT", "KEY_CTRL", "KEY_ALT", "KEY_SELECT"),
-           reindentKeys: setObject("KEY_TAB"),
-           reindentAfterKeys: setObject("KEY_RIGHT_SQUARE_BRACKET"),
-        stylesheet: PATH_t3e+"css/t3editor.css",
-        parser: parseTypoScript,
-           linesPerPass: 10,
-           passDelay: 500,
-        autoComplete: true,
-        acWords:5});
+var t3eOptions = {
+               safeKeys:       { "KEY_ARROW_UP":true, 
+                                         "KEY_ARROW_DOWN":true, 
+                                         "KEY_ARROW_LEFT":true, 
+                                         "KEY_ARROW_RIGHT":true, 
+                                         "KEY_END":true, 
+                                         "KEY_HOME":true,
+                                         "KEY_PAGE_UP":true, 
+                                         "KEY_PAGE_DOWN":true, 
+                                         "KEY_SHIFT":true, 
+                                         "KEY_CTRL":true, 
+                                         "KEY_ALT":true, 
+                                         "KEY_SELECT":true
+               },
+               reindentKeys: {"KEY_TAB":true},
+               reindentAfterKeys: {"KEY_RIGHT_SQUARE_BRACKET":true},
+               stylesheet: PATH_t3e+"css/t3editor.css",
+               parser: parseTypoScript,
+               linesPerPass: 10,
+               passDelay: 200,
+               autoComplete: true,
+               acWords:5
+       };
 // These default options can be overridden by passing a set of options
 // to a specific CodeMirror constructor.
 
 var t3editor = function(){
   // The HTML elements whose content should be suffixed by a newline
   // when converting them to flat text.
-  var newlineElements = setObject("P", "DIV", "LI");
+  var newlineElements = {"P":true, "DIV":true, "LI":true};
 
   // Helper function for traverseDOM. Flattens an arbitrary DOM node
   // into an array of textnodes and <br> tags.
@@ -121,11 +133,12 @@ var t3editor = function(){
         result.push(node);
       }
       else {
-        forEach(node.childNodes, simplifyNode);
+        // forEach(node.childNodes, simplifyNode);
+        $A(node.childNodes).each(simplifyNode);
         if (!leaving && newlineElements.hasOwnProperty(node.nodeName)) {
           leaving = true;
-          el = withDocument(doc, SPAN);
-                 result.push(withDocument(doc, BR));
+          el = new Element('SPAN');            
+                 result.push(new Element('BR'));   
         }
       }
     }
@@ -170,7 +183,10 @@ var t3editor = function(){
       var text = "\n";
       if (part.nodeType == 3) {
         text = part.nodeValue;
-        part = withDocument(owner, partial(SPAN, {"class": "part"}, part));
+        
+        newpart = new Element('SPAN',{"class": "part"});
+        newpart.appendChild(part);
+        part = newpart;
         part.currentText = text;
       }
       part.dirty = true;
@@ -183,9 +199,13 @@ var t3editor = function(){
     // non-normalized nodes.
     function writeNode(node, c){
       var toYield = [];
-      forEach(simplifyDOM(node), function(part) {
-        toYield.push(insertPart(part));
-      });
+      var simdom = simplifyDOM(node);
+                       simdom.each(
+                               function(part) {
+                                       toYield.push(insertPart(part));
+                               }
+                       );
+
       return yield(toYield.join(""), c);
     }
 
@@ -214,7 +234,7 @@ var t3editor = function(){
       }
       else {
         point = pointAt(node);
-        removeElement(node);
+        Element.remove(node);
         return writeNode(node, c);
       }
     }
@@ -232,8 +252,10 @@ var t3editor = function(){
   function t3editor(theTextarea, index, options) {
    
    // Use passed options, if any, to override defaults.
-    this.options = options || {}
-    setdefault(this.options, t3eOptions);
+    this.options = options || t3eOptions; // {}
+    for (var lo in options) {
+               this.options[lo] = options[lo];
+       }
        
     //History Array
     this.history = [];
@@ -251,28 +273,32 @@ var t3editor = function(){
        this.index = index;
 
     // create the wrapping div
-    this.outerdiv = $(createDOM("DIV", {
-       "class":        "t3e_outerdiv",
-       "id":           "t3e_"+this.textarea.getAttribute('id')
-       }));
+    this.outerdiv = new Element("div", {
+                               "class":        "t3e_outerdiv",
+                               "id":           "t3e_"+this.textarea.getAttribute('id')
+                       }
+               );
 
        // place the div before the textarea
     this.textarea.parentNode.insertBefore(this.outerdiv,$(this.textarea));
 
        // an overlay that covers the whole editor
-       this.modalOverlay = $(createDOM("DIV", {
-       "class":        "t3e_modalOverlay",
-               "id":           "t3e_modalOverlay_wait"
-       }));
+               this.modalOverlay = new Element("DIV", {
+                               "class":        "t3e_modalOverlay",
+                               "id":           "t3e_modalOverlay_wait"
+                       }
+               );
     this.modalOverlay.hide();
     this.modalOverlay.setStyle(this.outerdiv.getDimensions());
     this.modalOverlay.setStyle({opacity: 0.5});
     this.outerdiv.appendChild(this.modalOverlay);
        
-       this.helpOverlay = $(createDOM("DIV", {
-       "class":        "t3e_modalOverlay",
-       "id":           "t3e_modalOverlay_help"
-       }));
+               this.helpOverlay = new Element("DIV", {
+                               "class":        "t3e_modalOverlay",
+                               "id":           "t3e_modalOverlay_help"
+                       }
+               );
+                       // TODO: fill with senseful content, make it dynamic
     this.helpOverlay.innerHTML = "<h2>t3editor</h2>"+
                                                                        "<p>put some helpful text here</p><br/><br/>"+
                                                                        "<p>Hotkeys:</p>"+
@@ -288,118 +314,122 @@ var t3editor = function(){
     this.helpOverlay.hide();
        this.outerdiv.appendChild(this.helpOverlay);
     
-       // wrapping the ilnenumbers
-    this.linenum_wrap = $(createDOM("DIV", {
-       "class":        "t3e_linenum_wrap"
-       }));
-       // the "linenumber" list itself
-    this.linenum = $(createDOM("DL", {
-       "class":        "t3e_linenum"
-       }));
+               // wrapping the linenumbers
+               this.linenum_wrap = new Element("DIV", {
+                               "class":        "t3e_linenum_wrap"
+                       }
+               );
+               // the "linenumber" list itself
+               this.linenum = new Element("DL", {
+                               "class":        "t3e_linenum"
+                       }
+               );
     this.linenum_wrap.appendChild(this.linenum);
     this.outerdiv.appendChild(this.linenum_wrap);
     
     //autocomplete box
-    this.autoCompleteBox = $(createDOM("DIV",{"class":"t3e_autoCompleteBox"}));
-    this.autoCompleteBox.hide();
-    this.outerdiv.appendChild(this.autoCompleteBox);
-    
-       // wrapping the iframe
-    this.iframe_wrap = $(createDOM("DIV", {
-       "class":        "t3e_iframe_wrap"
-       }));
-
-       // the iframe (the actual "editor")
-    // display: block occasionally suppresses some Firefox bugs, so we
-    // always add it, redundant as it sounds.
-    this.iframe = $(createDOM("IFRAME", {
-       "style": "border: 0; display: block;",
-       "class": "t3e_iframe" 
-       }));
+               this.autoCompleteBox = new Element("DIV",{
+                               "class":        "t3e_autoCompleteBox"
+                       }
+               );
+               this.autoCompleteBox.hide();
+               this.outerdiv.appendChild(this.autoCompleteBox);
+
+               // wrapping the iframe
+               this.iframe_wrap = new Element("DIV", {
+                               "class":        "t3e_iframe_wrap"
+                       }
+               );
+
+               // the iframe (the actual "editor")
+               // display: block occasionally suppresses some Firefox bugs, so we
+               // always add it, redundant as it sounds.
+               this.iframe = new Element("IFRAME", {
+                               "style":        "border: 0; display: block;",
+                               "class":        "t3e_iframe" 
+                       }
+               );
 
     this.iframe_wrap.appendChild(this.iframe);
     this.outerdiv.appendChild(this.iframe_wrap);
     
        // wrapping the footer/statusline
-    this.footer_wrap = $(createDOM("DIV", {
-       "class":        "t3e_footer_wrap"
-       }));
-    this.outerdiv.appendChild(this.footer_wrap);
-    
-       // this.fitem_resize = this.createFooterItem('#', false);
-    // this.footer_wrap.appendChild(this.fitem_resize);
-       
-       // footer item: show help Window
-         // TODO make this more flexible! And get rid of inline css and unsed options! 
-    this.fitem_help = this.createFooterItem('Help', true, 'toggleHelp');
-    this.footer_wrap.appendChild(this.fitem_help);
-       
-
-       // footer item: options menu
-       this.fitem_options_overlay = $(createDOM("DIV", {
-       "class":        "t3e_footer_overlay",
-       "id":           "t3e_footer_overlay_options"
-       }));
-       
-         // TODO make this more flexible! And get rid of inline css and unsed options!
-    this.fitem_options_overlay.innerHTML = '<ul>'+
-                               // '<li style="color:grey"><input type="checkbox" disabled="disabled" /> Syntax highlighting</li>'+ 
-                               '<li><input type="checkbox" onclick="t3e_instances['+this.index+'].fitem_options_overlay.hide();t3e_instances['+this.index+'].toggleAutoComplete();" id="t3e_autocomplete" checked="checked" /><label for="t3e_autocomplete">AutoCompletion</label></li>'+
-                               '<li><span onclick="t3e_instances['+this.index+'].fitem_options_overlay.hide();t3e_instances['+this.index+'].footeritem_demo_click();">Test snippets</span></li>'+
-                               '<li><input type="checkbox" onclick="t3e_instances['+this.index+'].fitem_options_overlay.hide();t3e_instances['+this.index+'].toggleFullscreen();" id="t3e_fullscreen" /> <label for="t3e_fullscreen">Fullscreen</label></li>'+
-                               // '<li style="color:grey"><input type="checkbox" disabled="disabled" /> other fancy stuff</li>'+
-                               '</ul>';
-    this.fitem_options_overlay.hide();
-    this.fitem_options = this.createFooterItem('Options', true, this.fitem_options_overlay);
-    this.footer_wrap.appendChild(this.fitem_options);
-    this.footer_wrap.appendChild(this.fitem_options_overlay);
-    
-       
-       // footer item: status field (total line numbers)
-    this.fitem_status = this.createFooterItem('', false);
-    this.footer_wrap.appendChild(this.fitem_status);
-    
-    // footer item: "name" of the document (taken from textarea alt-attribut), and save indicator
-    this.fitem_name = this.createFooterItem(this.documentname, false);
-    this.footer_wrap.appendChild(this.fitem_name);
-       
-       
-    
-       // window and document objects from the iframe
-       this.win = this.iframe.contentWindow;
-    this.doc = this.win.document;
-    
-       // make the iframe "editable"
-       this.doc.designMode = "on";
-    
-    this.doc.open();
-    this.doc.write("<html><head><link rel=\"stylesheet\" type=\"text/css\" href=\"" + t3eOptions.stylesheet + "\"/></head>" +
-                   "<body class=\"editbox\" spellcheck=\"false\"></body></html>");
-    this.doc.close();
-
-
-       // new Resizable(this.outerdiv,{handle:$(this.fitem_resize)});
-
-    // An array of known dirty nodes, nodes that have been modified
-    // since they were last parsed.
-    this.dirty = [];
-
-       // dimensions
-    this.width   = $(this.textarea).getDimensions().width;
-    this.height  = $(this.textarea).getDimensions().height;
-
-       var content = this.textarea.value;
-
-       // hide the textarea
-    this.textarea.hide();
-
-    // Some browsers immediately produce a <body> in a new <iframe>,
-    // others only do so later and fire an onload event when they do.
-    if (this.doc.body) {
-      this.init(content);
-    } else {
-      connect(this.iframe, "onload", bind(function(){disconnectAll(this.iframe, "onload"); this.init(content);}, this));
-    }
+               this.footer_wrap = new Element("DIV", {
+                               "class":        "t3e_footer_wrap"
+                       }
+               );
+               this.outerdiv.appendChild(this.footer_wrap);
+
+               // footer item: show help Window
+               // TODO make this more flexible! And get rid of inline css and unsed options!   
+               this.fitem_help = this.createFooterItem('Help', true, "this.toggleHelp()");
+               this.footer_wrap.appendChild(this.fitem_help);
+
+               // footer item: options menu
+               this.fitem_options_overlay = new Element("DIV", {
+                               "class":        "t3e_footer_overlay",
+                               "id":           "t3e_footer_overlay_options"
+                       }
+               );
+
+               // TODO make this more flexible! And get rid of inline css and unsed options!
+               this.fitem_options_overlay.innerHTML = '<ul>'+
+                       // '<li style="color:grey"><input type="checkbox" disabled="disabled" /> Syntax highlighting</li>'+ 
+                       '<li><input type="checkbox" onclick="t3e_instances['+this.index+'].fitem_options_overlay.hide();t3e_instances['+this.index+'].toggleAutoComplete();" id="t3e_autocomplete" checked="checked" /><label for="t3e_autocomplete">AutoCompletion</label></li>'+
+                       '<li><span onclick="t3e_instances['+this.index+'].fitem_options_overlay.hide();t3e_instances['+this.index+'].footeritem_demo_click();">Test snippets</span></li>'+
+                       '<li><input type="checkbox" onclick="t3e_instances['+this.index+'].fitem_options_overlay.hide();t3e_instances['+this.index+'].toggleFullscreen();" id="t3e_fullscreen" /> <label for="t3e_fullscreen">Fullscreen</label></li>'+
+                       // '<li style="color:grey"><input type="checkbox" disabled="disabled" /> other fancy stuff</li>'+
+                       '</ul>';
+               this.fitem_options_overlay.hide();
+               this.fitem_options = this.createFooterItem('Options', true, this.fitem_options_overlay);
+               this.footer_wrap.appendChild(this.fitem_options);
+               this.footer_wrap.appendChild(this.fitem_options_overlay);
+
+               // footer item: status field (total line numbers)
+               this.fitem_status = this.createFooterItem('', false);
+               this.footer_wrap.appendChild(this.fitem_status);
+
+               // footer item: "name" of the document (taken from textarea alt-attribut), and save indicator
+               this.fitem_name = this.createFooterItem(this.documentname, false);
+               this.footer_wrap.appendChild(this.fitem_name);
+
+               // window and document objects from the iframe
+               this.win = this.iframe.contentWindow;
+               this.doc = this.win.document;
+
+               // make the iframe "editable"
+               this.doc.designMode = "on";
+
+               this.doc.open();
+               this.doc.write(
+                       "<html><head>"+
+                       "<link rel=\"stylesheet\" type=\"text/css\" href=\"" + 
+                        t3eOptions.stylesheet + 
+                       "\"/></head>" +
+                       "<body class=\"editbox\" spellcheck=\"false\"></body></html>");
+               this.doc.close();
+
+               // An array of known 'dirty' nodes, nodes that have been modified
+               // since they were last parsed.
+               this.dirty = [];
+
+               // dimensions
+               this.width   = $(this.textarea).getDimensions().width;
+               this.height  = $(this.textarea).getDimensions().height;
+
+               var content = this.textarea.value;
+
+               // hide the textarea
+               this.textarea.hide();
+
+               // Some browsers immediately produce a <body> in a new <iframe>,
+               // others only do so later and fire an onload event when they do.
+               if (this.doc.body)      {
+                       this.init(content);
+               } else  {
+                       // connect(this.iframe, "onload", bind(function(){disconnectAll(this.iframe, "onload"); this.init(content);}, this));
+                       Event.observe(this.iframe, "load", function(){ this.init(content);}.bindAsEventListener(this));
+               }
   }
 
 
@@ -414,26 +444,26 @@ var t3editor = function(){
       this.container = this.doc.body;
       
          // fetch key press events
-         connect(this.doc, "onkeydown", method(this, "keyDown"));
-      connect(this.doc, "onkeyup", method(this, "keyUp"));
-         
-         // fetch scroll events for updateing line numbers
-         connect(this.doc, "onscroll", method(this, "scroll"));
-      connect(this.win, "onscroll", method(this, "scroll"));
-      
-      //fetch mouse click event
-      connect(this.doc, "onclick", method(this, "click"));
-    
-      // get the form object (needed for Ajax saving)
-      var form = $(this.textarea.form)
-         this.saveButtons = form.getInputs('submit', 'submit');
-
-      // initialize ajax saving events
-      this.saveAjaxEvent = this.saveAjax.bind(this);
-      this.saveButtons.each(function(button) {
-       Event.observe(button,'click',this.saveAjaxEvent);
-      }.bind(this));
-      
+                       Event.observe(this.doc, "keydown", this.keyDown.bindAsEventListener(this));
+                       Event.observe(this.doc, "keyup",   this.keyUp.bindAsEventListener(this));
+
+                       // fetch scroll events for updateing line numbers
+                       Event.observe(this.doc, "scroll", this.scroll.bindAsEventListener(this));
+                       Event.observe(this.win, "scroll", this.scroll.bindAsEventListener(this));
+
+                       // fetch mouse click event
+                       Event.observe(this.doc, "click", this.click.bindAsEventListener(this));
+
+                       // get the form object (needed for Ajax saving)
+                       var form = $(this.textarea.form)
+                       this.saveButtons = form.getInputs('submit', 'submit');
+
+                       // initialize ajax saving events
+                       this.saveAjaxEvent = this.saveAjax.bind(this);
+                       this.saveButtons.each(function(button) {
+                               Event.observe(button,'click',this.saveAjaxEvent);
+                       }.bind(this));
+
          // resize the editor
       this.resize(this.width, this.height);
          
@@ -465,8 +495,6 @@ var t3editor = function(){
                
                this.markCursorDirty();
                this.scheduleHighlight();
-
-               // this.doc.execCommand("undo", false, null);
        },
        
     // toggle between the textarea and t3editor
@@ -490,9 +518,10 @@ var t3editor = function(){
 
        // create an item for the footer line and connect an event
     createFooterItem: function(title, mouseover, clickAction)  {
-       var item = $(createDOM("DIV", {
-               "class":        "t3e_footer_item"
-       }));
+                       var item = new Element("DIV", {
+                                       "class":        "t3e_footer_item"
+                               }
+                       );
        item.innerHTML = title;
        
        if (mouseover) {
@@ -500,12 +529,11 @@ var t3editor = function(){
                Event.observe(item, "mouseover", function(e){Event.element(e).addClassName('t3e_footeritem_active');} );
                Event.observe(item, "mouseout",  function(e){Event.element(e).removeClassName('t3e_footeritem_active');} );
                }
-               
                if (typeof clickAction == 'object') { // display an overlay
                        Event.observe(item, "click",  function(e){ clickAction.toggle(); } );
                
                } else if (typeof clickAction == 'string' && clickAction != '') {       // execute a method
-                       connect(item, "onclick", method(this, clickAction+''));
+                       Event.observe(item, "click",  function(e){ eval(clickAction); }.bindAsEventListener(this) );
                }
                
        return item;
@@ -572,7 +600,7 @@ var t3editor = function(){
        
        toggleHelp: function()  {
                this.modalOverlay.toggle();
-               this.helpOverlay.toggle();\r
+               this.helpOverlay.toggle();
        },
 
     
@@ -779,7 +807,10 @@ var t3editor = function(){
         }
         //save code and text to history object
         obj.code = this.container.innerHTML;
-        obj.text = this.getCode();
+       
+       // TODO
+       /// obj.text = this.getCode();
+       
         // check if was undo/redo than refresh history array
         if (this.currHistoryPosition+1 < this.history.length){
             this.history = this.history.slice (0,this.currHistoryPosition+1);
@@ -850,7 +881,7 @@ var t3editor = function(){
             this.pushToHistory();
             return ;
         }
-        if (this.getCode(code) != this.history[this.currHistoryPosition].text){
+        if (code != this.history[this.currHistoryPosition].code){
             this.pushToHistory();
         }
         
@@ -913,14 +944,16 @@ var t3editor = function(){
     // Split a chunk of code into lines, put them in the frame, and
     // schedule them to be coloured.
     importCode: function(code) {
-      replaceChildNodes(this.container);
+               while ((child = this.container.firstChild)) {
+                               this.container.removeChild(child);
+                       }
 
       if (code == "\n" || code == "\r\n" || code == "\r"){code = '';}
       var lines = code.replace(/[ \t]/g, nbsp).replace(/\r\n?/g, "\n").split("\n");
 
       for (var i = 0; i != lines.length; i++) {
         if (i > 0)
-          this.container.appendChild(withDocument(this.doc, BR));
+          this.container.appendChild(this.win.document.createElement('BR'));
         var line = lines[i];
         if (line.length > 0)
           this.container.appendChild(this.doc.createTextNode(line));
@@ -943,16 +976,23 @@ var t3editor = function(){
         return "";
 
       var accum = [];
-      forEach(traverseDOM(this.container.firstChild), method(accum, "push"));
+      
+                       tdom = traverseDOM(this.container.firstChild);
+                       try     {
+                               while (tmp = tdom.next()) {
+                                       accum.push(tmp);
+                               }
+                       } catch(e)      {
+                               if (e != StopIteration) throw e;
+                       }
       return accum.join("").replace(nbspRegexp, " ");
     },
 
     // Intercept enter and any keys that are specified to re-indent
     // the current line.
     keyDown: function(event) {
-      var name = event.key().string;
-
-      if (name == "KEY_ENTER") {
+      var keycode = event.keyCode;
+      if (keycode == Event.KEY_RETURN) {
             event.stop();
                        if (this.ac === 1)      {
                this.insertCurrWordAtCursor();
@@ -962,33 +1002,34 @@ var t3editor = function(){
             }
             this.updateLinenum();
                        
-         } else if (name == "KEY_S" && event.modifier().ctrl) {        // save via ajax request
+         } else if (keycode == 83      && event.ctrlKey) {     // CTRL-S   save via ajax request
                this.saveAjax();
                event.stop();
                return;
                        
-      } else if (name == "KEY_F11" && event.modifier().ctrl) { // toogle fullscreen mode
+      } else if (keycode == 122        && event.ctrlKey)       {       // CTRL-F11 toogle fullscreen mode
                this.toggleFullscreen();
                event.stop();
                return;
                        
-      } else if (name == "KEY_SPACEBAR" && event.modifier().ctrl && this.options.autoComplete){ // call autocomplete if autocomplete turn on
+                       // TODO
+      } else if (keycode == 32 && event.ctrlKey && this.options.autoComplete){ // CTRL-Space  call autocomplete if autocomplete turn on
         this.autoComplete();
         event.stop();
-      } else if (name=="KEY_ARROW_UP" && this.ac == 1){ // move up cursor in autocomplete box
+      } else if (keycode == 38 && this.ac == 1){ // arrow up:  move up cursor in autocomplete box
         event.stop();
         window.setTimeout('t3e_instances['+this.index+'].autoCompleteBoxMoveUpCursor()',100);
-      } else if (name=="KEY_ARROW_DOWN" && this.ac == 1){ // move down cursor in autocomplete box
+      } else if (keycode == 40 && this.ac == 1){ // Arrow down: move down cursor in autocomplete box
         event.stop();
         window.setTimeout('t3e_instances['+this.index+'].autoCompleteBoxMoveDownCursor();',100);
-      } else if (name=="KEY_ESCAPE" && this.ac === 1){ // if autocomplete box is showing. by ESC press it's hide and autocomplete is finish
+      } else if (keycode == 27 && this.ac === 1){ // Esc: if autocomplete box is showing. by ESC press it's hide and autocomplete is finish
             this.ac = 0;
             this.autoCompleteBox.hide();
-      } else if (name=='KEY_Z' && event.modifier().ctrl){
+      } else if (keycode == 90 && event.ctrlKey){
          this.undoable = 1;
          this.undo();
          event.stop();
-      } else if (name=='KEY_Y' && event.modifier().ctrl){
+      } else if (keycode == 89 && event.ctrlKey){
          this.redoable = 1;
          this.redo();
          event.stop();
@@ -999,12 +1040,31 @@ var t3editor = function(){
     // mark the node at the cursor dirty when a non-safe key is
     // released.
     keyUp: function(event) {
-      var name = event.key().string;
+      // var name = event.key().string;
+      var keycode = event.keyCode;
+      
+      // TODO
+      /*
       if (this.options.reindentAfterKeys.hasOwnProperty(name))
         this.indentAtCursor();
-      else if (!this.options.safeKeys.hasOwnProperty(name)) {
+      else */ 
+      // TODO 
+      if (
+               keycode != 37 
+                       && keycode != 38 
+                       && keycode != 39
+                       && keycode != 40 
+                       && keycode != 35 
+                       && keycode != 36
+                       && keycode != 33
+                       && keycode != 34 
+                       && keycode != 16 
+                       && keycode != 17 
+                       && keycode != 18 
+                       && !event.ctrlKey) {
         this.markCursorDirty();
         this.checkTextModified();
+        window.setTimeout('t3e_instances['+this.index+'].checkHistoryChanges();',100);
          }
          
        if (this.ac===1){ // if autocomplete now is not finish, but started and continue typing - refresh autocomplete box
@@ -1016,7 +1076,9 @@ var t3editor = function(){
             }
        } 
       
-      if (name == "KEY_ENTER" || name == "KEY_BACKSPACE" || name == "KEY_DELETE" ){
+      if (keycode == Event.KEY_RETURN
+                        || keycode == Event.KEY_BACKSPACE
+                        || keycode == Event.KEY_DELETE )       {
           this.updateLinenum();
       }
        
@@ -1149,7 +1211,8 @@ var t3editor = function(){
         }
        // Otherwise, we have to add a new whitespace node.
         else {
-          whiteSpace = withDocument(this.doc, function(){return SPAN({"class": "part whitespace"}, repeatString(nbsp, indentDiff))});
+             whiteSpace = new Element('SPAN',{"class": "whitespace part"});
+                       whiteSpace.innerHTML = repeatString(nbsp, indentDiff);
           if (start)
             insertAfter(whiteSpace, start);
           else
@@ -1197,7 +1260,8 @@ var t3editor = function(){
     // should as unobtrusive as possible.
     scheduleHighlight: function() {
          if (this.highlightTimeout) clearTimeout(this.highlightTimeout);
-         this.highlightTimeout = setTimeout(bind(this.highlightDirty, this), this.options.passDelay);
+         this.highlightTimeout = setTimeout(this.highlightDirty.bind(this), this.options.passDelay);
+         
     },
 
     // Fetch one dirty node, and remove it from the dirty set.
@@ -1278,8 +1342,10 @@ var t3editor = function(){
     }
     // Create a part corresponding to a given token.
     function tokenPart(token){
-      var part = withDocument(document, partial(SPAN, {"class": "part " + token.style}, token.value));
-      part.currentText = token.value;
+      var part = new Element('SPAN',{"class": "part " + token.style});
+               part.update(token.value);
+               part.currentText = token.value;
+               part.innerHTML = token.value;
       return part;
     }
 
@@ -1340,7 +1406,9 @@ var t3editor = function(){
     // This forEach loops over the tokens from the parsed stream, and
     // at the same time uses the parts object to proceed through the
     // corresponding DOM nodes.
-    forEach(parsed, function(token){
+               try     {
+                       while (true)    { // stopped by StopIteration
+                               token = parsed.next();
       var part = parts.nextNonEmpty();
       if (token.value == "\n"){
        // The idea of the two streams actually staying synchronized
@@ -1401,10 +1469,17 @@ var t3editor = function(){
           }
         }
       }
-    });
+     }// while
+    } catch (e) {
+       if (e != StopIteration) {
+               throw e;
+       }
+       }
     this.refreshCursorObj();
     this.initable = 1;
-    window.setTimeout ('t3e_instances['+this.index+'].checkHistoryChanges();',100);
+    
+    // window.setTimeout('t3e_instances['+this.index+'].checkHistoryChanges();',100);
+    
     // The function returns some status information that is used by
     // hightlightDirty to determine whether and where it has to
     // continue.
@@ -1427,7 +1502,7 @@ function t3editor_toggleEditor(checkbox,index) {
                        function(textarea,i) {
                                t3editor_toggleEditor(checkbox,i);
                        }
-               );      \r
+               );      
        } else {
                if (t3e_instances[index] != undefined) {
                        var t3e = t3e_instances[index];
@@ -1435,7 +1510,7 @@ function t3editor_toggleEditor(checkbox,index) {
                } else if (!checkbox.checked) {
                        var t3e = new t3editor($$('textarea.t3editor')[index], index);
                        t3e_instances[index] = t3e;
-               }\r
+               }
        }       
 }