X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2Futil%2FPreprocessor.java;h=00ae93eddf2435df7cb598e8e7e5857657043762;hb=de378041d5ca2aca1a2b5a31ef15ae90a86c977f;hp=cc6d34db1b44da92621ff367da4171c637a75454;hpb=550183c89d7f6fa5152527450cd8c4b4dc2808e5;p=org.ibex.core.git diff --git a/src/org/xwt/util/Preprocessor.java b/src/org/xwt/util/Preprocessor.java index cc6d34d..00ae93e 100644 --- a/src/org/xwt/util/Preprocessor.java +++ b/src/org/xwt/util/Preprocessor.java @@ -1,4 +1,10 @@ -// Copyright 2003 Adam Megacz, see the COPYING file for licensing [GPL] +// Copyright (C) 2003 Adam Megacz all rights reserved. +// +// You may modify, copy, and redistribute this code under the terms of +// the GNU Library Public License version 2.1, with the exception of +// the portion of clause 6a after the semicolon (aka the "obnoxious +// relink clause") + package org.xwt.util; import java.util.*; @@ -148,13 +154,13 @@ PROCESS: } else if (trimmed.startsWith("//#switch")) { int expStart = trimmed.indexOf('(') +1; if (expStart < 1) { err.add(new Error("expected ( in #switch")); continue PROCESS; } - int expEnd = trimmed.indexOf(')'); + int expEnd = trimmed.lastIndexOf(')'); if (expEnd == -1) { err.add(new Error("expected ) in #switch")); continue PROCESS; } if (expEnd - expStart <= 1) { err.add(new Error("badly formed #switch statement")); continue PROCESS; } String expr = trimmed.substring(expStart, expEnd); - out.println("final String ccSwitch"+enumSwitch+" = (String)("+expr+");"+ - "switch(ccSwitch"+enumSwitch+".length()) {"); + out.println("final String ccSwitch"+enumSwitch+" = (String)("+expr+");"); + out.println("SUCCESS:do { switch(ccSwitch"+enumSwitch+".length()) {"); Hashtable[] byLength = new Hashtable[255]; String key = null; @@ -196,8 +202,9 @@ PROCESS: buildTrie("", byLength[i]); out.println("}; break; }"); } - if (Default != null) out.println("default: { " + Default + " }"); out.println("} //switch"); + if (Default != null) out.println(Default); + out.println("} while(false); //OUTER"); enumSwitch++; } else { @@ -231,7 +238,7 @@ PROCESS: String code = (String)cases.get(keys.elementAt(i)); code = code.substring(0, code.length() - 1); String key = (String)keys.elementAt(i); - out.println("if (\""+key+"\".equals(ccSwitch"+enumSwitch+")) { " + code + " } break; "); + out.println("if (\""+key+"\".equals(ccSwitch"+enumSwitch+")) { if (true) do { " + code + " } while(false); break SUCCESS; } break; "); } } }