三生万物,所有开发相关命令均为以 @ 开头的 3 字符组成。
如下表:
命令 | 功能 |
---|---|
@@@ | 打开@开发面板 |
@@C | 编译应用包 |
@@P | 编译并发布应用包 |
@GS | 打开 git bash 终端。 |
安装 @lisp开发工具 并输入个人信息就可以使用本网开发的 开发工具 创建应用、编译应用、上传和发布你的应用了。
然后 点击菜单 开发工具(DevelopTools) -> 获取开发令牌 ,过程中根据提示输入用户信息及密码。如果你的 Email 和 手机号 没有被注册过的话,就可以注册新用户进行应用的创建和发布了。
该功能可创建一个初始的空应用包,注意应用包的标识名(name)为全网唯一,不能与已有的应用名重复(英文标识)。
中文显示的名称(full name) 可以重复,但显示的作者不同。
应用包的标识名(name) 与安装的文件夹 (目录)应完全一致。创建后它们是一致的,不得更改。
英文标识名(pkg.lsp 文件中的 :name) 尽量采用有意义的单词,命令行安装时易于识别。
中文名称(pkg.lsp 文件中的 :full-name)尽量能表明功能。这个可以更改为自己中意的名称。
简介(pkg.lsp 文件中的 :description)对应用包的功能进行简述。
请记住 应用包的标识名 在编译和发布时需要输入。
当你创建了一个应用包,并完成功能代码的编写工作之后。就可以 编译应用 了, 编译应用 可以将你的开发包定义中的 :files 中的可执行文件(不含扩展名的文件) 进行编译 生成 .fas 文件。
上传应用 是 将你编写的应用包上传到 @lisp服务器 的 先行版数据池 中,用于测试及公众测试 。
发布应用 是 将你编写的应用包上传到 @lisp服务器 的 稳定版数据池 中,供一般用户使用 。
@lisp 采用应用包的方式管理相对独立的程序。
每个包有自己的目录结构。
包目录文件结构:
首先需要对自己的程序进行包定义。用于定义包的名称,作者,下载网址及组成文件等。
包定义文件命名方式为 pkg.lsp 。
如 at-pm 包 ,其定义文件名为 pkg.lsp
其内容示例如下:
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; @lisp 工程管理
;;; Author: VitalGG<vitalgg@gmail.com>
;;; Description: 基于 AutoLisp/VisualLisp 开发的绘图工具集
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(@:def-pkg '((:name . "at-pm")
(:full-name . "工程管理")
(:author . "vitalGG")
(:email . "vitalgg@gmail.com")
(:version . "1.0.0")
(:locale . "CHS")
(:description . "CAD 常用工具,图层、文本、基本数学运算、批量打印、业务逻辑化管理。")
(:category . "通用")
(:tags . ("批量打印"))
(:url . "http://atlisp.cn")
(:files . ("tools-anti-virus"
"virus.lib"
"tools-contents"
"tools-layer"
"tools-math"
"tools-text"
"tukuang.dwg" ))))
在 files 点对中对应的文件列表,不带扩展名的文件均为 lsp 文件,编译上传后为 fas 文件。其它文件则需要带有扩展名,如病毒库文件 virus.lib,图框的dwg 文件等。
如果需要安装这个包,需在 CAD 命令行 输入
@I at-pm
或
(@:package-install "at-pm")
即可完成下载及安装配置工作,并重新生成菜单。
CAD 在启动加载的时候会按这个文件列表加载各个 fas 文件(用户)。
@:def-pkg 定义包
@:add-menu 菜单生成函数(用于在加载时生成菜单)
@:add-menus 批量菜单生成函数(用于在加载时生成菜单)
@:help 命令提示函数(用于运行前的功能用法提示)
@:define-config 定义包中可供使用者修改的参数。
@:set-config 使用者修改包中定义的变量。
@:get-config 取包中定义的变量的值。
@lisp 可以在安装时生成相应的菜单。目前 所有的功能菜单均集中于 @lisp(A) 中。
@:add-menu 函数用于生成菜单。
格式如下:
(@:add-menu "子菜单" "功能名称" "(功能函数)")
(defun 功能函数 ()
...
)
示例(无参数):
(@:add-menu "大绘图" "附着签名" "(@:attach-sign)")
(defun @:attach-sign ( )
...
)
示例(有参数):
(@:add-menu "大绘图" "插入图框" "(@:insert-tukuang \"tukuang.dwg\" @:*tukuang*)")
(@:add-menu "变更及工程处理" "变更" "(@:insert-tukuang \"bg-tukuang.dwg\" @:*bg-tukuang*)")
(@:add-menu "变更及工程处理" "处理方案" "(@:insert-tukuang \"fa-tukuang.dwg\" @:*fa-tukuang*)")
(defun @:insert-tukuang (tk-file tk-dwg)
...)
(@:define-config 'vitaltools:projects-output "D:\\Output" "本地PDF输出目录")
(@:set-config 'vitaltools:projects-output "D:\\PDF")
(@:get-config 'vitaltools:projects-output)
(@:list-config)
说明:
(@:define-config 可供用户修改的变量名(符号) 默认值 变量说明)
(@:set-config 可供用户修改的变量名(符号) 用户设定值)
(@:get-config 可供用户修改的变量名(符号) )
(@:list-config)
@lisp 支持应用包的多国语言,不同语种的CAD环境,可以加载不同的语言包,显示用户使用的语言。
在代码中使用 (_”string”) 就可以将string 作为翻译标记,生成可翻译的文件。
(_"语言字符串")
开发者可以自行制作翻译文件,文件名为 pkgname-locale.lang 将该文件放在 @lisp/locale/ 目录下就可以实现翻译了。
TODO : 共享翻译 ,系统会收集未翻译的字符串,将未翻译的字符串,共享到 @lisp 网站,有翻译能力的 使用者 可以翻译这些内容让其他 使用者 使用。
在函数定义体后跟提示内容. 在配置文件 @config.lsp 中设置提示方式。 目前有两种提示方式, 1 是命令行提示方式, 2 是 alert 提示方式。
(defun foobar ()
(@:help "运行时提示该 foobar 函数的使用方法等。 ")
...)
包定义: pkg.lsp :
(@:def-pkg '((:name . "helloworld")
(:full-name . "hello world 示例")
(:author . "vitalGG")
(:email . "vitalgg@gmail.com")
(:version . "1.0.0")
(:description . "第一个示例。")
(:url . "http://atlisp.cn")
(:files . ("helloworld"))))
helloworld.lsp :
(@:add-menu "Hello" "helloworld" "(helloworld)")
(defun helloworld ()
(@:help "输出hello world 到命令行及对话框提示。")
(princ "hello world.\n")
(alert "hello world.")
(princ)
)
安装 helloworld 包
(@:package-install "helloworld")
完成后会在 菜单中出现相应的 helloworld 项。点击会执行相应的代码功能.
如果你有自己的服务器, 可将 包定义的的 url 改成你自己的网址,确保 files 中的文件能从你的网址中下载。 下载地址为 url/stable/ 下的文件。
然后把 包定义文件 pkg.lsp 分享到包数据库中即可。
见 @lisp 文档 的 @lisp部分
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。