changeset 2196:100352dbae36

Fix tricky case of functor signature subsumption
author Adam Chlipala <adam@chlipala.net>
date Fri, 27 Nov 2015 15:28:12 -0500 (2015-11-27)
parents 18e6fb487880
children 6eae499c56cb
files src/elab_env.sig src/elab_env.sml src/elaborate.sml tests/subfunctor.ur tests/subfunctor.urs
diffstat 5 files changed, 22 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/src/elab_env.sig	Wed Nov 25 18:48:17 2015 -0500
+++ b/src/elab_env.sig	Fri Nov 27 15:28:12 2015 -0500
@@ -37,6 +37,8 @@
 
     type env
 
+    val dump : env -> unit
+
     val empty : env
 
     exception UnboundRel of int
--- a/src/elab_env.sml	Wed Nov 25 18:48:17 2015 -0500
+++ b/src/elab_env.sml	Fri Nov 27 15:28:12 2015 -0500
@@ -239,6 +239,10 @@
      str : (string * sgn) IM.map
 }
 
+fun dump (env : env) =
+    (print "NamedC:\n";
+     IM.appi (fn (n, (x, k, co)) => print (x ^ " [" ^ Int.toString n ^ "]\n")) (#namedC env))
+
 val namedCounter = ref 0
 
 fun newNamed () =
--- a/src/elaborate.sml	Wed Nov 25 18:48:17 2015 -0500
+++ b/src/elaborate.sml	Fri Nov 27 15:28:12 2015 -0500
@@ -1359,7 +1359,9 @@
      end
 
  and unifyCons env loc c1 c2 =
-     unifyCons' env loc c1 c2
+     ((*Print.prefaces "uc" [("c1", p_con env c1),
+                           ("c2", p_con env c2)];*)
+     unifyCons' env loc c1 c2)
      handle CUnify' (env', err) => raise CUnify (c1, c2, env', err)
           | KUnify (arg as {3 = env', ...}) => raise CUnify (c1, c2, env', CKind arg)
 
@@ -3079,6 +3081,8 @@
 
             fun cpart n = IM.find (!counterparts, n)
             fun cparts (n2, n1) = counterparts := IM.insert (!counterparts, n2, n1)
+            fun uncparts n2 = (counterparts := #1 (IM.remove (!counterparts, n2)))
+                              handle NotFound => ()
 
             val sub2 = U.Con.map {kind = fn k => k,
                                   con = fn c =>
@@ -3107,7 +3111,8 @@
                                                           if E.checkENamed env n then
                                                               env
                                                           else
-                                                              E.pushCNamedAs env x n k (SOME c)
+                                                              (uncparts n;
+                                                               E.pushCNamedAs env x n k (SOME c))
                                                         | L'.SgiConAbs (x, n, k) =>
                                                           if E.checkENamed env n then
                                                               env
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/subfunctor.ur	Fri Nov 27 15:28:12 2015 -0500
@@ -0,0 +1,6 @@
+functor F(M : sig con fs :: {Type} end) = struct
+    open M
+
+    functor G(M : sig val x : $(map sql_injectable_prim fs) end) = struct
+    end
+end
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/subfunctor.urs	Fri Nov 27 15:28:12 2015 -0500
@@ -0,0 +1,3 @@
+functor F(M : sig con fs :: {Type} end) : sig
+    functor G(M : sig val x : $(map sql_injectable_prim M.fs) end) : sig end
+end