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