Java
Java
JavaScript console using Callbacks
See more JavaScript Examples
Demonstrates console output using Chilkat JavaScript with callbacks.Chilkat Java Downloads
import com.chilkatsoft.*;
public class jsProgress extends CkBaseProgress
{
public void ProgressInfo(String name, String value)
{
System.out.println(name + ": " + value);
return;
}
};
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// This example demonstrates using the built-in console object.
// The Javascript run in this example is shown below.
// Load the JavaScript from a file.
CkStringBuilder sbScript = new CkStringBuilder();
success = sbScript.LoadFile("qa_data/js_tests/test_console.js","utf-8");
if (success == false) {
System.out.println(sbScript.lastErrorText());
return;
}
CkJs js = new CkJs();
jsProgress js_progress = new jsProgress();
js.put_EventCallbackObject(js_progress);
CkJsonObject result = new CkJsonObject();
// Run the JavaScript
// Results (not console output) go to result.
// Note: Eval returns the completion value of the script. This is generally the value of the last evaluated expression.
// In this case, the last evaluated expression is console.log which does not calculate a value. Therefore, it returns undefined.
success = js.Eval(sbScript,result);
if (success == false) {
System.out.println(sbScript.lastErrorText());
return;
}
// We can look at the result, which is "undefined", which is normal and expected.
System.out.println(result.emit());
// The result JSON is: {"type":"undefined","value":"undefined"}
// The console output is received using ProgressInfo callbacks.
// The output is:
// log: Hello World, 248, 12.05
//
// error: foo:bar baz
//
// warn: 1 2 3
//
// log: %% %s
//
// log: myApp: {
// "appName": "Example",
// "version": 1,
// "isDebug": true,
// "supportedTypes": [
// "string",
// "number",
// "object"
// ],
// "settings": {
// "maxWidgets": 1024,
// "allowIO": true
// }
// }
//
// log: App: myApp (Version 1)
//
// {"type":"undefined","value":"undefined"}
}
}