0

我正在使用来自 C++ 的 Microsoft 的 Chakracore,并且我编写了一个基本的评估器,我可以从 read-eval-print 循环中重复调用它,如下所示:

void readEvalPrint(const char *prompt, JsSourceContext sourceContext) {    
    JsValueRef result;
    JsValueRef scriptSource;
    JsValueRef fileName;
    JsErrorCode status;
    JsValueRef strResult;
    std::string script;
    std::cout << prompt;    
    std::cout.flush();
    std::getline(std::cin, script);
    JsCreateString("", 0, &fileName);
    JsCreateExternalArrayBuffer(const_cast<char*> (script.c_str()), script.length(), nullptr, nullptr, &scriptSource);
    status = JsRun(scriptSource, sourceContext, fileName, JsParseScriptAttributeNone, &result);    
    if (status != JsNoError) {
        JsValueRef exception;
        // TODO: print stack trace
        JsGetAndClearException(&exception);
        std::cout << "Error: Could not evaluate expression" << std::endl;
        return;
    }
    status = JsConvertValueToString(result, &strResult);
    if (status != JsNoError) {
        std::cout << "Could not convert expression to displayable form" << std::endl;
        return;
    }
    size_t written;
    size_t bufferSize;
    JsCopyString(strResult, nullptr, std::numeric_limits<int>::max(), &bufferSize);
    char buffer[bufferSize+1];        
    JsCopyString(strResult, buffer, bufferSize, &written);
    buffer[bufferSize] = 0;
    std::cout << buffer << std::endl;
}

这似乎适用于大多数情况,但是当我输入 javascript 函数声明时,虽然我可以调用该函数并且它会产生正确的结果,但如果我只是尝试按名称检查函数以查看它的主体,就像我期望的那样对于任何通过调用其 toString() 方法的 javascript 函数,结果显然是垃圾。如果我检查其他函数(例如内置函数),我会看到预期的结果(即,'function function-name() { [native code] }',如果我创建一个匿名函数,例如,var a = function foo ().... 并尝试显示 a 的值,我看到了完整的匿名函数定义。但是,我似乎无法弄清楚如何显示我在 JsRun() 的先前迭代中定义的命名函数。我想我要么做错了什么,要么误解了一些预期的行为,或者我发现了一个错误。然而,我还不够流利地使用 Jsrt API 来确定它是哪一个。

4

0 回答 0