Hash :
ca6ffa97
        
        Author :
 Thomas de Grivel
 Thomas de Grivel
        
        Date :
2018-07-02T16:14:04
        
      
rewrite without iterate
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
;;
;;  adams  -  Remote system administration tools
;;
;;  Copyright 2013,2014 Thomas de Grivel <thomas@lowh.net>
;;
;;  Permission to use, copy, modify, and distribute this software for any
;;  purpose with or without fee is hereby granted, provided that the above
;;  copyright notice and this permission notice appear in all copies.
;;
;;  THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
;;  WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
;;  MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
;;  ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
;;  WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
;;  ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
;;  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
;;
(in-package :adams)
(in-re-readtable)
(define-resource-class openbsd-pkg (pkg)
  ()
  ((probe-openbsd-pkg :properties (:versions))))
(define-syntax pkg_info<1> (name version)
  #~|\s*((?:[^-\s]+)(?:-[^-0-9\s][^-\s]*)*)-([0-9][^-\s]*-[^\s]+)?|
  "Syntax for pkg_info(1) on OpenBSD"
  (values name (list version)))
(defgeneric probe-openbsd-pkg (resource os))
(defmethod probe-openbsd-pkg ((pkg openbsd-pkg) (os os-openbsd))
  (let ((id (resource-id pkg)))
    (multiple-value-bind (versions)
      (with-pkg_info<1> (name versions)
          (run "pkg_info | egrep ~A" (sh-quote (str "^" id "-")))
        (when (string= id name)
          (return (values versions))))
      (properties* versions))))
(defmethod merge-property-values ((pkg openbsd-pkg)
                                  (property (eql :versions))
                                  (old list)
                                  (new list))
  (sort (remove-duplicates (append old new))
        #'string<))
(defmethod probe-installed-packages% ((host host) (os os-openbsd))
  (with-host host
    (let ((packages))
      (with-pkg_info<1> (name versions) (run "pkg_info")
        (let ((pkg (resource 'openbsd-pkg name)))
          (add-probed-properties pkg (properties* name versions))
          (push pkg packages)))
      (nreverse packages))))
(defun probe-installed-packages (&optional (host (current-host)))
  (probe-installed-packages% host (host-os host)))
#+nil
(clear-resources)
#+nil
(describe-probed (resource 'openbsd-pkg "emacs"))
#+nil
(probe-installed-packages)
#+nil
(map nil #'describe-probed (probe-installed-packages))
#+nil
(run "pkg_info -q | grep emacs-")