3013adea9071dc9b387fefaaf054d388f4f6dc98
[candle] / bin / candle-server
1 #!/usr/bin/sbcl --script
2   
3 (setf *compile-print* nil)
4 (require 'asdf)
5 (asdf:initialize-source-registry
6  `(:source-registry (:tree ,(car (directory "."))) :INHERIT-CONFIGURATION))
7 (let
8  ((*error-output* (make-broadcast-stream)))
9  (asdf:load-system :candle))
10 (asdf:load-system :opera)
11
12 (defpackage #:candle-server-cli (:use #:common-lisp))
13 (in-package #:candle-server-cli)
14
15 (defvar *options*
16  '((:name :help :short "h" :long "help" :description "Print this usage.")
17    (:name :port :short "p" :long "port" :takes-argument t :variable-name "PORT"
18     :description "Port on which to listen for commands.  Defaults to 25004")))
19
20 (defun usage ()
21  (format t "~A"
22   (opera:usage
23    "candle-server"
24    *options*
25    "Starts a candle continuous integration server.  Use 'candle' to interact with the server.")))
26
27 (multiple-value-bind (options remaining-args error) (opera:process-arguments *options* (cdr sb-ext:*posix-argv*))
28  (cond
29   ((opera:option-present :help options) (usage))
30   (remaining-args
31    (format *error-output* "Don't understand ~A.  See 'candle-server -h'~%" (car remaining-args))
32    (sb-ext:exit :code 1))
33   ((and (opera:option-present :port options) (not (parse-integer (opera:option-argument :port options) :junk-allowed t)))
34    (format *error-output* "--port requires a number.  See 'candle-server -h'~%"))
35   (t
36    (let
37     ((port (or (and
38                 (opera:option-present :port options)
39                 (parse-integer (opera:option-argument :port options) :junk-allowed t))
40             25004)))
41    (format t "Starting server on port ~A~%" port)
42    (candle:server port nil)))))
43
44 ; vim:ft=lisp