Unicode C
Unicode C
JavaScript console using Callbacks
See more JavaScript Examples
Demonstrates console output using Chilkat JavaScript with callbacks.Chilkat Unicode C Downloads
#include <C_CkStringBuilderW.h>
#include <C_CkJsW.h>
#include <C_CkJsonObjectW.h>
void js_ProgressInfo(const wchar_t *name, const wchar_t *value)
{
wprintf(L"%s: %s\n",name,value);
}
void ChilkatSample(void)
{
BOOL success;
HCkStringBuilderW sbScript;
HCkJsW js;
void (*fnjsProgressInfo)(const wchar_t *name, const wchar_t *value) = js_ProgressInfo;
HCkJsonObjectW result;
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();
CkJsW_setProgressInfo(js, fnjsProgressInfo);
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 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"}
CkStringBuilderW_Dispose(sbScript);
CkJsW_Dispose(js);
CkJsonObjectW_Dispose(result);
}