Sample code for 30+ languages & platforms
Unicode C

JavaScript console

See more JavaScript Examples

Demonstrates console output using Chilkat JavaScript.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkStringBuilderW.h>
#include <C_CkJsW.h>
#include <C_CkJsonObjectW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkStringBuilderW sbScript;
    HCkJsW js;
    HCkJsonObjectW result;
    HCkStringBuilderW sbOut;

    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.
    sbScript = CkStringBuilderW_Create();
    success = CkStringBuilderW_LoadFile(sbScript,L"qa_data/js_tests/test_console.js",L"utf-8");
    if (success == FALSE) {
        wprintf(L"%s\n",CkStringBuilderW_lastErrorText(sbScript));
        CkStringBuilderW_Dispose(sbScript);
        return;
    }

    js = CkJsW_Create();
    result = CkJsonObjectW_Create();

    // 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 = CkJsW_Eval(js,sbScript,result);
    if (success == FALSE) {
        wprintf(L"%s\n",CkStringBuilderW_lastErrorText(sbScript));
        CkStringBuilderW_Dispose(sbScript);
        CkJsW_Dispose(js);
        CkJsonObjectW_Dispose(result);
        return;
    }

    // We can look at the result, which is "undefined", which is normal and expected.
    wprintf(L"%s\n",CkJsonObjectW_emit(result));
    // The result JSON is: {"type":"undefined","value":"undefined"}

    // The console output is retrieved by calling ConsoleOutputSb
    sbOut = CkStringBuilderW_Create();
    CkJsW_ConsoleOutputSb(js,sbOut);
    wprintf(L"%s\n",CkStringBuilderW_getAsString(sbOut));


    CkStringBuilderW_Dispose(sbScript);
    CkJsW_Dispose(js);
    CkJsonObjectW_Dispose(result);
    CkStringBuilderW_Dispose(sbOut);

    }