Make editor save source before compiling

This commit is contained in:
John Lorentzson 2025-07-29 19:52:27 +02:00
parent ab9ff442ef
commit 4f096b9820

View file

@ -766,8 +766,18 @@ Additionally ensures correct line numbers on the way, as a bonus."
(defun com-compile-buffer () (defun com-compile-buffer ()
(when *refresh-asm-functions-p* (when *refresh-asm-functions-p*
(usc:usc-init)) (usc:usc-init))
(let* ((src (buffer-string (current-buffer *editor*))) (let* ((timestring (multiple-value-bind (seconds minutes hours day month year)
(bytes (get-decoded-time)
(format nil "~D-~2,'0D-~2,'0D_~2,'0D-~2,'0D-~2,'0D"
year month day
hours minutes seconds)))
(bin-name (format nil "compiled-program_~A.bin" timestring))
(src-name (format nil "source-program_~A.c6l" timestring))
(src (buffer-string (current-buffer *editor*))))
(with-open-file (output src-name :direction :output
:if-exists :supersede)
(write-string src output))
(let ((bytes
(handler-case (handler-case
(usc:compile-string-to-bytes src :print-ir-p t) (usc:compile-string-to-bytes src :print-ir-p t)
(usc:usc-error (c) (usc:usc-error (c)
@ -775,16 +785,7 @@ Additionally ensures correct line numbers on the way, as a bonus."
(compile-fail-prompt c (car source) (cdr source))) (compile-fail-prompt c (car source) (cdr source)))
nil)))) nil))))
(unless (null bytes) (unless (null bytes)
(let* ((timestring (multiple-value-bind (seconds minutes hours day month year) (let* ()
(get-decoded-time)
(format nil "~D-~2,'0D-~2,'0D_~2,'0D-~2,'0D-~2,'0D"
year month day
hours minutes seconds)))
(bin-name (format nil "compiled-program_~A.bin" timestring))
(src-name (format nil "source-program_~A.c6l" timestring)))
(with-open-file (output src-name :direction :output
:if-exists :supersede)
(write-string src output))
(with-open-file (output bin-name :direction :output (with-open-file (output bin-name :direction :output
:element-type '(unsigned-byte 8) :element-type '(unsigned-byte 8)
:if-exists :supersede) :if-exists :supersede)
@ -795,7 +796,7 @@ Additionally ensures correct line numbers on the way, as a bonus."
'draw-transfer-progress) 'draw-transfer-progress)
(clear-screen) (clear-screen)
(redisplay-view (current-view *editor*)) (redisplay-view (current-view *editor*))
(redisplay-status-line :completely-p t))))) (redisplay-status-line :completely-p t))))))