allow statistics on data base keys of integers.
change pred_entry not to fail on this case. avoid using functor in this case.
This commit is contained in:
parent
e35af2a352
commit
821cc384a3
@ -681,6 +681,8 @@ get_pred(Term t, Term tmod, char *pname)
|
|||||||
return NULL;
|
return NULL;
|
||||||
} else if (IsAtomTerm(t)) {
|
} else if (IsAtomTerm(t)) {
|
||||||
return RepPredProp(Yap_GetPredPropByAtom(AtomOfTerm(t), tmod));
|
return RepPredProp(Yap_GetPredPropByAtom(AtomOfTerm(t), tmod));
|
||||||
|
} else if (IsIntegerTerm(t) && tmod == IDB_MODULE) {
|
||||||
|
return Yap_FindLUIntKey(IntegerOfTerm(t));
|
||||||
} else if (IsApplTerm(t)) {
|
} else if (IsApplTerm(t)) {
|
||||||
Functor fun = FunctorOfTerm(t);
|
Functor fun = FunctorOfTerm(t);
|
||||||
if (fun == FunctorModule) {
|
if (fun == FunctorModule) {
|
||||||
|
@ -2596,6 +2596,12 @@ find_lu_int_key(Int key)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PredEntry *
|
||||||
|
Yap_FindLUIntKey(Int key)
|
||||||
|
{
|
||||||
|
return find_lu_int_key(key);
|
||||||
|
}
|
||||||
|
|
||||||
static DBProp
|
static DBProp
|
||||||
find_int_key(Int key)
|
find_int_key(Int key)
|
||||||
{
|
{
|
||||||
@ -2642,6 +2648,7 @@ new_lu_int_key(Int key)
|
|||||||
p->ArityOfPE = 3;
|
p->ArityOfPE = 3;
|
||||||
p->OpcodeOfPred = Yap_opcode(_op_fail);
|
p->OpcodeOfPred = Yap_opcode(_op_fail);
|
||||||
p->cs.p_code.TrueCodeOfPred = p->CodeOfPred = FAILCODE;
|
p->cs.p_code.TrueCodeOfPred = p->CodeOfPred = FAILCODE;
|
||||||
|
WRITE_UNLOCK(ae->FRWLock);
|
||||||
INT_LU_KEYS[hash_key] = p0;
|
INT_LU_KEYS[hash_key] = p0;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
@ -3791,6 +3798,8 @@ p_lu_statistics(void)
|
|||||||
} else if (IsAtomTerm(t)) {
|
} else if (IsAtomTerm(t)) {
|
||||||
Atom at = AtomOfTerm(t);
|
Atom at = AtomOfTerm(t);
|
||||||
pe = RepPredProp(Yap_GetPredPropByAtom(at, mod));
|
pe = RepPredProp(Yap_GetPredPropByAtom(at, mod));
|
||||||
|
} else if (IsIntegerTerm(t) && mod == IDB_MODULE) {
|
||||||
|
pe = find_lu_int_key(IntegerOfTerm(t));
|
||||||
} else if (IsApplTerm(t)) {
|
} else if (IsApplTerm(t)) {
|
||||||
Functor fun = FunctorOfTerm(t);
|
Functor fun = FunctorOfTerm(t);
|
||||||
pe = RepPredProp(Yap_GetPredPropByFunc(fun, mod));
|
pe = RepPredProp(Yap_GetPredPropByFunc(fun, mod));
|
||||||
|
@ -151,6 +151,7 @@ void STD_PROTO(Yap_WakeUp,(CELL *));
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* dbase.c */
|
/* dbase.c */
|
||||||
|
struct pred_entry *STD_PROTO(Yap_FindLUIntKey,(Int));
|
||||||
int STD_PROTO(Yap_DBTrailOverflow,(void));
|
int STD_PROTO(Yap_DBTrailOverflow,(void));
|
||||||
CELL STD_PROTO(Yap_EvalMasks,(Term,CELL *));
|
CELL STD_PROTO(Yap_EvalMasks,(Term,CELL *));
|
||||||
void STD_PROTO(Yap_InitBackDB,(void));
|
void STD_PROTO(Yap_InitBackDB,(void));
|
||||||
|
19
pl/preds.yap
19
pl/preds.yap
@ -815,7 +815,7 @@ predicate_property(Pred,Prop) :-
|
|||||||
|
|
||||||
'$generate_all_preds_from_mod'(Pred, M, M) :-
|
'$generate_all_preds_from_mod'(Pred, M, M) :-
|
||||||
'$current_predicate'(M,Na,Ar),
|
'$current_predicate'(M,Na,Ar),
|
||||||
functor(Pred, Na, Ar).
|
'$ifunctor'(Pred,Na,Ar).
|
||||||
'$generate_all_preds_from_mod'(Pred, SourceMod, Mod) :-
|
'$generate_all_preds_from_mod'(Pred, SourceMod, Mod) :-
|
||||||
recorded('$import','$import'(SourceMod,Mod,_,Pred,_,_),_).
|
recorded('$import','$import'(SourceMod,Mod,_,Pred,_,_),_).
|
||||||
|
|
||||||
@ -921,14 +921,14 @@ system_predicate(P) :-
|
|||||||
|
|
||||||
'$current_predicate_no_modules'(M,A,T) :-
|
'$current_predicate_no_modules'(M,A,T) :-
|
||||||
'$current_predicate'(M,A,Arity),
|
'$current_predicate'(M,A,Arity),
|
||||||
functor(T,A,Arity),
|
'$ifunctor'(T,A,Arity),
|
||||||
'$pred_exists'(T,M).
|
'$pred_exists'(T,M).
|
||||||
|
|
||||||
'$current_predicate3'(M,A/Arity) :- nonvar(A), nonvar(Arity), !,
|
'$current_predicate3'(M,A/Arity) :- nonvar(A), nonvar(Arity), !,
|
||||||
(
|
(
|
||||||
'$current_predicate'(M,A,Arity)
|
'$current_predicate'(M,A,Arity)
|
||||||
->
|
->
|
||||||
functor(T,A,Arity),
|
'$ifunctor'(T,A,Arity)
|
||||||
'$pred_exists'(T,M)
|
'$pred_exists'(T,M)
|
||||||
% ;
|
% ;
|
||||||
% '$current_predicate'(prolog,A,Arity)
|
% '$current_predicate'(prolog,A,Arity)
|
||||||
@ -943,7 +943,7 @@ system_predicate(P) :-
|
|||||||
'$current_predicate3'(M,A/Arity) :- !,
|
'$current_predicate3'(M,A/Arity) :- !,
|
||||||
(
|
(
|
||||||
'$current_predicate'(M,A,Arity),
|
'$current_predicate'(M,A,Arity),
|
||||||
functor(T,A,Arity),
|
'$ifunctor'(T,A,Arity),
|
||||||
'$pred_exists'(T,M)
|
'$pred_exists'(T,M)
|
||||||
% ;
|
% ;
|
||||||
% '$current_predicate'(prolog,A,Arity),
|
% '$current_predicate'(prolog,A,Arity),
|
||||||
@ -959,9 +959,7 @@ system_predicate(P) :-
|
|||||||
|
|
||||||
current_key(A,K) :-
|
current_key(A,K) :-
|
||||||
'$current_predicate'(idb,A,Arity),
|
'$current_predicate'(idb,A,Arity),
|
||||||
functor(K,A,Arity).
|
'$ifunctor'(K,A,Arity).
|
||||||
current_key(A,K) :-
|
|
||||||
'$current_immediate_key'(A,K).
|
|
||||||
|
|
||||||
% do nothing for now.
|
% do nothing for now.
|
||||||
'$noprofile'(_, _).
|
'$noprofile'(_, _).
|
||||||
@ -985,3 +983,10 @@ current_key(A,K) :-
|
|||||||
'$notrace'(G, Mod) :-
|
'$notrace'(G, Mod) :-
|
||||||
\+ '$undefined'(G, Mod),
|
\+ '$undefined'(G, Mod),
|
||||||
'$donotrace'(Mod:G).
|
'$donotrace'(Mod:G).
|
||||||
|
|
||||||
|
'$ifunctor'(Pred,Na,Ar) :-
|
||||||
|
(Ar > 0 ->
|
||||||
|
functor(Pred, Na, Ar)
|
||||||
|
;
|
||||||
|
Pred = Na
|
||||||
|
).
|
||||||
|
Reference in New Issue
Block a user