X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Fjava%2Forg%2Fibex%2Fxt%2FTemplate.java;h=8456f611ed7ea9bd7148874d779d31b22a9defd3;hb=aa4748b4f5c375bedcfac257b684a59906c6f03a;hp=445a6ee66a32674b6b825069db887b75b4bf39f4;hpb=6649e6f6761b25310be908ef2101a1efadc537ff;p=org.ibex.xt-crawshaw.git diff --git a/src/java/org/ibex/xt/Template.java b/src/java/org/ibex/xt/Template.java index 445a6ee..8456f61 100644 --- a/src/java/org/ibex/xt/Template.java +++ b/src/java/org/ibex/xt/Template.java @@ -36,7 +36,7 @@ public class Template extends JSElement { //#switch(uri.substring(19)) case "io": System.out.println("ibex.xt.io not yet implemented"); // TODO //#end - //throw new RuntimeException("Unknown XT library: "+uri); + //throw new JSElement.Exn("Unknown XT library: "+uri); } else if (uri.startsWith("local:")) { Template t = parse(s.getLocalPath() + uri.substring(6), s); @@ -45,7 +45,7 @@ public class Template extends JSElement { if (c.size() > 0) { // move all children from e to placeholder XML.Element placeholder = findPlaceholder(t); - if (placeholder == null) throw new RuntimeException( + if (placeholder == null) throw new JSElement.Exn( "<"+e.getQName()+"> attempted to include children into a " + "template which does not contain an tag."); @@ -102,7 +102,7 @@ public class Template extends JSElement { try { Object varIf = get("if"); if (varIf != null) undeclare("if"); if (varIf != null && !"true".equals(varIf)) return; - } catch (JSExn e) { throw new RuntimeException(e); } + } catch (JSExn e) { throw new JSElement.Exn(e); } wrapped.out(w); } @@ -113,7 +113,7 @@ public class Template extends JSElement { super(e); List c = getChildren(); for (int i=0; i < c.size(); i++) - if (c.get(i) instanceof XML.Element) throw new RuntimeException( + if (c.get(i) instanceof XML.Element) throw new JSElement.Exn( "<"+getPrefix()+":js> tags may not have child elements"); } @@ -138,16 +138,16 @@ public class Template extends JSElement { Object varPut = get("put"); if (varPut != null) undeclare("put"); varIn = exec("return (" + varIn + ");"); - if (varIn == null || (varIn instanceof JSArray)) throw new RuntimeException( + if (varIn == null || (varIn instanceof JSArray)) throw new JSElement.Exn( "<"+getPrefix()+":foreach> requires attribute 'in' to specify " + "the name of a valid js array in the current scope, not in='"+varIn+"'."); if (varPut == null) varPut = "x"; else if (!(varPut instanceof String) || get(varPut) != null) - throw new RuntimeException( + throw new JSElement.Exn( "<"+getPrefix()+":foreach> 'put' attribute requires the name of "+ "an undeclared variable, not put='"+varPut+"'."); - if (get(varPut) != null) throw new RuntimeException( + if (get(varPut) != null) throw new JSElement.Exn( "<"+getPrefix()+":foreach> has no 'put' attribute defined and the "+ "default variable 'x' already exists in the current scope."); @@ -158,7 +158,7 @@ public class Template extends JSElement { put(varPut, it.next()); for (int i=0; i < c.size(); i++) ((Tree.Leaf)c.get(i)).out(w); } - } catch (JSExn e) { throw new RuntimeException(e); } + } catch (JSExn e) { throw new JSElement.Exn(e); } } } @@ -184,11 +184,6 @@ public class Template extends JSElement { } } - public static final class Java extends JSElement { - // TODO what exactly? - public Java(XML.Element w) { super(w); } - } - public abstract static class Scope extends JSScope { public Scope(JSScope j) { super(j); } @@ -199,4 +194,11 @@ public class Template extends JSElement { public abstract void transaction(JS t); } + public static class Signal extends RuntimeException {} + public static class ReturnSignal extends Signal { } + public static class RedirectSignal extends Signal { + protected String target; + public RedirectSignal(String target) { super(); this.target = target; } + public String getTarget() { return target; } + } }