Common Lisp 学习笔记系列01


要学一门编程语言,首先需要将语言的环境配置好。如果想要个直接上手的环境,感谢日本的大神 Shirakumo,打造了一个 Common Lisp 的 IDE -- Portacle ,选择下载相对应的版本。然后只要了解下 quicklisp 的操作就好。从体验来看,Windows 使用 portacle 很方便,类 unix 的系统的话还是推荐自己配置。此外, The Common Lisp Cookbook 中也有介绍使用 Roswell 和 Docker 来搭建 Common Lisp 的环境,有兴趣的可以去尝试下,反正我是懒的去弄了。


安装解释器(implementation)

  • Ubuntu/Debian

    sudo apt-get install -y sbcl
  • Mac OS

    brew install sbcl
  • CentOS/Fedora

    sudo yum install -y sbcl

    其他各版本的解释器,请参考:Wikipedia's list of implementations

安装 quicklisp

  • 获取

    curl -O https://beta.quicklisp.org/quicklisp.lisp
  • 加载

    sbcl --load quicklisp.lisp
  • 安装

    (quicklisp-quickstart:install)

    默认安装路径为 ~/quicklisp,当然,也可可以指定 quicklisp 的安装目录,通过使用 :path 关键字,如我自己不想让该目录显示出来,将目录的名字最前面加个点 .,就像这样:

    (quicklisp-quickstart:install :path "~/.quicklisp")
  • 配置

    在执行完 install 后,运行

    (ql:add-to-init-file)

    程序将会自动创建 ~/.sbclrc 并将以下内容写入文件中:

    #-quicklisp
    (let ((quicklisp-init (merge-pathnames "quicklisp/setup.lisp"
    (user-homedir-pathname))))
    (when (probe-file quicklisp-init)
    (load quicklisp-init)))

    其中 merge-pathnames 后面接的是 quicklisp 安装路径加 setup.lisp

    如果不想默认加载 quicklisp 的话,可以不设置,使用 quicklisp 时需手动加载 setup.lisp

quicklisp 用法:

  • 加载库

    (ql:quickload "package-name")
  • 卸载库

    (ql:uninstall "package-name")
  • 查询库

    (ql:system-apropos "package-name")
  • 更新

    (ql:update-dist "quicklisp")
  • 查看依赖关系

    (ql:who-depends-on "package-name")
  • 默认项目目录(本地的项目库目录)

    ~/common-lisp/
    ~/.local/share/common-lisp/source
    ~/quicklisp/local-projects
  • 查看默认的目录

    (asdf/source-registry:default-user-source-registry)
    asdf:*central-registry*
  • 添加项目目录

    (push #p"/path/to/my-project/" asdf:*central-registry*)
    (ql:quickload "my-project")

Common Lisp 项目

  • 使用 cl-project 包快速创建

    (ql:quickload "cl-project")
    (cl-project:make-project #P"/path-to-project/project-name")

    执行后,会在相对应的目录下生成以下项目文件

    |-- my-project.asd
    |-- my-project-test.asd
    |-- README.markdown
    |-- README.org
    |-- src
    | `-- my-project.lisp
    `-- tests
    `-- my-project.lisp
  • 导入项目

    将项目放入到 quicklisp 默认项目目录中,或是将项目路径添加到 asdf:*central-registry* 变量中。


Reference:

Lisp-01: 相关开发环境配置部署的更多相关文章

  1. Storm开发——环境配置部署

    配置开发环境:http://storm.apache.org/releases/current/Setting-up-development-environment.html 开发环境定义: Stor ...

  2. Android Studio开发环境配置以及相关说明

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 这里简单记录下在开发的时候使用的Android Studio开发环境版本以及相关注意事项. 一般来讲,每隔一段时间就要检查下Andr ...

  3. Fedora和Ubuntu下安装OpenGL开发环境配置

    Fedora下OpenGl开发环境配置 开发OpenGL工程需要3个库文件和对应的头文件: libglut.so,libGLU.so,libGL.so, gl.h ,glu.h, glut.h 这些库 ...

  4. XE4 IOS开发环境配置

    l 配置IOS的安装开发环境 使用RAD XE4开发IOS程序,一台MAC是必须的(也可以用虚拟机), MAC上需要安装Xcode, 独立版本的Commnand Line Tools 以及RAD的pa ...

  5. Linux 桌面玩家指南:18. 使用 Docker 隔离自己的开发环境和部署环境

    特别说明:要在我的随笔后写评论的小伙伴们请注意了,我的博客开启了 MathJax 数学公式支持,MathJax 使用$标记数学公式的开始和结束.如果某条评论中出现了两个$,MathJax 会将两个$之 ...

  6. 基于webpack4的react开发环境配置

    一.基础配置 1.init项目 mkdir react-webpack4-cook cd react-webpack4-cook mkdir src mkdir dist npm init -y 复制 ...

  7. Ubuntu开发环境配置

    主要是: 源的更新 安装vim编辑器 远程登录xrdp相关配置 synergy symless键鼠共享配置 对新买的硬盘进行格式化和分区 vsftp环境搭建 gcc开发环境配置 qt5开发环境配置 m ...

  8. Win8.1+VS2013+WDK8.1+VirtualBox or VMware 驱动开发环境配置

    https://blog.csdn.net/charlessimonyi/article/details/50904956 Win8.1+VS2013+WDK8.1+VirtualBox or VMw ...

  9. XMPP开发环境配置

    首先配置XMPP开发环境配置需要的软件 先安装xampp-osx-1.8.3-5-installer.dmg 安装成功后launchpad里会多出一个XAMPP(其他),点开里面的manager-os ...

随机推荐

  1. Levenshtein Distance(编辑距离)算法与使用场景

    前提 已经很久没深入研究过算法相关的东西,毕竟日常少用,就算死记硬背也是没有实施场景导致容易淡忘.最近在做一个脱敏数据和明文数据匹配的需求的时候,用到了一个算法叫Levenshtein Distanc ...

  2. iPhone UIButton图标与文字间距设置【转】

    UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(50, 50, 150, 50)]; [button setTitle:@& ...

  3. Redis篇之操作、lettuce客户端、Spring集成以及Spring Boot配置

    Redis篇之操作.lettuce客户端.Spring集成以及Spring Boot配置 目录 一.Redis简介 1.1 数据结构的操作 1.2 重要概念分析 二.Redis客户端 2.1 简介 2 ...

  4. R语言实战(二) 创建数据集

    2.1 数据集的概念 不同的行业对于数据集的行和列叫法不同.统计学家称它们为观测(observation)和变量(variable),数据库分析师则称其为记录(record)和字段(field),数据 ...

  5. Python包的应用

    包的简介 你们听到的包,可不是女同胞疯狂喜欢的那个包,我们来看看这个是啥包 官方解释: ? 1 2 3 4 5 6 7 8 9 Packages are a way of structuring Py ...

  6. 利用border-radius画椭圆

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  7. vue基础回顾 router

    vue-router 1. 底层原理 hash 或者h5 histroy(有兼容性) 2. 使用的时候Vue需要引入VueRouter Vue.use(VueRouter) //VueRouter 底 ...

  8. js 实现简单的选项卡

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. ajax3

    json json:JavaScript对象表示方法(JavaScript object notation) json:是存储和交换文本信息的语法,类似与xml.他使用键值对的方式来组织,易于人们阅读 ...

  10. js获取按钮的文字

    button按钮有两种情况: 1 <input type="button" id="button" value="button"> ...