4 test "$(uname)" = Darwin
&& {
12 now
() { echo "print_float @@ Unix.gettimeofday ()" | ocaml unix.cma
-stdin; }
15 vecho
() { ${vecho-:} "$*"; }
16 command -v md5sum >/dev
/null
&& alias sum=md5sum || true
17 test -z "${debugdeps-}" \
18 && digest
() { sum $
* 2>/dev
/null |
while read h _
; do printf "$h"; done; } \
19 || digest
() { sum $
* 2>/dev
/null
; }
22 test $?
-eq 0 && msg
="ok" || msg
="ko"
23 echo "$msg $(echo "scale
=3; ($
(now
) - $tstart)/1" | bc -l) sec"
33 test $
(ocamlc
-version |
{ IFS
=.
read a b _
; echo $a$b; }) -lt 406 && {
34 die OCaml version
4.06+ is required
37 test -n "${1-}" || die
"usage: $0 build-directory"
42 muinc
="-I $mudir/include -I $mudir/thirdparty/freetype/include"
45 test -e "$1" && test -r "$1.past" && {
51 test "${USER-}" = "malc" && {
52 keycmd
="cd $mudir && git describe --tags --dirty"
53 isfresh
"$outd/mupdf" "$(eval $keycmd)" ||
(
55 make -C "$mudir" CC
='ccache gcc' build
=native
-j4 libs
&& :>$outd/mupdf
56 echo "k=$(eval $keycmd)" >$outd/mupdf.past
57 ) && vecho
"fresh mupdf"
62 main.cmo|utils.cmo|config.cmo|parser.cmo|wsi.cmi|
$wsi/wsi.cmo
)
63 f
="-g -strict-sequence -strict-formats -warn-error a";;
72 f
="-g -std=c99 -O2 $muinc -Wall -Werror -pedantic-errors"
74 $darwin && echo "$f -D__COCOA__" ||
echo $f;;
75 keysym2ucs.o
) echo "-DKeySym=long";;
76 */ml_gl.o
) echo "-g -Wno-pointer-sign -O2";;
81 mflags
() { echo "-I $(ocamlc -where) -g -O2"; }
85 ocamlc
-depend -bytecode -one-line $
(echo $incs) $s |
{
87 depl
=$
(eval echo $depl)
89 bocaml
${d#$srcd/} $
((n
+1))
90 test $d = "build/help.cmo" \
91 && dd=$outd/help.cmo ||
dd=$outd/${d#$srcd/}
92 printf "$dd " >>$o.depl
95 cmd
="ocamlc $(oflags $o) -c -o $o $s"
96 keycmd
="digest $s $(cat $o.depl)"
97 grep -q "$o" $outd/ordered ||
{
98 echo "$o" >>"$outd/ordered"
99 isfresh
"$o" "$cmd$(eval $keycmd)" ||
{
100 printf "%*.s%s -> %s\n" $n '' "${s#$srcd/}" "${o#$outd/}"
101 eval "$cmd" || die
"$cmd failed"
102 echo "k='$cmd$(eval $keycmd)'" >"$o.past"
103 } && vecho
"fresh '$o'"
111 test ${wocmi%help.cmo} != $wocmi && {
115 test "$o" = "$wocmi" && s
=$srcd/${o%.cmo}.ml || s
=$srcd/$wocmi.mli
118 incs
="-I $srcd/lablGL -I $srcd/$wsi -I $srcd"
119 incs
="$incs -I $outd/lablGL -I $outd/$wsi -I $outd"
126 cmd
="ocamlc -ccopt \"$(cflags $o) -MMD -MF $o.dep -MT_ -o $o\" $s"
127 test -r $o.dep
&& read _ d
<$o.dep || d
=
128 keycmd
='digest $o $d'
129 isfresh
"$o" "$cmd$(eval $keycmd)" ||
{
130 printf "%s -> %s\n" "${s#$srcd/}" "${o#$outd/}"
131 eval "$cmd" || die
"$cmd failed"
133 echo "k='$cmd$(eval $keycmd)'" >"$o.past"
134 } && vecho
"fresh $o"
140 cmd
="$mcomp $(mflags $o) -MMD -MF $o.dep -MT_ -c -o $o $s"
141 test -r $o.dep
&& read _ d
<$o.dep || d
=
142 keycmd
='digest $o $d'
143 isfresh
"$o" "$cmd$(eval $keycmd)" ||
{
144 printf "%s -> %s\n" "${s#$srcd/}" "${o#$outd/}"
147 echo "k='$cmd$(eval $keycmd)'" >"$o.past"
148 } && vecho
"fresh $o"
152 mkdir
-p $outd/lablGL
156 ocaml str.cma
-stdin $srcd/KEYS
<<EOF
157 let fixup = let open Str in
158 let dash = regexp {|\([^ ]*\) +- +\(.*\)|}
159 and head = regexp {|-----\(.*\)-----|} in fun s ->
160 String.escaped s |> global_replace dash {|\1\t\2|}
161 |> global_replace head {|\xc2\xb7\1|};;
162 let rec iter ic = match input_line ic with
163 | s -> Printf.printf "\"%s\";\\n" @@ fixup s; iter ic
164 | exception End_of_file -> ();;
165 Printf.printf "let keys = [\\n";
166 iter @@ open_in Sys.argv.(1);;
167 Printf.printf "] and version = \"$ver\";;"
171 ver
=$
(cd $srcd && git describe
--tags --dirty) || ver
=unknown
172 cmd
="mkhelp >$outd/help.ml"
173 keycmd
="digest $srcd/KEYS; echo $ver"
174 isfresh
"$outd/help.ml" '$cmd$(eval $keycmd)' ||
{
176 echo "k='$cmd$(eval $keycmd)'" >"$outd/help.ml.past"
177 } && vecho
"fresh $outd/help.ml"
183 for m
in llpp llppac llpphtml
; do
187 keycmd
="digest $xml $man"
188 conf
="$srcd/man/asciidoc.conf"
189 cmd
="asciidoc -d manpage -b docbook -f $conf -o '$xml' '$man'"
190 isfresh
"$xml" "$cmd$(eval $keycmd)" ||
{
192 echo "k='$cmd$(eval $keycmd)'" >"$md/$m.past"
193 } && vecho
"fresh manual xmls"
194 keycmd
="digest $out $xml"
195 cmd
="xmlto man -o $md $xml"
196 isfresh
"$out" "$cmd$(eval $keycmd)" ||
{
198 echo "k='$cmd$(eval $keycmd)'" >"$out.past"
199 } && vecho
"fresh manual pages"
205 # following is disgusting (from "generalize everything" perspective),
206 # but generic method of derviving .ml's location from .mli's is not
207 # immediately obvious
208 for m
in lablGL
/glMisc.cmo lablGL
/glTex.cmo
$wsi/wsi.cmo main.cmo
; do
212 for m
in keysym2ucs.o link.o
; do
214 cobjs
="$cobjs $outd/$m"
217 libs
="str.cma unix.cma"
218 clibs
="-L$mudir/build/native -lmupdf -lmupdfthird -lpthread"
220 mcomp
=$
(ocamlc
-config |
grep bytecomp_c_co |
{ read _ c
; echo $c; })
221 clibs
="$clibs -framework Cocoa -framework OpenGL"
223 cobjs
="$cobjs $outd/main_osx.o"
225 clibs
="$clibs -lGL -lX11"
229 for f
in ml_gl ml_glarray ml_raw
; do
231 globjs
="$globjs $outd/lablGL/$f.o"
234 ord
=$
(echo $
(grep -v \.cmi
$outd/ordered
))
235 cmd
="ocamlc -custom $libs -o $outd/llpp $cobjs $ord"
236 cmd
="$cmd $globjs -cclib \"$clibs\""
237 keycmd
="digest $outd/llpp $cobjs $ord"
238 isfresh
"$outd/llpp" "$cmd$(eval $keycmd)" ||
{
239 echo linking
$outd/llpp
240 eval $cmd || die
"$cmd failed"
241 echo "k='$cmd$(eval $keycmd)'" >"$outd/llpp.past"
242 } && vecho
"fresh llpp"
245 out
="$outd/llpp.app/Contents/Info.plist"
246 keycmd
="digest $out $srcd/misc/Info.plist.sh"
247 isfresh
$out "$(eval $keycmd)" ||
{
248 shortver
=$
(echo $ver |
{ IFS
='-' read s _
; echo ${s#v}; })
250 test -d "$d" || mkdir
-p "$d"
251 .
$srcd/misc
/Info.plist.sh
>"$out"
252 echo "k=$(eval $keycmd)" >"$out.past"
253 } && vecho
"fresh plist"
255 out
=$outd/llpp.app
/Contents
/MacOS
/llpp
256 keycmd
="digest $out $outd/llpp"
257 isfresh
$out "$(eval $keycmd)" ||
{
261 echo "k=$(eval $keycmd)" >"$out.past"
262 } && vecho
"fresh bundle"