Index: trunk/web/templates/help.tmpl
===================================================================
--- trunk/web/templates/help.tmpl	(revision 139)
+++ trunk/web/templates/help.tmpl	(revision 139)
@@ -0,0 +1,16 @@
+#from skeleton import skeleton
+#extends skeleton
+
+#def title
+Help
+#end def
+
+
+#def body
+#if not $simple
+<h1>Help</h1>
+#end if
+#for $subject in $subjects
+<p>$mapping[$subject]</p>
+#end for
+#end def
Index: trunk/web/templates/list.tmpl
===================================================================
--- trunk/web/templates/list.tmpl	(revision 138)
+++ trunk/web/templates/list.tmpl	(revision 139)
@@ -80,5 +80,5 @@
 	</tr>
 	<tr>
-	  <td>HVM/ParaVM</td>
+	  <td>HVM/ParaVM$helppopup('hvm_paravm')</td>
 	  <td>
 	    <input checked type="radio" name="vmtype" value="hvm">HVM</input>
Index: trunk/web/templates/main.py
===================================================================
--- trunk/web/templates/main.py	(revision 138)
+++ trunk/web/templates/main.py	(revision 139)
@@ -25,4 +25,12 @@
     pass
 
+def helppopup(subj):
+    return '<span class="helplink"><a href="help?subject='+subj+'&amp;simple=true" target="_blank" onclick="return helppopup(\''+subj+'\')">(?)</a></span>'
+
+
+global_dict = {}
+global_dict['helppopup'] = helppopup
+
+
 # ... and stolen from xend/uuid.py
 def randomUUID():
@@ -48,5 +56,5 @@
 def error(op, user, fields, err):
     d = dict(op=op, user=user, errorMessage=str(err))
-    print Template(file='error.tmpl', searchList=d);
+    print Template(file='error.tmpl', searchList=[d, global_dict]);
 
 def validMachineName(name):
@@ -268,5 +276,5 @@
              machine=machine)
     print Template(file='create.tmpl',
-                   searchList=d);
+                   searchList=[d, global_dict]);
 
 def listVms(user, fields):
@@ -282,6 +290,5 @@
             has_vnc[m.name] = True
         else:
-            help_name = 'paravm_console'
-            has_vnc[m.name] = 'ParaVM <span class="helplink"><a href="help?subject=%s&amp;simple=true" target="_blank" onclick="return helppopup(\'%s\')">(?)</a></span>' % (help_name, help_name)
+            has_vnc[m.name] = "ParaVM"+helppopup("paravm_console")
     #     for m in machines:
     #         status = statusInfo(m)
@@ -295,5 +302,5 @@
              uptimes=uptimes,
              cdroms=CDROM.select())
-    print Template(file='list.tmpl', searchList=d)
+    print Template(file='list.tmpl', searchList=[d, global_dict])
 
 def testMachineId(user, machineId, exists=True):
@@ -346,5 +353,5 @@
              authtoken=token)
     print Template(file='vnc.tmpl',
-                   searchList=d)
+                   searchList=[d, global_dict])
 
 def getNicInfo(data_dict, machine):
@@ -421,8 +428,29 @@
              command=action,
              machine=machine)
-    print Template(file="command.tmpl", searchList=d)
+    print Template(file="command.tmpl", searchList=[d, global_dict])
         
 def modify(user, fields):
     machine = testMachineId(user, fields.getfirst('machine_id'))
+    
+def help(user, fields):
+    simple = fields.getfirst('simple')
+    subjects = fields.getlist('subject')
+    
+    mapping = dict(paravm_console="""
+ParaVM machines do not support console access over VNC.  To access
+these machines, you either need to boot with a liveCD and ssh in or
+hope that the sipb-xen maintainers add support for serial consoles.""",
+                   hvm_paravm="""
+HVM machines use the virtualization features of the processor, while
+ParaVM machines use Xen's emulation of virtualization features.  You
+want an HVM virtualized machine.""",
+                   cpu_weight="""Don't ask us!  We're as mystified as you are.""")
+    
+    d = dict(user=user,
+             simple=simple,
+             subjects=subjects,
+             mapping=mapping)
+    
+    print Template(file="help.tmpl", searchList=[d, global_dict])
     
 
@@ -452,5 +480,5 @@
                       'DISK_INFO',
                       ('state', 'state (xen format)'),
-                      ('cpu_weight', 'CPU weight'),
+                      ('cpu_weight', 'CPU weight'+helppopup('cpu_weight')),
                       ('on_reboot', 'Action on VM reboot'),
                       ('on_poweroff', 'Action on VM poweroff'),
@@ -497,5 +525,5 @@
              fields = fields)
     print Template(file='info.tmpl',
-                   searchList=d)
+                   searchList=[d, global_dict])
 
 mapping = dict(list=listVms,
@@ -504,5 +532,6 @@
                modify=modify,
                info=info,
-               create=create)
+               create=create,
+               help=help)
 
 if __name__ == '__main__':
@@ -513,5 +542,4 @@
         email = 'moo@cow.com'
     u = User()
-    connect('postgres://sipb-xen@sipb-xen-dev/sipb_xen')
     operation = os.environ.get('PATH_INFO', '')
     if not operation:
