From 84c986dffe7a85c87b80e6d736b3b36e460ff4dd Mon Sep 17 00:00:00 2001 From: Juan MarĂ­n Noguera Date: Thu, 5 Dec 2024 13:24:52 +0100 Subject: Update instructions to apply to Guile Also rename `main` to `main.lua` and `main.scm` to `main`. --- main | 64 +++++++++++++++++++++++++++++++++++----------------------------- 1 file changed, 35 insertions(+), 29 deletions(-) (limited to 'main') diff --git a/main b/main index 38189ee..39f8da9 100755 --- a/main +++ b/main @@ -1,29 +1,35 @@ -#!/usr/bin/lua - -if #arg < 1 or #arg > 2 then - error ("Syntax: %s [inputfile]"):format(arg[0]) - os.exit(1) -end - -local num, letter = arg[1]:match("^(%d+)([ab])$") -if not num then - error ('Expected as first argument (e.g. "01b"), got: %s'):format(arg[1]) - os.exit(1) -end -num = tonumber(num) - -local script = ("%02d.lua"):format(num) -local infile = arg[2] or ("%02d.in"):format(num) -local input_stream = io.open(infile) -if input_stream then - io.input(input_stream) -else - print "Reading from standard input." -end - -local parsed = loadfile(script)() -if letter == 'a' then - parsed:part1() -else - parsed:part2() -end +#!/usr/bin/env guile +!# + +(use-modules (ice-9 format) (ice-9 regex)) + +(define args (program-arguments)) + +(unless (<= 2 (length args) 3) + (error (format #f "Syntax: ~a [INFILE]\n" (car args))) + (exit 1)) + +(define mtch (string-match "^([0-9]+)(a|b)$" (list-ref args 1))) + +(unless mtch + (error (format #f "Expected day and part (like \"03a\" or \"02b\"), got: ~a" + (list-ref args 1)))) + +(define day (format #f "~2,'0d" (string->number (match:substring mtch 1)))) +(define part (if (string= (match:substring mtch 2) "a") 'part1 'part2)) + +(set! %load-path (cons "." %load-path)) + +(define day-module + (resolve-module (list (string->symbol (string-append "day" day))))) +(define func (module-ref day-module part)) + +(define input-file + (cond ((= (length args) 2) (string-append day ".in")) + ((string= (list-ref args 2) "-") #f) + (else (list-ref args 2)))) + +(display (if input-file + (call-with-input-file input-file func) + (func (current-input-port)))) +(newline) -- cgit v1.2.3