Ignore:
Timestamp:
Dec 21, 2009, 1:11:35 AM (15 years ago)
Author:
broder
Message:

Allow reconnecting to the same terminal session

Location:
package_branches/invirt-web/ajaxterm-rebased/code
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • package_branches/invirt-web/ajaxterm-rebased/code/ajaxterm.py

    r2749 r2753  
    321321        def dumplatin1(self):
    322322                return self.dump().translate(self.trl1)
    323         def dumphtml(self,color=1):
     323        def dumphtml(self,color=1,force=False):
    324324                h=self.height
    325325                w=self.width
     
    344344                                span+='\n'
    345345                r='<?xml version="1.0" encoding="ISO-8859-1"?><pre class="term">%s</pre>'%r
    346                 if self.last_html==r:
     346                if self.last_html==r and not force:
    347347                        return '<?xml version="1.0"?><idem></idem>'
    348348                else:
     
    437437                except (IOError,OSError):
    438438                        self.proc_kill(fd)
    439         def dump(self,fd,color=1):
     439        def dump(self,fd,color=1,force=False):
    440440                try:
    441                         return self.proc[fd]['term'].dumphtml(color)
     441                        return self.proc[fd]['term'].dumphtml(color, force)
    442442                except KeyError:
    443443                        return False
  • package_branches/invirt-web/ajaxterm-rebased/code/main.py

    r2752 r2753  
    408408
    409409        @cherrypy.expose
    410         def at(self, machine_id, k=None, c=0):
     410        def at(self, machine_id, k=None, c=0, force=0):
    411411            machine = validation.Validate(cherrypy.request.login, cherrypy.request.state, machine_id=machine_id).machine
    412412            if machine_id in self.atsessions:
     
    420420                self.atmulti.proc_write(term,k)
    421421            time.sleep(0.002)
    422             dump=self.atmulti.dump(term,c)
     422            dump=self.atmulti.dump(term,c,int(force))
    423423            cherrypy.response.headers['Content-Type']='text/xml'
    424424            if isinstance(dump,str):
    425425                return dump
    426426            else:
     427                print "Removing session for", machine_id
    427428                del self.atsessions[machine_id]
    428429                return '<?xml version="1.0"?><idem></idem>'
  • package_branches/invirt-web/ajaxterm-rebased/code/static/ajaxterm/ajaxterm.js

    r2752 r2753  
    1313        var sending=0;
    1414        var rmax=1;
     15        var force=true;
    1516
    1617        var div=document.getElementById(id);
     
    103104                        }
    104105                        var query=query1+send;
     106                        if (force) {
     107                            query=query+"&force=1";
     108                            force=false;
     109                        }
    105110                        if(opt_get.className=='on') {
    106111                                r.open("GET",base_path+"?"+query,true);
     
    270275                document.onkeypress=keypress;
    271276                document.onkeydown=keydown;
     277                force=true;
    272278                timeout=window.setTimeout(update,100);
    273279        }
Note: See TracChangeset for help on using the changeset viewer.