clog/tools/clog-builder-asdf-browser.lisp
2024-03-25 11:34:07 -04:00

64 lines
3 KiB
Common Lisp

(in-package :clog-tools)
(defun on-new-asdf-browser (obj &key (project nil))
(let* ((win (create-gui-window obj :title "ASDF System Browser"
:top 40 :left 225
:width 592 :height 435
:client-movement t))
(panel (create-asdf-systems (window-content win))))
(when *open-external*
(setf (checkedp (ext-open-source panel)) t))
(when *open-panels-as-popups*
(setf (checkedp (pop-open-clog panel)) t))
(when project
(setf (text-value (loaded-systems panel)) (string-downcase project))
(asdf-browser-populate panel))))
(defun asdf-browser-reset (panel)
(let* ((app (connection-data-item panel "builder-app-data")))
(setf (inner-html (loaded-systems panel)) "")
(dolist (n (sort (asdf:already-loaded-systems) #'string-lessp))
(add-select-option (loaded-systems panel) n n))
(if (current-project app)
(setf (text-value (loaded-systems panel)) (current-project app))
(setf (text-value (loaded-systems panel)) "clog"))
(asdf-browser-populate panel)))
(defun asdf-browser-populate (panel)
(setf (window-title (current-window panel))
(format nil "ASDF Browser - ~A" (text-value (loaded-systems panel))))
(setf (text-value (source-file panel))
(asdf:system-source-file
(asdf:find-system (text-value (loaded-systems panel)))))
(setf (inner-html (deps panel)) "")
(dolist (n (asdf:system-depends-on
(asdf:find-system (text-value (loaded-systems panel)))))
(add-select-option (deps panel) n n))
(setf (inner-html (files panel)) "")
(dolist (n (asdf:module-components
(asdf:find-system (text-value (loaded-systems panel)))))
(let ((name (asdf:component-relative-pathname n))
(path (asdf:component-pathname n)))
(add-select-option (files panel) path name))))
(defun asdf-files-double-click (panel target)
(let ((disp (select-text target))
(item (text-value target)))
(cond ((equal (subseq item (1- (length item))) "/")
(setf (inner-html (files panel)) "")
(dolist (n (asdf:module-components
(asdf:find-component
(asdf:find-system (text-value (loaded-systems panel)))
(subseq disp 0 (1- (length disp))))))
(let ((name (asdf:component-relative-pathname n))
(path (asdf:component-pathname n)))
(add-select-option (files panel) path name))))
((and (> (length item) 5)
(equal (subseq item (- (length item) 5)) ".clog"))
(if (checkedp (ext-open-source panel))
(on-new-builder-panel-ext panel :open-file item :open-ext (checkedp (pop-open-clog panel)))
(on-new-builder-panel panel :open-file item :open-ext (checkedp (pop-open-clog panel)))))
(t
(if (checkedp (ext-open-source panel))
(on-open-file-ext panel :open-file item)
(on-open-file panel :open-file item))))))