X-Git-Url: https://git.hcoop.net/hcoop/domtool2.git/blobdiff_plain/75d4c2d6fb7996625d062f5949ceb2e66c0a70ab..06bd821502f57dcb4ef89295b221fc2b9a4f1ae3:/src/order.sml diff --git a/src/order.sml b/src/order.sml index 599c62a..b58c9f7 100644 --- a/src/order.sml +++ b/src/order.sml @@ -300,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}