Sample code for 30+ languages & platforms
Java

JavaScript console using Callbacks

See more JavaScript Examples

Demonstrates console output using Chilkat JavaScript with callbacks.

Chilkat Java Downloads

Java
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"}
  }
}