为编程爱好者分享易语言教程源码的资源网

网站首页 > 易语言相关 > 易语言例程 正文

[编译x64程序] EplOnCpp Build 20190406 (Concept Preview)

三叶资源网 2019-04-30 10:52:46 易语言例程 1233 ℃ 0 评论

Only Chinese document is available.

EplOnCpp (EOC for short)

介绍

基于Cpp构建的Epl语言编译环境
用于支持x64程序编写及实现特殊功能

版本

版本编号:Build 20190406
版本类型:概念预览(Concept Preview)
缺乏较多库命令支持,几乎不可能用于实际工程
请勿将其使用在正式工程中,在未来的版本中,其行为可能与预览版有很大不同

开源许可证

项目许可证
EplOnCppCoreThe MIT License
EplOnCppGUIThe MIT License
EocSystemEnvThe MIT License
EocLib_krnlnThe MIT License
EocLib_EocHelperThe MIT License



已知限制

  1. 不支持窗口功能

  2. 不支持“资源”

  3. 不支持编写DLL

  4. 不支持Linux程序编写

  5. 不支持置入代码(无法解决)

  6. 通用型功能相当不完善,建议避免使用(库、API声明除外,可放心使用)



用户使用指南

基本条件

  1. 正确安装了.NET 4.0(或兼容版本) Windows 10自带

  2. 任何支持C++ 17标准的编译器 目前仅在VS2017下进行了测试,在clang等编译器下使用时极可能遇到问题
    明确不支持VS2015/VS2012/VS2010/VC6等任何缺少C++ 17支持的编译器

  3. cmake编译系统 建议在安装VS时勾选cmake支持以便快速完成安装并获得VS IDE支持



安装配置

配置EOC系统环境

  1. 解压env.7z

  2. 设置环境变量“EOC_HOME”为“eoc”文件夹路径

  3. 重启以确保环境变量生效

  4. 解压GUI.7z到任意目录



安装EocHelper库

安装EocHelper库可以使用一些EOC附加功能(通常用于跨平台)

  1. 解压EocHelper.fne.build,将fne文件拷贝到e/lib目录

  2. 重启易语言,勾选EocHelper库启用



使用

生成工程文件

  1. 编写*.e文件

  2. 在编译菜单中选择 编译为Windows模块文件

  3. 在EOC主程序(GUI.7z/QIQI.EplOnCpp.GUI.exe)中输入模块文件路径

  4. 在EOC主程序中选择正确的工程类型

  5. 输入输出目录路径

  6. 点击按钮生成



编译

生成目录中将包含完整的cmake工程信息,请您使用cmake命令行自行编译
新版本的VS也包含了良好的cmake支持(需要安装),您可以在配置成功后,通过“在VS中打开文件夹”来浏览工程

XP支持

EOC不对XP系统提供主流支持,且任何对XP的有限支持都可能在未来的版本中移除
但由于VS2017仍然保留有限XP支持,您可以在cmake中使用参数-T v141_xp编译
为了更好的兼容性,您可以还需要使用VC-LTL等项目

库编写指南

请参照核心库的编写,正确编写C++代码、cmake配置文件config.cmake和库信息文件info.json

规范

命名

所有库命令应该放在命名空间e::lib::{LibName}下,其中{LibName}为库的英文名

自定义类型

所有自定义结构应该为智能指针类型e::system::struct_ptr<Raw>的别名,其中Raw为原始类型
所有自定义类应该为智能指针类型e::system::object_ptr<Raw>的别名,其中Raw为原始类型,应继承自e::system::basic_object并正确实现clone函数

info.json

库信息文件 CMakeName描述库在CMake配置文件中的名称,应与config.cmake中信息相匹配
Cmd/Type/Constant/Enum描述库提供的命令/类型/常量/枚举,其类型为Object【Key为中文名,Value为具体信息】

config.cmake

cmake配置文件
其应当正确配置库项目并定义{CMakeName}_FOUND/{CMakeName}_INCLUDE_DIRS/{CMakeName}_LIBRARIES,其中{CMakeName}应与info.json中信息相匹配

SuperTemplate

用于实现某些特殊支持库,接口极不稳定,如非必要请避免使用

类型

中文名类型名
算术类型-
字节型uint8_t
短整数型int16_t
整数型int32_t
长整数型int64_t
小数型float
双精度小数型double
平台整数intptr_t
非算术基本类型-
文本型e::system::string
字节集e::system::bin
日期时间型e::system::datetime
子程序指针e::system::methodptr
通用型e::system::any
高级类型-
数组(单维或多维)e::system::array<*>
自定义类型{CppName}



注意事项

  1. 对于末尾的可空参数,其在C++层面应当包含默认值(通常为std::nullopt)

  2. 对于通用型参数,在库层面建议结合模板以便加快效率(此时在info.json中将类型声明为*而非e::system::any)

  3. 任何类型声明为*的函数应当能够接受e::system::any,以便在和 通用型变量 和 其他命令的通用型返回值 组合使用时,能够正确工作:如到文本 (取字节集数据 ({ 1, 2, 3, 4, 5, 6, 7, 8 }, #长整数型, ))

  4. 参数的ByRef选项,仅用于非常量引用,对常量引用(const&)应为false以便获取更高的运行速度

文件下载

来源:三叶资源网,欢迎分享,公众号:iisanye,(三叶资源网⑤群:21414575

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

百度站内搜索
关注微信公众号
三叶资源网⑤群:三叶资源网⑤群

网站分类
随机tag
二维码登录简历下载任务栏缩略图趣生活登录反调试拼多多下单淘宝宝贝列表分页源码MTP发信易语言游戏开发矩阵应用获取拼多多指定店铺商品详情源码圆形图像旋转ETCP正则表达式测试工具拖放对象模块DX2登录辅助教程弹幕监听自绘旋转图片界面UI
最新评论