keep three modules, just for imported stuff.

This commit is contained in:
Vítor Santos Costa 2014-10-05 23:53:05 +01:00
parent 64e7e7e663
commit 9f00389e52
2 changed files with 119 additions and 115 deletions

View File

@ -280,7 +280,7 @@ private(_).
:- use_system_module( '$_modules', ['$get_undefined_pred'/4, :- use_system_module( '$_modules', ['$get_undefined_pred'/4,
'$meta_expansion'/6, '$meta_expansion'/6,
'$module_expansion'/5]). '$module_expansion'/6]).
:- use_system_module( '$_preddecls', ['$dynamic'/2]). :- use_system_module( '$_preddecls', ['$dynamic'/2]).
@ -649,11 +649,11 @@ number of steps.
; ;
'$execute_commands'(O,VL,Pos,Option,O) '$execute_commands'(O,VL,Pos,Option,O)
). ).
'$execute_command'((?-G), V, Pos, Option, Source) :- '$execute_command'((?-G), VL, Pos, Option, Source) :-
Option \= top, !, Option \= top, !,
'$execute_command'(G, V, Pos, top, Source). '$execute_command'(G, VL, Pos, top, Source).
'$execute_command'(G, V, Pos, Option, Source) :- '$execute_command'(G, VL, Pos, Option, Source) :-
'$continue_with_command'(Option, V, Pos, G, Source). '$continue_with_command'(Option, VL, Pos, G, Source).
% %
% This command is very different depending on the language mode we are in. % This command is very different depending on the language mode we are in.
@ -715,22 +715,27 @@ number of steps.
% not 100% compatible with SICStus Prolog, as SICStus Prolog would put % not 100% compatible with SICStus Prolog, as SICStus Prolog would put
% module prefixes all over the place, although unnecessarily so. % module prefixes all over the place, although unnecessarily so.
% %
'$go_compile_clause'(G,V,Pos,N,Source) :- % G is the goal to compile
% Vs the named variables
% Pos the source position
% N where to add first or last
% Source the original clause
'$go_compile_clause'(G,Vs,Pos,N,Source) :-
'$current_module'(Mod), '$current_module'(Mod),
'$go_compile_clause'(G,V,Pos,N,Mod,Mod,Source). '$go_compile_clause'(G,Vs,Pos,N,Mod,Mod,Mod,Source).
'$go_compile_clause'(G,_,_,_,_,_,Source) :- '$go_compile_clause'(G,_Vs,_Pos,_N,_HM,_BM,_SM,Source) :-
var(G), !, var(G), !,
'$do_error'(instantiation_error,assert(Source)). '$do_error'(instantiation_error,assert(Source)).
'$go_compile_clause'((G:-_),_,_,_,_,_,Source) :- '$go_compile_clause'((G:-_),_Vs,_Pos,_N,_HM,_BM,_SM,Source) :-
var(G), !, var(G), !,
'$do_error'(instantiation_error,assert(Source)). '$do_error'(instantiation_error,assert(Source)).
'$go_compile_clause'(M:G,V,Pos,N,_,_,Source) :- !, '$go_compile_clause'(M:G,Vs,Pos,N,_,_,SourceMod,Source) :- !,
'$go_compile_clause'(G,V,Pos,N,M,M,Source). '$go_compile_clause'(G,Vs,Pos,N,M,M,M,Source).
'$go_compile_clause'((M:H :- B),V,Pos,N,_,BodyMod,Source) :- !, '$go_compile_clause'((M:H :- B),Vs,Pos,N,_,BodyMod,SourceMod,Source) :- !,
'$go_compile_clause'((H :- B),V,Pos,N,M,BodyMod,Source). '$go_compile_clause'((H :- B),Vs,Pos,N,M,BodyMod,SourceMod,Source).
'$go_compile_clause'(G,V,Pos,N,HeadMod,BodyMod,Source) :- !, '$go_compile_clause'(G,Vs,Pos,N,HeadMod,BodyMod,SourceMod,Source) :- !,
'$precompile_term'(G, G0, G1, BodyMod, SourceMod), '$precompile_term'(G, G0, G1, HeadMod, BodyMod, SourceMod),
'$$compile'(G1, G0, N, HeadMod). '$$compile'(G1, G0, N, HeadMod).
@ -1399,9 +1404,9 @@ bootstrap(F) :-
% return two arguments: Expanded0 is the term after "USER" expansion. % return two arguments: Expanded0 is the term after "USER" expansion.
% Expanded is the final expanded term. % Expanded is the final expanded term.
% %
'$precompile_term'(Term, Expanded0, Expanded, BodyMod, SourceMod) :- '$precompile_term'(Term, Expanded0, Expanded, HeadMod, BodyMod, SourceMod) :-
%format('[ ~w~n',[Term]), %format('[ ~w~n',[Term]),
'$module_expansion'(Term, Expanded0, ExpandedI, BodyMod, SourceMod), !, '$module_expansion'(Term, Expanded0, ExpandedI, HeadMod, BodyMod, SourceMod), !,
%format(' -> ~w~n',[Expanded0]), %format(' -> ~w~n',[Expanded0]),
( (
'$access_yap_flags'(9,1) /* strict_iso on */ '$access_yap_flags'(9,1) /* strict_iso on */
@ -1411,7 +1416,7 @@ bootstrap(F) :-
; ;
'$expand_array_accesses_in_term'(ExpandedI,Expanded) '$expand_array_accesses_in_term'(ExpandedI,Expanded)
). ).
'$precompile_term'(Term, Term, Term, _, _). '$precompile_term'(Term, Term, Term, _, _, _).
/** @pred expand_term( _T_,- _X_) /** @pred expand_term( _T_,- _X_)

View File

@ -164,7 +164,7 @@ not at all defined.
'$meta_predicate'/4, '$meta_predicate'/4,
'$module'/3, '$module'/3,
'$module'/4, '$module'/4,
'$module_expansion'/5, '$module_expansion'/6,
'$module_transparent'/2, '$module_transparent'/2,
'$module_transparent'/4]). '$module_transparent'/4]).
@ -563,7 +563,7 @@ source_module(Mod) :-
'$current_module'(Mod). '$current_module'(Mod).
% expand module names in a clause % expand module names in a clause (interface predicate).
% A1: Input Clause % A1: Input Clause
% A2: Output Class to Compiler (lives in module HM) % A2: Output Class to Compiler (lives in module HM)
% A3: Output Class to clause/2 and listing (lives in module HM) % A3: Output Class to clause/2 and listing (lives in module HM)
@ -574,19 +574,19 @@ source_module(Mod) :-
% A6: head module (this is the one used in compiling and accessing). % A6: head module (this is the one used in compiling and accessing).
% %
% %
'$module_expansion'(H,H,H,_M,_HM) :- var(H), !. '$module_expansion'(H, H, H, _HM, _BM, _SM) :- var(H), !.
'$module_expansion'((H:-B),(H:-B1),(H:-BOO),M,HM) :- !, '$module_expansion'((H:-B), (H:-B1), (H:-BOO), HM, BM, SM) :- !,
'$is_mt'(M, H, B, IB, MM), '$is_mt'(HM, H, SM, B, IB, MM),
'$module_u_vars'(H,UVars,M), % collect head variables in '$module_u_vars'(H,UVars,HM), % collect head variables in
% expanded positions % expanded positions
'$module_expansion'(IB,B1,BO,M,MM,HM,UVars), '$expand_modules'(IB, B1, BO, HM, BM, MM, UVars),
('$full_clause_optimisation'(H, M, BO, BOO) -> ('$full_clause_optimisation'(H, SM, BO, BOO) ->
true true
; ;
BO = BOO BO = BOO
). ).
% do not expand bodyless clauses. % do not expand bodyless clauses.
'$module_expansion'(H,H,H,_,_). '$module_expansion'(H,H,H,_,_,_).
'$trace_module'(X) :- '$trace_module'(X) :-
@ -642,7 +642,7 @@ source_module(Mod) :-
% A6: head module (this is the one used in compiling and accessing). % A6: head module (this is the one used in compiling and accessing).
% %
% %
'$module_expansion'(V,NG,NG,_,SM,_,HVars) :- '$expand_modules'(V,NG,NG,_,_,SM,HVars) :-
var(V), !, var(V), !,
( '$not_in_vars'(V,HVars) ( '$not_in_vars'(V,HVars)
-> ->
@ -650,49 +650,49 @@ source_module(Mod) :-
; ;
NG = call(V) NG = call(V)
). ).
'$module_expansion'((A,B),(A1,B1),(AO,BO),M,SM,HM,HVars) :- !, '$expand_modules'((A,B),(A1,B1),(AO,BO),HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AO,M,SM,HM,HVars), '$expand_modules'(A,A1,AO,HM,BM,SM,HVars),
'$module_expansion'(B,B1,BO,M,SM,HM,HVars). '$expand_modules'(B,B1,BO,HM,BM,SM,HVars).
'$module_expansion'((A;B),(A1;B1),(AO;BO),M,SM,HM,HVars) :- var(A), !, '$expand_modules'((A;B),(A1;B1),(AO;BO),HM,BM,SM,HVars) :- var(A), !,
'$module_expansion'(A,A1,AO,M,SM,HM,HVars), '$expand_modules'(A,A1,AO,HM,BM,SM,HVars),
'$module_expansion'(B,B1,BO,M,SM,HM,HVars). '$expand_modules'(B,B1,BO,HM,BM,SM,HVars).
'$module_expansion'((A*->B;C),(A1*->B1;C1),(yap_hacks:current_choicepoint(DCP),AO,yap_hacks:cut_at(DCP),BO; CO),M,SM,HM,HVars) :- !, '$expand_modules'((A*->B;C),(A1*->B1;C1),(yap_hacks:current_choicepoint(DCP),AO,yap_hacks:cut_at(DCP),BO; CO),HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AOO,M,SM,HM,HVars), '$expand_modules'(A,A1,AOO,HM,BM,SM,HVars),
'$clean_cuts'(AOO, AO), '$clean_cuts'(AOO, AO),
'$module_expansion'(B,B1,BO,M,SM,HM,HVars), '$expand_modules'(B,B1,BO,HM,BM,SM,HVars),
'$module_expansion'(C,C1,CO,M,SM,HM,HVars). '$expand_modules'(C,C1,CO,HM,BM,SM,HVars).
'$module_expansion'((A;B),(A1;B1),(AO;BO),M,SM,HM,HVars) :- !, '$expand_modules'((A;B),(A1;B1),(AO;BO),HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AO,M,SM,HM,HVars), '$expand_modules'(A,A1,AO,HM,BM,SM,HVars),
'$module_expansion'(B,B1,BO,M,SM,HM,HVars). '$expand_modules'(B,B1,BO,HM,BM,SM,HVars).
'$module_expansion'((A|B),(A1|B1),(AO|BO),M,SM,HM,HVars) :- !, '$expand_modules'((A|B),(A1|B1),(AO|BO),HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AO,M,SM,HM,HVars), '$expand_modules'(A,A1,AO,HM,BM,SM,HVars),
'$module_expansion'(B,B1,BO,M,SM,HM,HVars). '$expand_modules'(B,B1,BO,HM,BM,SM,HVars).
'$module_expansion'((A->B),(A1->B1),(AO->BO),M,SM,HM,HVars) :- !, '$expand_modules'((A->B),(A1->B1),(AO->BO),HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AOO,M,SM,HM,HVars), '$expand_modules'(A,A1,AOO,HM,BM,SM,HVars),
'$clean_cuts'(AOO, AO), '$clean_cuts'(AOO, AO),
'$module_expansion'(B,B1,BO,M,SM,HM,HVars). '$expand_modules'(B,B1,BO,HM,BM,SM,HVars).
'$module_expansion'(\+A,\+A1,\+AO,M,SM,HM,HVars) :- !, '$expand_modules'(\+A,\+A1,\+AO,HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AO,M,SM,HM,HVars). '$expand_modules'(A,A1,AO,HM,BM,SM,HVars).
'$module_expansion'(not(A),not(A1),not(AO),M,SM,HM,HVars) :- !, '$expand_modules'(not(A),not(A1),not(AO),HM,BM,SM,HVars) :- !,
'$module_expansion'(A,A1,AO,M,SM,HM,HVars). '$expand_modules'(A,A1,AO,HM,BM,SM,HVars).
'$module_expansion'(true,true,true,_,_,_,_) :- !. '$expand_modules'(true,true,true,_,_,_,_) :- !.
'$module_expansion'(fail,fail,fail,_,_,_,_) :- !. '$expand_modules'(fail,fail,fail,_,_,_,_) :- !.
'$module_expansion'(false,false,false,_,_,_,_) :- !. '$expand_modules'(false,false,false,_,_,_,_) :- !.
% if I don't know what the module is, I cannot do anything to the goal, % if I don't know what the module is, I cannot do anything to the goal,
% so I just put a call for later on. % so I just put a call for later on.
'$module_expansion'(M:G,call(M:G),'$execute_wo_mod'(G,M),_,_,_,_) :- var(M), !. '$expand_modules'(M:G,call(M:G),'$execute_wo_mod'(G,M),_,_,_,_) :- var(M), !.
'$module_expansion'(M:G,G1,GO,_,_CM,HM,HVars) :- !, '$expand_modules'(M:G,G1,GO,HM,_M,_SM,HVars) :- !,
'$module_expansion'(G,G1,GO,M,M,HM,HVars). '$expand_modules'(G,G1,GO,HM,M,M,HVars).
'$module_expansion'(G, G1, GO, CurMod, SM, HM,HVars) :- '$expand_modules'(G, G1, GO, HM, BM, SM, HVars) :-
% is this imported from some other module M1? % is this imported from some other module M1?
'$imported_pred'(G, CurMod, GG, M1), '$imported_pred'(G, BM, GG, M1),
!, !,
'$module_expansion'(GG, G1, GO, M1, SM, HM,HVars). '$expand_modules'(GG, G1, GO, HM, M1, SM, HVars).
'$module_expansion'(G, G1, GO, CurMod, SM, HM,HVars) :- '$expand_modules'(G, G1, GO, HM, BM, SM, HVars) :-
'$meta_expansion'(G, CurMod, SM, HM, GI, HVars), !, '$meta_expansion'(G, HM, BM, SM, GI, HVars), !,
'$complete_goal_expansion'(GI, CurMod, SM, HM, G1, GO, HVars). '$complete_goal_expansion'(GI, HM, BM, SM, G1, GO, HVars).
'$module_expansion'(G, G1, GO, CurMod, SM, HM, HVars) :- '$expand_modules'(G, G1, GO, HM, BM, SM, HVars) :-
'$complete_goal_expansion'(G, CurMod, SM, HM, G1, GO, HVars). '$complete_goal_expansion'(G, HM, BM, SM, G1, GO, HVars).
expand_goal(G, G) :- expand_goal(G, G) :-
var(G), !. var(G), !.
@ -703,15 +703,14 @@ expand_goal(G, NG) :-
'$do_expand'(G, Mod, prolog, [], NG), !. '$do_expand'(G, Mod, prolog, [], NG), !.
expand_goal(G, G). expand_goal(G, G).
'$do_expand'(G, _, _, _, G) :- var(G), !. '$do_expand'(G, _HM, _BM, _SM, _, G) :- var(G), !.
'$do_expand'(M:G, _CurMod, SM, HVars, M:GI) :- !, '$do_expand'(M:G, HM, _BM, _SM, HVars, M:GI) :- !,
nonvar(M), nonvar(M),
'$do_expand'(G, M, SM, HVars, GI). '$do_expand'(G, HM, M, M, HVars, GI).
'$do_expand'(G, CurMod, _SM, _HVars, GI) :- '$do_expand'(G, HM, BM, SM, _HVars, GI) :-
nonvar(G),
( (
'$pred_exists'(goal_expansion(G,GI), CurMod), '$pred_exists'(goal_expansion(G,GI), SM),
call(CurMod:goal_expansion(G, GI)) call(SM:goal_expansion(G, GI))
-> ->
true true
; ;
@ -720,51 +719,51 @@ expand_goal(G, G).
-> ->
true true
; ;
user:goal_expansion(G, CurMod, GI) user:goal_expansion(G, SM, GI)
-> ->
true true
; ;
user:goal_expansion(G, GI) user:goal_expansion(G, GI)
), !. ), !.
'$do_expand'(G, CurMod, SM, HVars, NG) :- '$do_expand'(G, HM, BM, SM, HVars, NG) :-
'$is_metapredicate'(G,CurMod), !, '$is_metapredicate'(G,BM), !,
functor(G, Name, Arity), functor(G, Name, Arity),
prolog:'$meta_predicate'(Name,CurMod,Arity,PredDef), prolog:'$meta_predicate'(Name,BM,Arity,PredDef),
G =.. [Name|GArgs], G =.. [Name|GArgs],
PredDef =.. [Name|GDefs], PredDef =.. [Name|GDefs],
'$expand_args'(GArgs, CurMod, SM, GDefs, HVars, NGArgs), '$expand_args'(GArgs, HM, BM, SM, GDefs, HVars, NGArgs),
NG =.. [Name|NGArgs]. NG =.. [Name|NGArgs].
'$expand_args'([], _, _, [], _, []). '$expand_args'([], _, _, _, [], _, []).
'$expand_args'([A|GArgs], CurMod, SM, [0|GDefs], HVars, [NA|NGArgs]) :- '$expand_args'([A|GArgs], HM, BM, SM, [0|GDefs], HVars, [NA|NGArgs]) :-
'$do_expand'(A, CurMod, SM, HVars, NA), !, '$do_expand'(A, HM, BM, SM, HVars, NA), !,
'$expand_args'(GArgs, CurMod, SM, GDefs, HVars, NGArgs). '$expand_args'(GArgs, HM, BM, SM, GDefs, HVars, NGArgs).
'$expand_args'([A|GArgs], CurMod, SM, [_|GDefs], HVars, [A|NGArgs]) :- '$expand_args'([A|GArgs], HM, BM, SM, [_|GDefs], HVars, [A|NGArgs]) :-
'$expand_args'(GArgs, CurMod, SM, GDefs, HVars, NGArgs). '$expand_args'(GArgs, HM, BM, SM, GDefs, HVars, NGArgs).
% args are: % args are:
% goal to expand % goal to expand
% current module for looking up pred % current module for looking up pred
% context module
% current module from head of clause % current module from head of clause
% context module
% :- module(m, []). o:p :- n:(g, l). % :- module(m, []). o:p :- n:(g, l).
% % would be o, n, m.
% goal to pass to listing % goal to pass to listing
% goal to pass to compiler % goal to pass to compiler
% head variables. % head variables.
'$complete_goal_expansion'(G, CurMod, SM, HM, G1, GO, HVars) :- '$complete_goal_expansion'(G, HM, BM, SM, G1, GO, HVars) :-
% '$pred_goal_expansion_on', % '$pred_goal_expansion_on',
'$do_expand'(G, CurMod, SM, HVars, GI), '$do_expand'(G, HM, BM, SM, HVars, GI),
GI \== G, !, GI \== G, !,
'$module_expansion'(GI, G1, GO, CurMod, SM, HM, HVars). '$expand_modules'(GI, G1, GO, HM, BM, SM, HVars).
'$complete_goal_expansion'(G, M, _SM, HM, G1, G2, _HVars) :- '$complete_goal_expansion'(G, HM, BM, SM, G1, G2, _HVars) :-
'$all_system_predicate'(G,M,ORIG), !, '$all_system_predicate'(G, M, ORIG), !,
% make built-in processing transparent. % make built-in processing transparent.
'$match_mod'(G, M, ORIG, HM, G1), '$match_mod'(G, M, ORIG, HM, G1),
'$c_built_in'(G1, M, Gi), '$c_built_in'(G1, M, Gi),
Gi = G2. Gi = G2.
'$complete_goal_expansion'(G, GMod, _, HM, NG, NG, _) :- '$complete_goal_expansion'(G, HM, BM, SM, NG, NG, _) :-
'$match_mod'(G, GMod, GMod, HM, NG). '$match_mod'(G, BM, BM, HM, NG).
%'$match_mod'(G, GMod, GMod, NG) :- !, %'$match_mod'(G, GMod, GMod, NG) :- !,
% NG = G. % NG = G.
@ -925,49 +924,49 @@ meta_predicate declaration
% $meta_expansion(ModuleWhereDefined,CurrentModule,Goal,ExpandedGoal,MetaVariables) % $meta_expansion(ModuleWhereDefined,CurrentModule,Goal,ExpandedGoal,MetaVariables)
'$meta_expansion'(G,Mod,MP,HM,G1,HVars) :- '$meta_expansion'(G, HM, BM, SM, G1,HVars) :-
functor(G,F,N), functor(G,F,N),
'$meta_predicate'(F,Mod,N,D), !, % we're in an argument '$meta_predicate'(F,BM,N,D), !, % we're in an argument
% format(user_error,'[ ~w ',[G]), % format(user_error,'[ ~w (~a, ~a, ~a)',[G, HM, BM, SM]),
functor(G1,F,N), functor(G1,F,N),
'$meta_expansion_loop'(N, D, G, G1, HVars, Mod, MP, HM). '$meta_expansion_loop'(N, D, G, G1, HVars, HM, BM, SM).
% format(user_error,' gives ~w]`n',[G1]). % format(user_error,' gives ~w]~n',[G1]).
% expand argument % expand argument
'$meta_expansion_loop'(0,_,_,_,_,_,_,_) :- !. '$meta_expansion_loop'(0,_,_,_,_,_,_,_) :- !.
'$meta_expansion_loop'(I,D,G,NG,HVars,CurMod,M,HM) :- '$meta_expansion_loop'(I,D,G,NG,HVars, HM, BM, SM) :-
arg(I,D,X), (X==':' -> true ; integer(X)), arg(I,D,X),
(X==':' -> true ; integer(X)),
arg(I,G,A), arg(I,G,A),
'$should_expand'(A,HVars), '$should_expand'(A,HVars),
!, !,
( X ==0 -> ( X ==0 ->
'$values'('$c_arith',Old, false), '$values'('$c_arith',Old, false),
'$meta_expansion0'(A,CurMod,M,HM,NA,HVars), '$meta_expansion0'(A, HM, BM, SM, NA, HVars),
'$values'('$c_arith', _False, Old) '$values'('$c_arith', _False, Old)
; ;
NA = M:A NA = SM:A
), ),
arg(I,NG,NA), arg(I,NG,NA),
I1 is I-1, I1 is I-1,
'$meta_expansion_loop'(I1, D, G, NG, HVars, CurMod, M, HM). '$meta_expansion_loop'(I1, D, G, NG, HVars, HM, BM, SM).
'$meta_expansion_loop'(I, D, G, NG, HVars, CurMod, M, HM) :- '$meta_expansion_loop'(I, D, G, NG, HVars, HM, BM, SM) :-
arg(I,G,A), arg(I,G,A),
arg(I,NG,A), arg(I,NG,A),
I1 is I-1, I1 is I-1,
'$meta_expansion_loop'(I1, D, G, NG, HVars, CurMod, M, HM). '$meta_expansion_loop'(I1, D, G, NG, HVars, HM, BM, SM).
'$meta_expansion0'(G,_Mod,MP,_HM, G1,_HVars) :- '$meta_expansion0'(G, _HM, _BM, SM, SM:G, _HVars) :-
var(G), !, var(G), !.
G1 = MP:G. '$meta_expansion0'(M:G, _HM, _BM, SM, G1, _HVars) :-
'$meta_expansion0'(M:G,_Mod,_MP,_HM,G1,_HVars) :-
var(M), !, var(M), !,
G1 = '$execute_wo_mod'(G,M). G1 = '$execute_wo_mod'(G,SM).
% support for all/3 % support for all/3
'$meta_expansion0'(same(G, P),Mod,MP,HM, same(G1, P),HVars) :- !, '$meta_expansion0'(same(G, P), HM, BM, SM, same(G1, P),HVars) :- !,
'$meta_expansion0'(G,Mod,MP,HM,G1,HVars). '$meta_expansion0'(G, _HM, BM, SM, G1,HVars).
'$meta_expansion0'(G,Mod,MP,HM,M1:G1,HVars) :- '$meta_expansion0'(G, HM, BM, SM, M1:G1,HVars) :-
strip_module(Mod:G,M1,G1). strip_module(SM:G,M1,G1).
% check if an argument should be expanded % check if an argument should be expanded
@ -1004,9 +1003,9 @@ its parent goal.
NFlags is Fl \/ 0x200004, NFlags is Fl \/ 0x200004,
'$flags'(P, M, Fl, NFlags). '$flags'(P, M, Fl, NFlags).
'$is_mt'(M, H, B, (context_module(CM),B), CM) :- '$is_mt'(M, H, CM, B, (context_module(CM),B), CM) :-
'$module_transparent'(_, M, _, H), !. '$module_transparent'(_, M, _, H), !.
'$is_mt'(M, _, B, B, M). '$is_mt'(_M, _H, CM, B, B, CM).
% comma has its own problems. % comma has its own problems.
:- '$install_meta_predicate'(','(0,0), prolog). :- '$install_meta_predicate'(','(0,0), prolog).