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()); 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()); 47 if (exceptionInfo->IsJSError()) { 48 thread->GetCurrentEcmaContext()->PrintJSErrorInfo(thread, exceptionInfo); 49 return; 50 } 51 JSHandle<EcmaString> str = JSTaggedValue::ToString(thread, exceptionInfo); 52 RETURN_IF_ABRUPT_COMPLETION(thread); 53 CString message = ConvertToString(*str); 54 LOG_ECMA(ERROR) << "Error occurs:" << message; 55 } 56 }; 57 } // namespace panda::ecmascript 58 #endif // ECMASCRIPT_MODULE_JS_SHARED_MODULE_H 59