--- a/src/Pure/Isar/class.ML Fri May 14 15:27:07 2010 +0200
+++ b/src/Pure/Isar/class.ML Fri May 14 21:23:29 2010 +0200
@@ -293,7 +293,8 @@
|-> (fn (param_map, params, assm_axiom) =>
`(fn thy => calculate thy class sups base_sort param_map assm_axiom)
#-> (fn (base_morph, eq_morph, export_morph, axiom, assm_intro, of_class) =>
- Locale.add_registration (class, base_morph)
+ Locale.add_registration (class, case eq_morph of SOME eq_morph => base_morph $> eq_morph | NONE => base_morph)
+ (*FIXME should avoid modification of base morphism, but then problem with sublocale linorder < distrib_lattice*)
(Option.map (rpair true) eq_morph) export_morph
#> register class sups params base_sort base_morph export_morph axiom assm_intro of_class))
|> Theory_Target.init (SOME class)