apolloxlua 源码内使用macros的使用方式

简介:

本文讲解如何在两种模式下使用macros,首先在apolloxlua下有两种模式, 一种是 web模式另一种是工具模式。 web模式下我们可以在浏览器端来使用,但是有一些限制, 就是比如说某些native的api是无法使用的, 比如说ngx,redis,mysql这种。示例请看 web控制台示例 。而另外一种工具模式, 工具模式没有使用限制。

我们在处理某个领域的问题时候, 会用到条件编译。 条件编译会减少我们代码的体积和增加程序的灵活性。 比如这个示例中展示了如何使用:

macros 宏使用的语法:

1 宏注释

{% 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 %}

2 inline macro

 {-inline_listense-} 
    Copyright (c) 2018 agent.zy@aliyun.com
 {-inline_listense-}

在代码中内联该语法会将不同的inline macro 输出到指定位置

3 函数定义

 {%   
    local lua\_member\_call    ="{{item}}:{{item1}}({{item2}})"
    local lua\_string\_add_val ="\\"{{item}}\\" .. {{item2}}"
    local lua\_string\_add_string ="\\"{{item}}\\" + \\"{{item2**}}\\""
 %}

4 内联函数

{-inline_max-}
function  max (a, b) {
return a>b;
}
{-inline_max-}

如何使用我们定义的内联函数

{_blocks.inline_max_}

5 替换模式

{% 
local string_macro ="\\"{{item}}\\""
%}
{\* MACRO(string_macro)(context) *}
{\* MACRO(string_macro){ item = "string-macro-context" } *}

例子 :

{-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工具 进行预编译。

相关文章
|
小程序 开发工具 开发者
小程序vant-weapp-商品卡片列表
小程序vant-weapp-商品卡片列表
465 0
|
NoSQL MongoDB
12 MongoDB - 数据查询(消除重复)
12 MongoDB - 数据查询(消除重复)
533 0
|
容器 微服务 Kubernetes
带你读《Istio入门与实战》之一:服务网格与Istio
本书系统化介绍Istio技术要点与应用技巧,可帮助读者快速搭建微服务架构并进行管理。主要内容包括:service mesh基本概念与使用,Istio架构设计与主要功能,快速搭建一个微服务实验,介绍如何让服务流量控制更简单,让服务更具弹性,让服务故障测试更容易,让服务通信更安全可控,让服务更易观测与监控,以及istio维护方案。本书内容丰富、案例讲解,实用性强,非常适合入门级读者快速掌握Istio技术。
|
Shell Linux 调度
cgroup 资源控制介绍
cgroup 资源控制介绍
|
机器学习/深度学习 数据采集 开发者
深度学习中的模型优化策略
【9月更文挑战第20天】在深度学习的海洋里,每一个研究者和实践者都在追求更高效、更准确的模型。本文将深入探讨深度学习中模型优化的策略,从数据预处理到正则化技术,再到超参数调整,我们将一步步揭开模型优化的神秘面纱。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用的技巧。让我们一起探索如何让你的深度学习模型更加出色吧!
260 8
|
Ubuntu 开发工具 git
交叉编译MiniGUI
交叉编译MiniGUI
|
消息中间件 安全 Java
ulimit 命令详解
ulimit 命令详解
|
分布式计算 Shell 开发工具
Spark编程实验二:RDD编程初级实践
Spark编程实验二:RDD编程初级实践
617 1
|
Java 程序员 应用服务中间件
springboot线程池的使用和扩展
我们常用ThreadPoolExecutor提供的线程池服务,springboot框架提供了@Async注解,帮助我们更方便的将业务逻辑提交到线程池中异步执行,今天我们就来实战体验这个线程池服务,并根据实际需要做定制化的扩展
1209 0
springboot线程池的使用和扩展
|
设计模式 数据采集 数据可视化
ECharts与Excel的火花
在数据爆炸的时代,如何有效地呈现和解析数据变得至关重要。ECharts和Excel作为两种广泛使用的数据处理和可视化工具,各自拥有其独特的魅力和功能。本文将深入探讨这两者之间的火花碰撞,以及如何结合它们以实现更强大的数据可视化效果。ECharts与Excel的结合,不仅可以充分发挥两者的优势,还可以实现更强大的数据可视化效果。无论是从数据处理、图表创建还是故事叙述的角度,这种结合都能为数据分析师、业务人员和决策者提供更丰富、更直观的数据洞察。
329 1