2013-03-30 10:32:07 +01:00
|
|
|
;; Copyright (C) 2012-2013 Dirk-Jan C. Binnema <djcb@djcbsoftware.nl>
|
2012-10-18 23:50:22 +02:00
|
|
|
;;
|
|
|
|
;; This program is free software; you can redistribute it and/or modify it
|
|
|
|
;; under the terms of the GNU General Public License as published by the
|
|
|
|
;; Free Software Foundation; either version 3, or (at your option) any
|
|
|
|
;; later version.
|
|
|
|
;;
|
|
|
|
;; This program is distributed in the hope that it will be useful,
|
|
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
;; GNU General Public License for more details.
|
|
|
|
;;
|
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
|
|
;; along with this program; if not, write to the Free Software Foundation,
|
|
|
|
;; Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
(define-module (mu script)
|
2012-10-22 22:14:39 +02:00
|
|
|
:export (mu:run-stats))
|
2012-10-18 23:50:22 +02:00
|
|
|
|
|
|
|
(use-modules (ice-9 getopt-long) (ice-9 optargs) (ice-9 popen) (ice-9 format))
|
|
|
|
(use-modules (mu) (mu stats) (mu plot))
|
|
|
|
|
|
|
|
(define (help-and-exit)
|
|
|
|
"Show some help."
|
2012-10-23 19:58:11 +02:00
|
|
|
(display
|
|
|
|
(string-append "usage: script [--help] [--textonly] "
|
|
|
|
"[--muhome=<muhome>] [--query=<query>")
|
|
|
|
(newline))
|
2012-10-18 23:50:22 +02:00
|
|
|
(exit 0))
|
|
|
|
|
2012-10-22 22:14:39 +02:00
|
|
|
(define (mu:run-stats args func)
|
|
|
|
"Run some statistics function.
|
|
|
|
Interpret argument-list ARGS (like command-line
|
2012-10-18 23:50:22 +02:00
|
|
|
arguments). Possible arguments are:
|
|
|
|
--help (show some help and exit)
|
|
|
|
--muhome (path to alternative mu home directory)
|
2013-07-23 21:22:57 +02:00
|
|
|
--output (a string describing the output, e.g. \"dumb\", \"png\" \"wxt\")
|
2012-10-18 23:50:22 +02:00
|
|
|
searchexpr (a search query)
|
2013-07-23 21:22:57 +02:00
|
|
|
then call FUNC with args SEARCHEXPR and OUTPUT."
|
|
|
|
(setlocale LC_ALL "")
|
|
|
|
(let* ((optionspec '((muhome (value #t))
|
|
|
|
(query (value #t))
|
|
|
|
(output (value #f))
|
|
|
|
(help (single-char #\h) (value #f))))
|
2012-10-18 23:50:22 +02:00
|
|
|
(options (getopt-long args optionspec))
|
2012-10-22 22:14:39 +02:00
|
|
|
(query (option-ref options 'query #f))
|
2012-10-18 23:50:22 +02:00
|
|
|
(help (option-ref options 'help #f))
|
2013-07-23 21:22:57 +02:00
|
|
|
(output (option-ref options 'output #f))
|
2012-10-18 23:50:22 +02:00
|
|
|
(muhome (option-ref options 'muhome #f))
|
2012-10-22 22:14:39 +02:00
|
|
|
(restargs (option-ref options '() #f)))
|
2012-10-18 23:50:22 +02:00
|
|
|
(if help (help-and-exit))
|
|
|
|
(mu:initialize muhome)
|
2013-07-23 21:22:57 +02:00
|
|
|
(func (or query "") output)))
|
2012-10-18 23:50:22 +02:00
|
|
|
|
|
|
|
;; Local Variables:
|
|
|
|
;; mode: scheme
|
|
|
|
;; End:
|