Clone project when adding
authorFrank Duncan <frank@kank.net>
Fri, 10 Dec 2021 13:08:54 +0000 (07:08 -0600)
committerFrank Duncan <frank@kank.net>
Fri, 10 Dec 2021 13:08:54 +0000 (07:08 -0600)
src/main/base.lisp
src/main/server.lisp

index 133e5150060b14e954bec3e602fdf36b7cbe0b77..3fe9dbe1fa5749f90e42157f418aeccf63c290ee 100644 (file)
@@ -4,3 +4,6 @@
 
 (lame-db:defdbstruct project name src)
 (lame-db:defdbstruct job status sha when-run (project :join project))
 
 (lame-db:defdbstruct project name src)
 (lame-db:defdbstruct job status sha when-run (project :join project))
+
+(defun project-dir (project)
+ (format nil "~Arepos/~A/" *candle-dir* (project-name project)))
index 163ba5a891b1bd0de5f7b7e9504e2755866ca862..4a0866e54f6132f2e653010b0c65cb20199c9ca9 100644 (file)
  (when
   (not (git nil "ls-remote" src))
   (error "Project uri is not a valid git repository"))
  (when
   (not (git nil "ls-remote" src))
   (error "Project uri is not a valid git repository"))
- (make-project :name name :src src)
+ (when
+  (find name *all-project* :test #'string= :key #'project-name)
+  (error "Project name already taken"))
+ (let
+  ((project (make-project :name name :src src)))
+  (ensure-directories-exist (project-dir project))
+  (git project "clone" src "."))
  t)
 
 (defun add-job (project-name sha)
  t)
 
 (defun add-job (project-name sha)