如何解决如何获取 Quicklisp 提供的每个系统的所有依赖项列表?
我知道如何列出 Quicklisp 提供的所有系统
(ql:system-list)
而且我需要获得一种我想为 Guix 打包的最依赖的系统。是否有提供该功能的 ASD 或 Quicklisp 工具?
解决方法
quicklisp 关于系统关系的所有信息都在releases.txt 和systems.txt 两个文件中。 systems.txt 会告诉您依赖关系,releases.txt 会将项目名称(如“alexandria”)映射到它提供的系统。
它们都是简单的以空格分隔的记录文件,因此应该很容易解析并获取您需要的信息。
要获取 Lisp 中的示例依赖信息,请查看 ql:dependency-tree
的来源。
我需要的一些工作解决方案,感谢 Xach 指出 systems.txt
文件
(defparameter *quicklisp-systems-path*
(merge-pathnames
(make-pathname :directory '(:relative "dists" "quicklisp")
:name "systems" :type "txt")
ql:*quicklisp-home*))
(defun quicklisp-systems ()
"Return a list of all systems listed in Quicklisp's sistems.txt"
(with-open-file
(stream *quicklisp-systems-path*
:direction :input
:element-type :default
:external-format :default
:if-does-not-exist nil)
(loop
:for line := (read-line stream nil)
:while line
:for line-list := (split-sequence:split-sequence #\Space line)
:if (not (find "#" line-list :test #'equal))
:append (cdr line-list))))
(defun quicklisp-system-occurrences (list)
"Return a list of conces for each element and it's accurrences of LIST.
ref: https://codereview.stackexchange.com/questions/215682"
(let ((table (make-hash-table :test #'equal)))
(loop
:for x :in list
:do (incf (gethash x table 0)))
(loop
:for k :being :the hash-key :of table
:using (hash-value v)
:collect (cons k v))))
一些结果
CL-USER> (subseq (sort (occurrences (get-systems)) #'> :key #'cdr) 0 50)
(("asdf" . 2441) ("alexandria" . 781) ("cl-ppcre" . 350)
("cl-glfw-opengl-core" . 346) ("cffi" . 337) ("fiveam" . 309)
("bordeaux-threads" . 228) ("closer-mop" . 194) ("split-sequence" . 185)
("iterate" . 180) ("uiop" . 158) ("prove" . 153) ("prove-asdf" . 146)
("hu.dwim.asdf" . 146) ("babel" . 136) ("local-time" . 132)
("flexi-streams" . 131) ("drakma" . 121) ("trivial-garbage" . 113)
("cl-fad" . 103) ("usocket" . 93) ("trivial-features" . 90)
("named-readtables" . 90) ("documentation-utils" . 83)
("trivial-gray-streams" . 75) ("ironclad" . 73) ("cffi-grovel" . 65)
("cl-json" . 62) ("anaphora" . 62) ("hunchentoot" . 60) ("hu.dwim.util" . 57)
("lift" . 56) ("cxml" . 55) ("log4cl" . 53) ("cl-base64" . 52) ("trivia" . 49)
("parse-number" . 46) ("cl-interpol" . 46) ("let-plus" . 46) ("yason" . 46)
("quri" . 43) ("parachute" . 41) ("lisp-unit" . 41) ("hu.dwim.stefil" . 40)
("puri" . 39) ("trivial-utf-8" . 38) ("swank" . 38) ("esrap" . 35)
("qtools-ui-base" . 35) ("cl-opengl" . 34))
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。