X-Git-Url: https://git.hcoop.net/hcoop/domtool2.git/blobdiff_plain/76405e1e2e13a95cdb4accd6af014ee21eed2c57..4f3ef3c5a314eee12b38efa938afcbb2a27c54d6:/src/order.sml diff --git a/src/order.sml b/src/order.sml index 08db062..b58c9f7 100644 --- a/src/order.sml +++ b/src/order.sml @@ -120,6 +120,9 @@ fun expNeeded G (e, loc) = empty es | ELocal (e1, e2) => unionCTE (expNeeded G e1, expNeeded G e2) | EWith (e1, e2) => unionCTE (expNeeded G e1, expNeeded G e2) + | EIf (e1, e2, e3) => unionCTE (expNeeded G e1, + unionCTE (expNeeded G e2, + expNeeded G e3)) fun declNeeded G (d, _, _) = case d of @@ -297,6 +300,25 @@ fun order basisOpt fnames = order basisOpt (List.filter (fn fname => not (SS.member (!naughtyFiles, fname))) fnames) end +val order = fn basisOpt => fn fnames => + let + val (providers, fnames) = order basisOpt fnames + + val (hasLib, fnames) = foldl (fn (fname, (hasLib, fnames)) => + if OS.Path.file fname = "lib.dtl" then + (SOME fname, fnames) + else + (hasLib, fname :: fnames)) + (NONE, []) fnames + + val fnames = rev fnames + val fnames = case hasLib of + NONE => fnames + | SOME hasLib => hasLib :: fnames + in + (providers, fnames) + end + type providers = {provideC : string SM.map, provideT : string SM.map, provideV : string SM.map}