• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef ECMASCRIPT_MODULE_MESSAGE_HELPER_H
17 #define ECMASCRIPT_MODULE_MESSAGE_HELPER_H
18 
19 #include "ecmascript/base/string_helper.h"
20 
21 namespace panda::ecmascript {
22 
23 class ModuleMessageHelper {
24 public:
VmModuleInfoMessage(JSThread * thread)25     static inline CString VmModuleInfoMessage(JSThread *thread)
26     {
27         EcmaVM *vm = thread->GetEcmaVM();
28         return "bundleName:" + vm->GetBundleName() +
29                ", moduleName:" + vm->GetModuleName() +
30                ", assetPath:" + vm->GetAssetPath();
31     }
32 
PrintAndThrowError(JSThread * thread,JSHandle<SourceTextModule> module)33     static void PrintAndThrowError(JSThread *thread, JSHandle<SourceTextModule> module)
34     {
35         // root error need throw error msg, for interface like pushurl(etc.) doesn't actually need ldmodulevar.
36         LOG_FULL(ERROR) << "Error found in module:" << module->GetEcmaModuleRecordNameString();
37         PrintErrorMessage(thread, module);
38         auto &options = const_cast<EcmaVM *>(thread->GetEcmaVM())->GetJSOptions();
39         if (options.EnableModuleException()) {
40             THROW_NEW_ERROR_AND_RETURN(thread, module->GetException(thread));
41         }
42     }
43 
PrintErrorMessage(JSThread * thread,JSHandle<SourceTextModule> module)44     static void PrintErrorMessage(JSThread *thread, JSHandle<SourceTextModule> module)
45     {
46         JSHandle<JSTaggedValue> exceptionInfo(thread, module->GetException(thread));
47         if (exceptionInfo->IsJSError()) {
48             base::ErrorHelper::PrintJSErrorInfo(thread, exceptionInfo);
49             return;
50         }
51         JSHandle<EcmaString> str = JSTaggedValue::ToString(thread, exceptionInfo);
52         RETURN_IF_ABRUPT_COMPLETION(thread);
53         CString message = ConvertToString(thread, *str);
54         LOG_ECMA(ERROR) << "Error occurs:" << message;
55     }
56 };
57 }  // namespace panda::ecmascript
58 #endif  // ECMASCRIPT_MODULE_JS_SHARED_MODULE_H
59