McCLIM:Common Lisp Interface Manager 的实现

McCLIM:Common Lisp Interface Manager 的实现

McCLIM An implementation of the Common Lisp Interface Manager, version II McCLIM 项目地址: https://gitcode.com/gh_mirrors/mc/McCLIM

1. 项目介绍

McCLIM(Common Lisp Interface Manager)是一个基于 Common Lisp 的便携式高级用户界面管理系统的工具包。它遵循 CLIM II 规范,提供了一个强大的表示模型,允许直接将对象的视觉表示与语义关联起来。McCLIM 拥有众多高级编程功能,使得开发用户界面变得方便,包括格式化输出、图形、窗口以及可以通过键入文本、键盘快捷键或点击鼠标按钮触发的命令。

McCLIM 支持 Allegro CL、Clozure CL、CLISP、CMUCL、Embeddable CL、Sciener CL 和 SBCL 等多种 Common Lisp 实现。目前,McCLIM 仅支持 CLX 后端,这意味着它依赖于宿主系统上的 Xserver 来运行应用程序。

2. 项目快速启动

要快速启动 McCLIM 项目,请确保已经安装了支持的 Common Lisp 实现(如 SBCL)以及 Quicklisp。以下是安装和运行 McCLIM 的步骤:

首先,在 Lisp REPL 中执行以下命令来安装 McCLIM:

(ql:quickload "mcclim")

接下来,你可以加载系统示例并运行示例浏览器应用程序:

(ql:quickload "clim-examples")
(clim-demo:demodemo)

3. 应用案例和最佳实践

以下是一个简单的 McCLIM 应用案例,演示如何创建一个应用程序窗口:

(in-package :common-lisp-user)

(defpackage "APP"
  (:use :clim :clim-lisp)
  (:export "APP-MAIN"))

(in-package :app)

(define-application-frame superapp ()
  ()
  (:panes
   (int :interactor :height 400 :width 600))
  (:layouts
   (default int)))

(defun app-main ()
  (run-frame-top-level (make-application-frame 'superapp)))

将上述代码保存为 example.lisp 文件,并在 Lisp REPL 中加载和运行它:

(load "example.lisp")
(app:app-main)

最佳实践建议包括:

  • 使用 define-application-frame 宏来定义应用程序窗口。
  • :panes 部分描述应用程序的不同部分。
  • :layouts 部分描述窗格的布局。
  • 使用 run-frame-top-level 函数来启动应用程序。

4. 典型生态项目

McCLIM 项目是 Common Lisp 生态系统中的一个重要组成部分,以下是一些与 McCLIM 相关的典型生态项目:

  • CLiki:一个关于 Common Lisp 和相关项目的社区 Wiki。
  • CLIM 2:McCLIM 遵循的 Common Lisp Interface Manager 规范的第二版。
  • Drei:一个文本编辑器库,可用于 McCLIM 应用程序中。
  • ESA:一个科学计算和图形库。

通过这些项目,可以进一步扩展 McCLIM 的功能和用途,为 Common Lisp 社区提供更丰富的工具和资源。

McCLIM An implementation of the Common Lisp Interface Manager, version II McCLIM 项目地址: https://gitcode.com/gh_mirrors/mc/McCLIM

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

姬忆慈Loveable

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值