- | GrafiteTypes.CommandMode ls -> ls
- in
- let nmenv, nsubst, nlexicon_status, nty =
- GrafiteDisambiguate.disambiguate_nterm None
- nlexicon_status [] [] [] (text,prefix_len,ty)
- in
- let nmenv, nsubst, nlexicon_status, nbo =
- GrafiteDisambiguate.disambiguate_nterm (Some nty)
- nlexicon_status [] nmenv nsubst ("",0,CicNotationPt.Implicit)
- in
- let ninitial_stack = Continuationals.Stack.of_nmetasenv nmenv in
- prerr_endline ("nuovo lemma: " ^ NCicPp.ppmetasenv ~subst:nsubst nmenv);
- { status with
- GrafiteTypes.ng_status =
- GrafiteTypes.ProofMode { NTacStatus.gstatus = ninitial_stack;
- istatus = {
- NTacStatus.pstatus =
- NUri.uri_of_string suri, 0, nmenv, nsubst,
- (NCic.Constant ([],"",Some nbo,nty,(`Provided,`Definition,`Regular)));
- lstatus = nlexicon_status} }
- },
- []
+ | GrafiteTypes.CommandMode ls -> ls in
+ let lexicon_status,obj =
+ GrafiteDisambiguate.disambiguate_nobj lexicon_status
+ ~baseuri:(GrafiteTypes.get_baseuri status) (text,prefix_len,obj) in
+ let uri,height,nmenv,nsubst,nobj = obj in
+ (match nmenv with
+ [] ->
+ (* CSC: cut&paste code from NQed *)
+ let obj =
+prerr_endline "CSC: here we should fix the height!!!";
+ uri,height,[],[],
+ NCicUntrusted.map_obj_kind (NCicUntrusted.apply_subst nsubst) nobj
+ in
+ NCicLibrary.add_obj uri obj;
+ {status with
+ GrafiteTypes.ng_status=GrafiteTypes.CommandMode lexicon_status },
+ `New [uri]
+ | _ ->
+ let ninitial_stack = Continuationals.Stack.of_nmetasenv nmenv in
+ { status with
+ GrafiteTypes.ng_status =
+ GrafiteTypes.ProofMode
+ { NTacStatus.gstatus = ninitial_stack;
+ istatus = { NTacStatus.pstatus = obj; lstatus = lexicon_status}}
+ },`New [])