All Downloads are FREE. Search and download functionalities are using the official Maven repository.

abcl-build.build.util.lisp Maven / Gradle / Ivy

Go to download

Extra contributions for ABCL code not necessarily licensed under the GPLv2 with classpath exception.

The newest version!
;;;; TODO: move to a utility package
(in-package :abcl/build)

;;; TODO remove
(defun localize-executable-name (name)
  (let* ((p (if (pathnamep name)
                name
                (pathname name)))
         (type (pathname-type p)))
    (make-pathname :defaults p
                   :type 
                   (if (uiop:os-windows-p)
                       (when (null type)
                         "exe")
                       type))))

(defun possible-executable-names (name
				  &key (suffixes '("exe" "cmd" "bat") suffixes-p))
  (let* ((p (if (pathnamep name)
                name
                (pathname name)))
         (type (pathname-type p)))
    (declare (ignore type))
    (unless (or (uiop:os-windows-p) suffixes-p)
      (return-from possible-executable-names
        (listify name)))
    (loop
       :for suffix :in suffixes
       :with result = (list p)
       :doing (push (make-pathname :defaults p :type suffix)
		    result)
       :finally (return (nreverse result)))))
       
(defun introspect-path-for (executable)
  (let ((which-command (if (uiop:os-windows-p)
                           "where"
                           "which")))
    (when (ignore-errors
            (uiop:run-program (list which-command which-command) :output :string))
      (dolist (p (possible-executable-names executable))
	(let ((raw-result 
	       (ignore-errors (uiop:run-program
			       (list which-command
				     (namestring p))
			       :output :string))))
	  (when raw-result
	    (let ((result (first (split-string raw-result #\Newline))))
	      (return-from introspect-path-for
		(values
		 result
		 (pathname result))))))))))

(defun probe-for-executable (directory executable)
  (dolist (executable (possible-executable-names executable))
    (let ((pathname
	   (probe-file
	    (merge-pathnames executable directory))))
      (when pathname
	(return-from probe-for-executable
	  pathname)))))
  
(defun split-string (string split-char)
  (loop :for i = 0 :then (1+ j)
     :as j = (position split-char string :test #'string-equal :start i)
     :collect (subseq string i j)
     :while j))

(defun stringify (thing)
  (cond
    ((pathnamep thing)
     (namestring thing))
    ((stringp thing)
     thing)
    (t
     (error "Don't know how stringify ~a." thing))))

(defun listify (thing)
  (if (consp thing)
      thing
      (list thing)))

(defun some-directory-containing (executable)
  ;; search path
  (let ((in-path (introspect-path-for executable)))
    (when in-path
      (return-from some-directory-containing
                   in-path))
    (dolist (d (if (uiop:os-windows-p)
                   '(#p"c:/Program Files/") ;; TODO localize me!
                   '(#p"/usr/local/bin/" #p"/opt/local/bin/" #p"/usr/bin/")))
      (let* ((e (localize-executable-name
                 (merge-pathnames executable d)))
             (p (probe-file e)))
        (when p
          (return-from some-directory-containing p))))))

(defun copy-directory-recursively (from to)
  (flet ((normalize-to-directory (p)
           (when (or (not (pathnamep p))
                     (not (and (null (pathname-name p))
                               (null (pathname-type p)))))
             (setf p (make-pathname :defaults p
                                    :name nil :type nil)))
           p))
    (normalize-to-directory from)
    (normalize-to-directory to)
    (let ((wildcard (merge-pathnames "**/*" from)))
      (loop :for source :in (directory wildcard)
            :for relative = (enough-namestring source from)
            :for destination = (merge-pathnames relative to)
            :doing
               (progn 
                 (ensure-directories-exist destination)
                 (when (or (pathname-name destination)
                           (pathname-type destination))
                   (uiop:copy-file source destination)))))))


                                                

                                                
    
        
       




© 2015 - 2025 Weber Informatics LLC | Privacy Policy