]> matita.cs.unibo.it Git - helm.git/blobdiff - matitaB/matita/matitaweb.js
Removed hardcoded include paths from matitadaemon.
[helm.git] / matitaB / matita / matitaweb.js
index 588643861f3c7b178e2019c05fc378febb63060c..ecb0133c3d31f3de5f4edcafd34fd71a20f17d60 100644 (file)
@@ -149,31 +149,29 @@ function p33 (p)
   return (tripletmap (function (a,b,c) { return (c); }, p));
 }
 
-function populate_goalarray(txt)
+function populate_goalarray(menv)
 {
-  if (txt == "") {
+  debug("metasenv.length = " + menv.length);
+  if (menv.length == 0) {
       try {
           hideSequent();
       } catch (err) { };
   } else {
       showSequent();
-      debug("populate with '" + txt + "'");
       goalarray = new Array();
       metalist = listnil();
       var tmp_goallist = "";
-      listiter (function(item)
-        {
-         debug ("item is '" + item + "'");
-         tripletmap (function(a,ahtml,b) {   
-          debug ("found meta n. " + a);
-          debug ("found goal\nBEGIN" + unescape(b) + "\nEND");
-          goalarray[a] = unescape(b);
-          tmp_goallist = " <A href=\"javascript:switch_goal(" + a + ")\">" + unescape(ahtml) + "</A>" + tmp_goallist;
-          metalist = listcons(a,metalist);
-          debug ("goalarray[\"" + a + "\"] = " + goalarray[a]); 
-         },item);
-        }, txt);
-      // metalist = listmap (p13,txt);
+      for (i = 0; i < menv.length; i++) {
+        metano = menv[i].getAttribute("number");
+       metaname = menv[i].childNodes[0].childNodes[0].data;
+       goal = menv[i].childNodes[1].childNodes[0].data;
+        debug ("found meta n. " + metano);
+        debug ("found goal\nBEGIN" + goal + "\nEND");
+        goalarray[metano] = goal;
+        tmp_goallist = " <A href=\"javascript:switch_goal(" + metano + ")\">" + metaname + "</A>" + tmp_goallist;
+        metalist = listcons(metano,metalist);
+        debug ("goalarray[\"" + metano + "\"] = " + goalarray[metano]); 
+      }
       goals.innerHTML = tmp_goallist;
       debug("new metalist is '" + metalist + "'");
       if (is_nil(metalist)) {
@@ -196,6 +194,19 @@ function switch_goal(meta)
   }
 }
 
+String.prototype.sescape = function() {
+       var patt1 = /%/gi;
+       var patt2 = /=/gi;
+       var patt3 = /&/gi;
+       var patt4 = /\+/gi;
+       var result = this;
+       result = result.replace(patt1,"%25");
+       result = result.replace(patt2,"%3D");
+       result = result.replace(patt3,"%26");
+       result = result.replace(patt4,"%2B");
+       return (result);
+}
+
 String.prototype.unescapeHTML = function()
 {
        var patt1 = /<br(\/|)>/gi;
@@ -263,15 +274,26 @@ function callServer(servicename,processResponse,reqbody)
                        stat = req.status;
                        stxt = req.statusText;
                        if(stat == 200)
-                       {       
-                               processResponse(req.responseText);
+                       {
+                         debug(req.responseText);
+                         if (window.DOMParser) {
+                            parser=new DOMParser();
+                            xmlDoc=parser.parseFromString(req.responseText,"text/xml");
+                          }
+                         else // Internet Explorer
+                          {
+                            xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
+                            xmlDoc.async="false";
+                            xmlDoc.loadXML(req.responseText);
+                          }    
+                         processResponse(xmlDoc);
                        } else {
-                               processResponse();
+                         processResponse();
                        }
-                       // resume();
                } 
        };
-       req.open("POST", servicename); // + escape(unlocked.innerHTML), true); 
+       req.open("POST", servicename); // + escape(unlocked.innerHTML), true);
+        req.setRequestHeader("Content-type","application/x-www-form-urlencoded");      
        if (reqbody) {
                req.send(reqbody); 
        } else {
@@ -282,11 +304,10 @@ function callServer(servicename,processResponse,reqbody)
 
 function advanceForm1()
 {
-       processor = function(responseText) {
-               if (is_defined(responseText)) {
+       processor = function(xml) {
+               if (is_defined(xml)) {
                        // debug("advance: received response\nBEGIN\n" + req.responseText + "\nEND");
-                       response = responseText.split("@");
-                       len = parseInt(response[0]);
+                       len = parseInt(xml.getElementsByTagName("parsed")[0].getAttribute("length"));
                        len0 = unlocked.innerHTML.length;
                        unescaped = unlocked.innerHTML.unescapeHTML();
                        parsedtxt = unescaped.substr(0,len); 
@@ -295,8 +316,8 @@ function advanceForm1()
                        unlocked.innerHTML = unparsedtxt;
                        len1 = unlocked.innerHTML.length;
                        len2 = len0 - len1;
-                       metasenv = response[1];
-                       populate_goalarray(response[1]);
+                       metasenv = xml.getElementsByTagName("meta");
+                       populate_goalarray(metasenv);
                        statements = listcons(len2,statements);
                        unlocked.scrollIntoView(true);
                } else {
@@ -305,35 +326,35 @@ function advanceForm1()
                resume();
        };
        pause();
-        callServer("advance",processor,unlocked.innerHTML.unescapeHTML());
+        callServer("advance",processor,"body=" + (unlocked.innerHTML.unescapeHTML()).sescape());
   
 }
 
 function gotoBottom()
 {
-       processor = function(responseText) {
-               if (is_defined(responseText)) {
+       processor = function(xml) {
+               if (is_defined(xml)) {
                        // debug("goto bottom: received response\nBEGIN\n" + req.responseText + "\nEND");
-                       response = responseText.split("@");
-                       len = parseInt(response[0]);
-                        len0 = unlocked.innerHTML.length;
+                       len = parseInt(xml.getElementsByTagName("parsed")[0].getAttribute("length"));
+                       len0 = unlocked.innerHTML.length;
                        unescaped = unlocked.innerHTML.unescapeHTML();
                        parsedtxt = unescaped.substr(0,len); 
                        unparsedtxt = unescaped.substr(len);
                        locked.innerHTML = locked.innerHTML + parsedtxt;
                        unlocked.innerHTML = unparsedtxt;
                        len1 = unlocked.innerHTML.length;
-                       len = len0 - len1;
-                        populate_goalarray(response[1]);
-                       statements = listcons(len,statements);
-                        unlocked.scrollIntoView(true);
+                       len2 = len0 - len1;
+                       metasenv = xml.getElementsByTagName("meta");
+                       populate_goalarray(metasenv);
+                       statements = listcons(len2,statements);
+                       unlocked.scrollIntoView(true);
                } else {
                        debug("goto bottom failed");
                } 
                 resume();
        };
        pause();
-       callServer("bottom",processor,unlocked.innerHTML.unescapeHTML());
+       callServer("bottom",processor,"body=" + (unlocked.innerHTML.unescapeHTML()).sescape());
   
 }
 
@@ -343,11 +364,10 @@ function gotoPos(offset)
         if (!is_defined(offset)) {
                offset = getCursorPos();
         }
-       processor = function(responseText) {
-               if (is_defined(responseText)) {
-                       // debug("advance: received response\nBEGIN\n" + req.responseText + "\nEND");
-                       response = responseText.split("@");
-                       len = parseInt(response[0]);
+       processor = function(xml) {
+               if (is_defined(xml)) {
+                       // debug("goto pos: received response\nBEGIN\n" + req.responseText + "\nEND");
+                       len = parseInt(xml.getElementsByTagName("parsed")[0].getAttribute("length"));
                        len0 = unlocked.innerHTML.length;
                        unescaped = unlocked.innerHTML.unescapeHTML();
                        parsedtxt = unescaped.substr(0,len); 
@@ -356,11 +376,13 @@ function gotoPos(offset)
                        unlocked.innerHTML = unparsedtxt;
                        len1 = unlocked.innerHTML.length;
                        len2 = len0 - len1;
+                       metasenv = xml.getElementsByTagName("meta");
+                       // populate_goalarray(metasenv);
                        statements = listcons(len2,statements);
-                       metasenv = response[1];
+                       unlocked.scrollIntoView(true);
                        // la populate non andrebbe fatta a ogni passo
                        if (offset <= len) {
-                               populate_goalarray(response[1]);
+                               populate_goalarray(metasenv);
                                resume();
                        } else {
                                gotoPos(offset - len);
@@ -372,21 +394,22 @@ function gotoPos(offset)
                }
        }
        pause();
-       callServer("advance",processor,unlocked.innerHTML.unescapeHTML());
+       callServer("advance",processor,"body=" + (unlocked.innerHTML.unescapeHTML()).sescape());
 }
 
 function retract()
 {
-       processor = function(responseText) {
-               if (typeof responseText != "undefined") {
-                debug("retract: received response\nBEGIN\n" + responseText + "\nEND");
+       processor = function(xml) {
+               if (typeof xml != "undefined") {
+                       // debug("advance: received response\nBEGIN\n" + req.responseText + "\nEND");
                        statementlen = parseInt(listhd(statements));
                         statements = listtl(statements);
                         lockedlen = locked.innerHTML.length - statementlen;
                        statement = locked.innerHTML.substr(lockedlen, statementlen);
                         locked.innerHTML = locked.innerHTML.substr(0,lockedlen);
                        unlocked.innerHTML = statement + unlocked.innerHTML;
-                        populate_goalarray(responseText);
+                       metasenv = xml.getElementsByTagName("meta");
+                        populate_goalarray(metasenv);
                         unlocked.scrollIntoView(true);
                } else {
                        debug("retract failed");
@@ -401,16 +424,16 @@ function retract()
 
 function openFile()
 { 
-       processor = function(responseText)
+       processor = function(xml)
        {
-               if (responseText) {     
+               if (is_defined(xml)) {  
                        locked.innerHTML = "";
-                       unlocked.innerHTML = responseText;
+                       unlocked.innerHTML = xml.documentElement.firstChild.data;
                } else {
                        debug("file open failed");
                }
        };
-       callServer("open?file=" + escape(filename.value),processor); 
+       callServer("open",processor,"file=" + escape(filename.value)); 
 }
 
 var goalcell;