1fb299fa2Sopenharmony_ci/* 2fb299fa2Sopenharmony_ci * Copyright (c) 2021 Huawei Device Co., Ltd. 3fb299fa2Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4fb299fa2Sopenharmony_ci * you may not use this file except in compliance with the License. 5fb299fa2Sopenharmony_ci * You may obtain a copy of the License at 6fb299fa2Sopenharmony_ci * 7fb299fa2Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8fb299fa2Sopenharmony_ci * 9fb299fa2Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10fb299fa2Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11fb299fa2Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12fb299fa2Sopenharmony_ci * See the License for the specific language governing permissions and 13fb299fa2Sopenharmony_ci * limitations under the License. 14fb299fa2Sopenharmony_ci */ 15fb299fa2Sopenharmony_ci#ifndef SCRIPT_INSTRUCTION_H 16fb299fa2Sopenharmony_ci#define SCRIPT_INSTRUCTION_H 17fb299fa2Sopenharmony_ci 18fb299fa2Sopenharmony_ci#include <string> 19fb299fa2Sopenharmony_ci#include "pkg_manager.h" 20fb299fa2Sopenharmony_ci#include "updater/updater.h" 21fb299fa2Sopenharmony_ci 22fb299fa2Sopenharmony_cinamespace Uscript { 23fb299fa2Sopenharmony_ciclass UScriptInstructionFactory; 24fb299fa2Sopenharmony_ciclass UScriptInstruction; 25fb299fa2Sopenharmony_citypedef UScriptInstructionFactory* UScriptInstructionFactoryPtr; 26fb299fa2Sopenharmony_citypedef UScriptInstruction* UScriptInstructionPtr; 27fb299fa2Sopenharmony_ci 28fb299fa2Sopenharmony_ci/** 29fb299fa2Sopenharmony_ci * 定义环境变量,记录需要使用的全局对象 30fb299fa2Sopenharmony_ci */ 31fb299fa2Sopenharmony_ciclass UScriptEnv { 32fb299fa2Sopenharmony_cipublic: 33fb299fa2Sopenharmony_ci UScriptEnv(Hpackage::PkgManager::PkgManagerPtr pkgManager) : pkgManager_(pkgManager) {} 34fb299fa2Sopenharmony_ci 35fb299fa2Sopenharmony_ci virtual ~UScriptEnv() {} 36fb299fa2Sopenharmony_ci 37fb299fa2Sopenharmony_ci Hpackage::PkgManager::PkgManagerPtr GetPkgManager() 38fb299fa2Sopenharmony_ci { 39fb299fa2Sopenharmony_ci return pkgManager_; 40fb299fa2Sopenharmony_ci } 41fb299fa2Sopenharmony_ci int32_t GetState() 42fb299fa2Sopenharmony_ci { 43fb299fa2Sopenharmony_ci return state_; 44fb299fa2Sopenharmony_ci } 45fb299fa2Sopenharmony_ci 46fb299fa2Sopenharmony_ci virtual void PostMessage(const std::string &cmd, std::string content) = 0; 47fb299fa2Sopenharmony_ci virtual UScriptInstructionFactoryPtr GetInstructionFactory() = 0; 48fb299fa2Sopenharmony_ci virtual const std::vector<std::string> GetInstructionNames() const = 0; 49fb299fa2Sopenharmony_ci virtual bool IsRetry() const = 0; 50fb299fa2Sopenharmony_ci virtual Updater::PostMessageFunction GetPostmsgFunc() = 0; 51fb299fa2Sopenharmony_ciprivate: 52fb299fa2Sopenharmony_ci Hpackage::PkgManager::PkgManagerPtr pkgManager_ = nullptr; 53fb299fa2Sopenharmony_ci int32_t state_ = 0; 54fb299fa2Sopenharmony_ci}; 55fb299fa2Sopenharmony_ci 56fb299fa2Sopenharmony_ci/** 57fb299fa2Sopenharmony_ci * 脚本执行时的上下文描述,在调用脚本指令时,使用这个函数传参 58fb299fa2Sopenharmony_ci * 输入参数使用 GetParam 获取 59fb299fa2Sopenharmony_ci * 输出参数使用 PushParam 添加 60fb299fa2Sopenharmony_ci */ 61fb299fa2Sopenharmony_ciclass UScriptContext { 62fb299fa2Sopenharmony_cipublic: 63fb299fa2Sopenharmony_ci enum ParamType { 64fb299fa2Sopenharmony_ci PARAM_TYPE_INTEGER = 1, // 整数类型 65fb299fa2Sopenharmony_ci PARAM_TYPE_FLOAT, // float类型 66fb299fa2Sopenharmony_ci PARAM_TYPE_STRING, // string类型 67fb299fa2Sopenharmony_ci PARAM_TYPE_INVALID = -1 68fb299fa2Sopenharmony_ci }; 69fb299fa2Sopenharmony_ci 70fb299fa2Sopenharmony_ci virtual ~UScriptContext() = default; 71fb299fa2Sopenharmony_ci 72fb299fa2Sopenharmony_ci /** 73fb299fa2Sopenharmony_ci * 按不同的类型添加一个输出参数,可以添加任意输出 74fb299fa2Sopenharmony_ci */ 75fb299fa2Sopenharmony_ci virtual int32_t PushParam(int value) = 0; 76fb299fa2Sopenharmony_ci virtual int32_t PushParam(float value) = 0; 77fb299fa2Sopenharmony_ci virtual int32_t PushParam(const std::string& value) = 0; 78fb299fa2Sopenharmony_ci 79fb299fa2Sopenharmony_ci /** 80fb299fa2Sopenharmony_ci * 获取输入参数的个数 81fb299fa2Sopenharmony_ci */ 82fb299fa2Sopenharmony_ci virtual int32_t GetParamCount() = 0; 83fb299fa2Sopenharmony_ci 84fb299fa2Sopenharmony_ci /** 85fb299fa2Sopenharmony_ci * 获取对应索引的输入参数的类型 86fb299fa2Sopenharmony_ci */ 87fb299fa2Sopenharmony_ci virtual ParamType GetParamType(int32_t index) = 0; 88fb299fa2Sopenharmony_ci 89fb299fa2Sopenharmony_ci /** 90fb299fa2Sopenharmony_ci * 获取对应索引的输入参数的值 91fb299fa2Sopenharmony_ci */ 92fb299fa2Sopenharmony_ci virtual int32_t GetParam(int32_t index, int32_t& value) = 0; 93fb299fa2Sopenharmony_ci virtual int32_t GetParam(int32_t index, float& value) = 0; 94fb299fa2Sopenharmony_ci virtual int32_t GetParam(int32_t index, std::string& value) = 0; 95fb299fa2Sopenharmony_ci}; 96fb299fa2Sopenharmony_ci 97fb299fa2Sopenharmony_ci/** 98fb299fa2Sopenharmony_ci * 脚本执行指令,实现对应指令的功能 99fb299fa2Sopenharmony_ci */ 100fb299fa2Sopenharmony_ciclass UScriptInstruction { 101fb299fa2Sopenharmony_cipublic: 102fb299fa2Sopenharmony_ci virtual ~UScriptInstruction() = default; 103fb299fa2Sopenharmony_ci 104fb299fa2Sopenharmony_ci /** 105fb299fa2Sopenharmony_ci * 脚本调用,执行函数 106fb299fa2Sopenharmony_ci * context : 函数执行的上下文信息 107fb299fa2Sopenharmony_ci * 入参:通过GetParam可以获取输入参数的类型和值 108fb299fa2Sopenharmony_ci * 出参:PushParam将输出结果压栈 109fb299fa2Sopenharmony_ci * 返回值:函数处理结果 110fb299fa2Sopenharmony_ci */ 111fb299fa2Sopenharmony_ci virtual int32_t Execute(UScriptEnv &env, UScriptContext &context) = 0; 112fb299fa2Sopenharmony_ci}; 113fb299fa2Sopenharmony_ci 114fb299fa2Sopenharmony_ci/** 115fb299fa2Sopenharmony_ci * 脚本执行指令的工厂类,根据指令名创建对应的实例 116fb299fa2Sopenharmony_ci */ 117fb299fa2Sopenharmony_ciclass UScriptInstructionFactory { 118fb299fa2Sopenharmony_cipublic: 119fb299fa2Sopenharmony_ci // 创建时必须使用new,在程序结束后,会使用delete删除指令对象 120fb299fa2Sopenharmony_ci virtual int32_t CreateInstructionInstance(UScriptInstructionPtr &instr, const std::string &name) = 0; 121fb299fa2Sopenharmony_ci 122fb299fa2Sopenharmony_ci virtual ~UScriptInstructionFactory() = default; 123fb299fa2Sopenharmony_ci}; 124fb299fa2Sopenharmony_ci} // namespace Uscript 125fb299fa2Sopenharmony_ci 126fb299fa2Sopenharmony_ci#ifdef __cplusplus 127fb299fa2Sopenharmony_ciextern "C" { 128fb299fa2Sopenharmony_ci#endif 129fb299fa2Sopenharmony_ci 130fb299fa2Sopenharmony_ci/** 131fb299fa2Sopenharmony_ci * 接口,用来从用户自定义的共享库中获取factory 132fb299fa2Sopenharmony_ci */ 133fb299fa2Sopenharmony_ciUscript::UScriptInstructionFactoryPtr GetInstructionFactory(); 134fb299fa2Sopenharmony_ci 135fb299fa2Sopenharmony_ci#ifdef __cplusplus 136fb299fa2Sopenharmony_ci} 137fb299fa2Sopenharmony_ci#endif 138fb299fa2Sopenharmony_ci#endif