@@ -528,4 +556,6 @@
                           error(operation, u, e,
                                 "Invalid operation '%s'" % operation))
+    if fun not in (help, ):
+        connect('postgres://sipb-xen@sipb-xen-dev/sipb_xen')
     try:
         fun(u, fields)
Index: trunk/web/templates/skeleton.py
===================================================================
--- trunk/web/templates/skeleton.py	(revision 138)
+++ trunk/web/templates/skeleton.py	(revision 139)
@@ -34,8 +34,8 @@
 __CHEETAH_version__ = '2.0rc8'
 __CHEETAH_versionTuple__ = (2, 0, 0, 'candidate', 8)
-__CHEETAH_genTime__ = 1191718104.9039481
-__CHEETAH_genTimestamp__ = 'Sat Oct  6 20:48:24 2007'
+__CHEETAH_genTime__ = 1191828896.641397
+__CHEETAH_genTimestamp__ = 'Mon Oct  8 03:34:56 2007'
 __CHEETAH_src__ = 'skeleton.tmpl'
-__CHEETAH_srcLastModified__ = 'Sat Oct  6 20:18:06 2007'
+__CHEETAH_srcLastModified__ = 'Mon Oct  8 03:34:52 2007'
 __CHEETAH_docstring__ = 'Autogenerated by CHEETAH: The Python-Powered Template Engine'
 
@@ -88,17 +88,44 @@
         _v = VFFSL(SL,"title",True) # '$title' on line 2, col 14
         if _v is not None: write(_filter(_v, rawExpr='$title')) # from line 2, col 14.
-        write('''</title></head>
+        write('''</title>
+  <link href="/static/favicon.ico" type="image/x-icon" rel="shortcut icon">
+  <style media="screen" type="text/css">
+    @import "static/css/all.css";
+  </style>
+  <script type="text/javascript">
+var helpWin = null;
+function closeWin(){
+\tif (helpWin != null){
+\t\tif(!helpWin.closed)
+\t\t\thelpWin.close();
+\t}
+}
+
+function helppopup(name){
+   closeWin()
+   helpWin = window.open("help?simple=true&subject="+encodeURIComponent(name), "HMMTHelp",
+"status, height = 300, width = 400");
+   if (window.focus){helpWin.focus();}
+   return false;
+}
+</script>
+</head>
 <body>
-<p>[You are logged in as ''')
-        _v = VFFSL(SL,"user.username",True) # '$user.username' on line 4, col 26
-        if _v is not None: write(_filter(_v, rawExpr='$user.username')) # from line 4, col 26.
-        write('''.]</p>
 ''')
-        _v = VFFSL(SL,"body",True) # '$body' on line 5, col 1
-        if _v is not None: write(_filter(_v, rawExpr='$body')) # from line 5, col 1.
+        if not VFFSL(SL,"varExists",False)('simple') or not VFFSL(SL,"simple",True): # generated from line 26, col 1
+            write('''<p>[You are logged in as ''')
+            _v = VFFSL(SL,"user.username",True) # '$user.username' on line 27, col 26
+            if _v is not None: write(_filter(_v, rawExpr='$user.username')) # from line 27, col 26.
+            write('''.]</p>
+''')
+        _v = VFFSL(SL,"body",True) # '$body' on line 29, col 1
+        if _v is not None: write(_filter(_v, rawExpr='$body')) # from line 29, col 1.
         write('''
-<hr />
+''')
+        if not VFFSL(SL,"varExists",False)('simple') or not VFFSL(SL,"simple",True): # generated from line 30, col 1
+            write('''<hr />
 Questions? Contact <a href="mailto:sipb-xen-dev@mit.edu">sipb-xen-dev@mit.edu</a>.
-</body>
+''')
+        write('''</body>
 </html>
 ''')
Index: trunk/web/templates/skeleton.tmpl
===================================================================
--- trunk/web/templates/skeleton.tmpl	(revision 138)
+++ trunk/web/templates/skeleton.tmpl	(revision 139)
@@ -1,9 +1,35 @@
 <html>
-<head><title>$title</title></head>
+<head><title>$title</title>
+  <link href="/static/favicon.ico" type="image/x-icon" rel="shortcut icon">
+  <style media="screen" type="text/css">
+    @import "static/css/all.css";
+  </style>
+  <script type="text/javascript">
+var helpWin = null;
+function closeWin(){
+	if (helpWin != null){
+		if(!helpWin.closed)
+			helpWin.close();
+	}
+}
+
+function helppopup(name){
+   closeWin()
+   helpWin = window.open("help?simple=true&subject="+encodeURIComponent(name), "HMMTHelp",
+"status, height = 300, width = 400");
+   if (window.focus){helpWin.focus();}
+   return false;
+}
+</script>
+</head>
 <body>
+#if not $varExists('simple') or not $simple
 <p>[You are logged in as $user.username.]</p>
+#end if
 $body
+#if not $varExists('simple') or not $simple
 <hr />
 Questions? Contact <a href="mailto:sipb-xen-dev@mit.edu">sipb-xen-dev@mit.edu</a>.
+#end if
 </body>
 </html>
