upgraded xt some more
authoradam <adam@megacz.com>
Mon, 21 Feb 2005 09:25:43 +0000 (09:25 +0000)
committeradam <adam@megacz.com>
Mon, 21 Feb 2005 09:25:43 +0000 (09:25 +0000)
darcs-hash:20050221092543-5007d-043da89d1943d44ab80b8fbe91d77e817daf9fe0.gz

src/org/ibex/xt/Prevalence.java
src/org/ibex/xt/Servlet.java
src/org/ibex/xt/Template.java

index 7245386..cd7546f 100644 (file)
@@ -75,10 +75,10 @@ public class Prevalence {
     public static class JSTransaction implements Transaction {
         public static final long serialVersionUid = 0xfb2aa281;
         private JS js;
-        Template.Scope newscope;
+        Scope newscope;
         String[] v;
         public JSTransaction(JS js) throws JSExn {
-            newscope = new Template.Scope(null);
+            newscope = new Scope(null);
             this.js = JSU.cloneWithNewGlobalScope(js, newscope);
             v = this.js.getFormalArgs();
             for(int i=0; i<v.length; i++) {
index f00c387..7a2b58f 100644 (file)
@@ -49,7 +49,9 @@ public class Servlet extends HttpServlet {
         w.flush();
     }
 
-    public class ServletScope extends JS.Obj {
+    // ServletScope //////////////////////////////////////////////////////////////////////////////
+
+    public class ServletScope extends JSSubProperties {
         HttpServletRequest request;
         HttpServletResponse response;
         ServletContext cx;
@@ -60,103 +62,80 @@ public class Servlet extends HttpServlet {
             this.response = (HttpServletResponse)response;
             this.cx = cx;
         }
+
+        // FIXME: setattributes
+        //#repeat params/cookies/requestHeader/attributes \
+        //        getParameter/getCookie/getHeader/getAttribute \
+        //        getParameterNames/getCookieNames/getHeaderNames/getAttributeNames \
+        //        request/request/request/session/response \
+        //        setParameter/setCookie/setHeader/setAttribute
         private JS params = new JS.Obj() {
-                public JS get(JS key) throws JSExn { return JSU.S(request.getParameter(JSU.toString(key))); }
-                public Enumeration keys() throws JSExn { return new JS.Enumeration.JavaStringEnumeration(request.getParameterNames()); }
-            };
-        private JS cookies = new JS.Obj() {
-                /*
-                public Object get(Object key) { return request.getCookie(JSU.toString(key)); }
-                public Enumeration keys() { return request.getCookieNames(); }
-                */
-            };
-        private JS sessionAttributes = new JS.Obj() {
-                public JS get(JS key) throws JSExn { return JSU.S(request.getSession(true).getAttribute(JSU.toString(key)).toString()); }
-                public void put(JS key, JS val) throws JSExn {
-                    if (val == null) request.getSession(true).removeAttribute(JSU.toString(key));
-                    else request.setAttribute(JSU.toString(key), val); }
-                public Enumeration keys() throws JSExn { return new JS.Enumeration.JavaStringEnumeration(request.getSession(true).getAttributeNames()); }
-            };
-        private JS requestHeader = new JS.Obj() {
-                public JS get(JS key) throws JSExn { return JSU.S(request.getHeader(JSU.toString(key))); }
-                public Enumeration keys() throws JSExn { return new JS.Enumeration.JavaStringEnumeration(request.getHeaderNames()); }
-            };
-        private JS responseHeader = new JS.Obj() {
-                public void put(JS key, JS val) throws JSExn { response.setHeader(JSU.toString(key), JSU.toString(val)); }
+                public JS get(JS key) throws JSExn { return JSU.S(request.getParameter(JSU.toString(key)).toString()); }
+                public void put(JS key, JS val) throws JSExn { request.setParameter(JSU.toString(key), JSU.toString(val)); }
+                public Enumeration keys() throws JSExn {
+                    return new JS.Enumeration.JavaStringEnumeration(request.getParameterNames()); }
             };
+        //#end
 
-
-        /** lets us put multi-level get/put/call keys all in the same method */
-        private class Sub extends JS.Obj {
-            JS key;
-            Sub(JS key) { this.key = key; }
-            public void put(JS key, JS val) throws JSExn {
-                ServletScope.this.put(JSU.S(JSU.toString(this.key) + "." + JSU.toString(key)), val); }
-            public JS get(JS key) throws JSExn {
-                return ServletScope.this.get(JSU.S(JSU.toString(this.key) + "." + JSU.toString(key))); }
-            public JS call(JS method, JS[] args) throws JSExn {
-                return ServletScope.this.call(JSU.S(JSU.toString(this.key) + "." + JSU.toString(method)), args);
-            }
-        }
-        private Sub getSub(String key) { return new Sub(JSU.S(key)); }
-
-        public JS call(JS method, JS[] args) throws JSExn {
-            //#switch(JSU.toString(method))
-            case "session.invalidate":    request.getSession(true).invalidate(); return null;
-            case "context.list":
-                String path = JSU.toString(args[0]);
-                if (path.indexOf("..") != -1) throw new JSExn("cannot use .. in paths");
-                File f = new File(cx.getRealPath("/") + File.separatorChar + path);
-                if (!f.isDirectory()) return null;
-                String[] contents = f.list();
-                JSArray ret = new JSArray(contents.length);
-                for(int i=0; i<contents.length; i++) ret.put(JSU.N(ret.size()), JSU.S(contents[i]));
-                return ret;
-            //#end
-            return null;
-        }
-        public JS get(JS key) throws JSExn {
+        public JS _get(JS key) throws JSExn {
             //#switch(JSU.toString(key))
             case "body":
             case "arg":                   return null;
             case "prevalent":             return (JS)prevayler.prevalentSystem();
-            case "request":               return getSub("request");
+            case "request":               return SUBPROPERTY;
             case "request.user":          return JSU.S(request.getRemoteUser());
             case "request.header":        return requestHeader;
             case "request.method":        return JSU.S(request.getMethod());
-            case "request.remote":        return getSub("request.remote");
+            case "request.remote":        return SUBPROPERTY;
             case "request.remote.ip":     return JSU.S(request.getRemoteAddr());
             case "request.remote.host":   return JSU.S(request.getRemoteHost());
             case "request.ssl":           return JSU.B(request.isSecure());
             case "request.path":          return JSU.S(request.getPathInfo());
-            case "response":              return getSub("response");
+            case "response":              return SUBPROPERTY;
             case "response.header":       return responseHeader;
-            case "session":               return getSub("session");
+            case "session":               return SUBPROPERTY;
             case "session.attr":          return sessionAttributes;
             case "session.created":       return new JSDate(request.getSession(true).getCreationTime());
             case "session.accessed":      return new JSDate(request.getSession(true).getLastAccessedTime());
             case "session.invalidate":    return METHOD;
-            case "page":                  return getSub("page");
+            case "page":                  return SUBPROPERTY;
             case "page.lastmodified":     return new JSDate(new File(path).lastModified());
-            case "context":               return getSub("context");
+            case "context":               return SUBPROPERTY;
             case "context.list":          return METHOD;
             case "params":                return params;
             case "cookie":                return cookies;
             //#end
             return null;
         }
+
         public void put(JS key, JS val) throws JSExn {
             try {
             //#switch(JSU.toString(key))
-            case "transaction":
-                try { prevayler.execute(new Prevalence.JSTransaction((JS)val));
-                } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(e); }
             case "response.code":         response.setStatus(JSU.toInt(val));
             case "response.redirect":     response.sendRedirect(JSU.toString(val));
             case "response.contentType":  response.setContentType(JSU.toString(val));
+            case "transaction":
+                try { prevayler.execute(new Prevalence.JSTransaction((JS)val));
+                } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(e); }
             //#end
             } catch (IOException e) { throw new JSExn(JSU.S(e.toString())); }
         }
+
+        public JS call(JS method, JS[] args) throws JSExn {
+            //#switch(JSU.toString(method))
+            case "session.invalidate":    request.getSession(true).invalidate(); return null;
+            case "context.list":
+                String path = JSU.toString(args[0]);
+                if (path.indexOf("..") != -1) throw new JSExn("cannot use .. in paths");
+                File f = new File(cx.getRealPath("/") + File.separatorChar + path);
+                if (!f.isDirectory()) return null;
+                String[] contents = f.list();
+                JSArray ret = new JSArray(contents.length);
+                for(int i=0; i<contents.length; i++) ret.put(JSU.N(ret.size()), JSU.S(contents[i]));
+                return ret;
+            //#end
+            return null;
+        }
     }
 
 }
index 3a492af..000670f 100644 (file)
@@ -158,24 +158,6 @@ public class Template extends Node.Stream.Filter implements Node.Stream.Functor
         }
     }
 
-    public static class Scope extends JS.Obj {
-        private final JS parent;
-        private final Hash declared = new Hash();
-        public Scope(JS parent) { this.parent = parent; }
-        public JS get(JS key) throws JSExn {
-            if (declared.get(key)!=null) return super.get(key);
-            return parent.get(key);
-        }
-        public void put(JS key, JS val) throws JSExn {
-            if (declared.get(key)!=null) super.put(key, val);
-            else parent.put(key, val);
-        }
-        public void declare(JS key) { declared.put(key, Boolean.TRUE); }
-        public void declare(String key) { declare(JSU.S(key)); }
-        public void undeclare(JS key) { declared.remove(key); }
-        public void undeclare(String key) { undeclare(JSU.S(key)); }
-    }
-
     private class DropTag implements Node.Stream.Functor {
         public Node.Stream wrap(Node.Stream kids) {
             return kids;