/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package evalexpr;
/**
* JSR 199 Demo application: compile from a String.
*
* <p><b>This is NOT part of any supported API.
* If you write code that depends on this, you do so at your own
* risk. This code and its internal interfaces are subject to change
* or deletion without notice.</b></p>
*
* @author Peter von der Ahé
*/
public class CompileFromString {
/**
* The name of the class used to evaluate expressions.
*/
/**
* Object used to signal errors from evalExpression.
*/
};
/**
* Compile and evaluate the specified expression using the
* given compiler.
* @param compiler a JSR 199 compiler tool used to compile the given expression
* @param expression a Java Programming Language expression
* @return the value of the expression; ERROR if any errors occured during compilation
* @throws java.lang.Exception exceptions are ignored for brevity
*/
throws Exception
{
// Use a customized file manager
// Create a file object from a string
" public static Object eval() throws Throwable {\n" +
" }\n}\n");
// Obtain a class loader for the compiled classes
// Load the compiled class
// Find the eval method
// Invoke it
} else {
// Report that an error occured
return ERROR;
}
}
/**
* Main entry point for program; ask user for expressions,
* compile, evaluate, and print them.
*
* @param args ignored
* @throws java.lang.Exception exceptions are ignored for brevity
*/
// Get a compiler tool
while (true) {
if (expression == null)
return; // end program on "cancel"
else
}
}
}