本文讲解如何在两种模式下使用macros,首先在apolloxlua下有两种模式, 一种是 web模式另外一种是工具模式。 web模式下咱们能够在浏览器端来使用,可是有一些限制, 就是好比说某些native的api是没法使用的, 好比说ngx,redis,mysql这种。示例请看 web控制台示例 。而另一种工具模式, 工具模式没有使用限制。mysql
咱们在处理某个领域的问题时候, 会用到条件编译。 条件编译会减小咱们代码的体积和增长程序的灵活性。 好比这个示例中展现了如何使用:git
{% if SCRIPT == "lua" then %} return exports.GetValueByType (eax.value); {% end %} {% if SCRIPT == "neko" then %} return exports.GetValueByType (eax.value); {% end %} {% if SCRIPT == "c" then %} return exports.GetValueByType (eax.value); {% end %}
{-inline_listense-} Copyright (c) 2018 agent.zy@aliyun.com {-inline_listense-}
在代码中内联该语法会将不一样的inline macro 输出到指定位置web
{% local lua\_member\_call ="{{item}}:{{item1}}({{item2}})" local lua\_string\_add_val ="\\"{{item}}\\" .. {{item2}}" local lua\_string\_add_string ="\\"{{item}}\\" + \\"{{item2**}}\\"" %}
{-inline_max-} function max (a, b) { return a>b; } {-inline_max-}
如何使用咱们定义的内联函数redis
{blocks.inline_max}sql
{% local string_macro ="\\"{{item}}\\"" %} {\* MACRO(string_macro)(context) *} {\* MACRO(string_macro){ item = "string-macro-context" } *}
例子 :api
{-inline\_esprima\_parse-} var options = { attachComment: false, range: false, loc: false, sourceType: "script", tolerant: true }; options.tokens = false; var result = exports.esprima.parse(buff, options); {-inline\_esprima\_parse-} ///// ///// 生成code ///// {-inline\_generate\_code-} exports.lexerGenerateCode(result); {-inline\_generate\_code-} //// //// 生成字节码 //// {-inline\_generate\_mid-} exports.lexerGenerateMidCode(result); {-inline\_generate\_mid-} {% if SCRIPT == "lua" then %} exports.Main = function (buff) { {% if DEBUG then %} console.log("lua mode.") {% end %} ///生成ast解析 {\*blocks.inline\_esprima\_parse\*} ///生成code {\*blocks.inline\_generate\_code\*} } {% end %} {% if SCRIPT == "c" then %} exports.Main = function (str) { {% if DEBUG then %} console.log("c mode.") {% end %} {\*blocks.inline\_esprima\_parse\*} {\*blocks.inline\_generate\_code\*} } {% end %}
最后在使用的时候, web模式不须要处理, 在tool模式下请使用 luadef工具 进行预编译。浏览器