diff options
author | Adam Chlipala <adamc@hcoop.net> | 2008-10-19 15:47:47 -0400 |
---|---|---|
committer | Adam Chlipala <adamc@hcoop.net> | 2008-10-19 15:47:47 -0400 |
commit | f47af837f76a49a6b8bcca24ea1a1e1fcfefab02 (patch) | |
tree | d6ab2f51a59206e3173d0f40da9266f3fb11fdc5 /src/monoize.sml | |
parent | 0a1e81c5811d640c00d5b5984d2254e0d8521743 (diff) |
Support for URL prefixes that works with local demo
Diffstat (limited to 'src/monoize.sml')
-rw-r--r-- | src/monoize.sml | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/src/monoize.sml b/src/monoize.sml index da7b9767..720a9485 100644 --- a/src/monoize.sml +++ b/src/monoize.sml @@ -35,6 +35,8 @@ structure L' = Mono structure IM = IntBinaryMap +val urlPrefix = ref "/" + val dummyTyp = (L'.TDatatype (0, ref (L'.Enum, [])), E.dummySpan) structure U = MonoUtil @@ -264,7 +266,7 @@ fun fooifyExp fk env = let val (_, _, _, s) = Env.lookupENamed env fnam in - ((L'.EPrim (Prim.String ("/" ^ s)), loc), fm) + ((L'.EPrim (Prim.String (!urlPrefix ^ s)), loc), fm) end | L'.EClosure (fnam, args) => let @@ -287,7 +289,7 @@ fun fooifyExp fk env = | _ => (E.errorAt loc "Type mismatch encoding attribute"; (e, fm)) in - attrify (args, ft, (L'.EPrim (Prim.String ("/" ^ s)), loc), fm) + attrify (args, ft, (L'.EPrim (Prim.String (!urlPrefix ^ s)), loc), fm) end | _ => case t of @@ -1283,8 +1285,6 @@ fun monoExp (env, st, fm) (all as (e, loc)) = val xp = " " ^ lowercaseFirst x ^ "=\"" - - val (e, fm) = fooify env fm (e, t) in ((L'.EStrcat (s, @@ -1677,6 +1677,15 @@ fun monoDecl (env, fm) (all as (d, loc)) = fun monoize env ds = let + val p = !urlPrefix + val () = + if p = "" then + urlPrefix := "/" + else if String.sub (p, size p - 1) <> #"/" then + urlPrefix := p ^ "/" + else + () + val (_, _, ds) = List.foldl (fn (d, (env, fm, ds)) => case monoDecl (env, fm) d of NONE => (env, fm, ds) |