builder: refactored

db4
Eduardo Cavazos 2008-02-11 23:42:21 -06:00
parent 620a2ab720
commit 4f113394ec
1 changed files with 39 additions and 65 deletions

View File

@ -167,24 +167,40 @@ SYMBOL: build-status
SYMBOL: report SYMBOL: report
: >>>report ( quot -- ) report get swap with-stream* ;
: file>>>report ( file -- ) [ <file-reader> contents write ] curry >>>report ;
! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
: run-or-report ( desc quot -- )
[ [ try-process ] curry ]
[ [ >>>report throw ] curry ]
bi*
recover ;
: run-or-report-file ( desc quot file -- )
[ [ try-process ] curry ]
[ [ >>>report ] curry ]
[ [ file>>>report throw ] curry ]
tri*
compose
recover ;
! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
: (build) ( -- ) : (build) ( -- )
enter-build-dir enter-build-dir
"report" <file-writer> report set "report" <file-writer> report set
report get [ "Build machine: " write host-name write nl ] with-stream*
report get [ "Build directory: " write cwd write nl ] with-stream*
[ git-clone try-process ]
[ [
report get "Build machine: " write host-name write nl
[ "Builder fatal error: git clone failed" write nl ] "Build directory: " write cwd write nl
with-stream* ] >>>report
throw
] git-clone [ "Builder fatal error: git clone failed" write nl ] run-or-report
recover
"factor" cd "factor" cd
@ -192,74 +208,32 @@ SYMBOL: report
make-clean run-process drop make-clean run-process drop
[ make-vm try-process ] make-vm
[ [ "Builder fatal error: vm compile error" write nl ]
report get "../compile-log"
[ run-or-report-file
"Builder fatal error: vm compile error" write nl
"../compile-log" <file-reader> contents write
]
with-stream*
throw
]
recover
[ my-arch download-image ] [ my-arch download-image ]
[ [ [ "Builder fatal error: image download" write nl ] >>>report throw ]
report get
[ "Builder fatal error: image download" write nl ]
with-stream*
throw
]
recover recover
[ bootstrap try-process ] bootstrap [ "Bootstrap error" write nl ] "../boot-log" run-or-report-file
[
report get
[
"Bootstrap error" write nl
"../boot-log" <file-reader> contents write
]
with-stream*
throw
]
recover
[ builder-test try-process ] builder-test [ "Builder test error" write nl ] run-or-report
[
report get
[ "Builder test error" write nl ]
with-stream*
throw
]
recover
report get [ "Bootstrap time: " write ] >>>report "../bootstrap-time" file>>>report
[
"Bootstrap time: " write
"../bootstrap-time" <file-reader> contents write nl
]
with-stream*
"../load-everything-vocabs" exists? "../load-everything-vocabs" exists?
[ [
report get [ "Did not pass load-everything: " write nl ] >>>report
[ "../load-everything-vocabs" file>>>report
"Did not pass load-everything: " write nl
"../load-everything-vocabs" <file-reader> contents write nl
]
with-stream*
] ]
when when
"../test-all-vocabs" exists? "../test-all-vocabs" exists?
[ [
report get [ "Did not pass test-all: " write nl ] >>>report
[ "../test-all-vocabs" file>>>report
"Did not pass test-all: " write nl
"../test-all-vocabs" <file-reader> contents write nl
]
with-stream*
] ]
when ; when ;