X-Git-Url: https://thelambdalab.xyz/gitweb/index.cgi?p=scratchy.git;a=blobdiff_plain;f=examples%2Fbrowse-git.scm;h=f9cd019be64396cfe855ab4375d794c8ae27e9d9;hp=02e755470dc5a96f76db66e01f52034136b00a08;hb=15927e29ee93ae17d2fe39becf8ff530d4dc874d;hpb=8cd0d616945d5ca6ae8d9a74a36d334b8870458f diff --git a/examples/browse-git.scm b/examples/browse-git.scm index 02e7554..f9cd019 100755 --- a/examples/browse-git.scm +++ b/examples/browse-git.scm @@ -8,17 +8,21 @@ srfi-13) (define git-base-url "git://MY.GIT.SERVER/") - (define git-base-dir "/PATH/TO/REPOS/") + (define git-base-dir "/PATH/TO/GIT/REPOS/") + (define (git . args) - (with-current-working-directory - (list git-base-dir repo) - (lambda () - (let-values (((in-port out-port id) (process "git" args))) - (let ((result (read-lines in-port))) - (close-input-port in-port) - (close-output-port out-port) - result))))) + (let ((repo-pathname (make-pathname git-base-dir repo))) + (if (not (string-prefix? git-base-dir (normalize-pathname repo-pathname))) + (error "Invalid git repository.")) + (with-current-working-directory + repo-pathname + (lambda () + (let-values (((in-port out-port id) (process "git" args))) + (let ((result (read-lines in-port))) + (close-input-port in-port) + (close-output-port out-port) + result)))))) (define (serve-tree) (let ((entries (git "ls-tree" branch path)) @@ -59,7 +63,7 @@ (for-each (lambda (line) (print line "\r")) - (git "cat-file" "blob" (conc branch "|" path))) + (git "cat-file" "blob" (conc branch ":" path))) (print ".\r")) (let ((type (string->symbol type-str)))