message handling.
This commit is contained in:
parent
81998122a8
commit
059c406fd9
18
C/errors.c
18
C/errors.c
@ -86,21 +86,24 @@ static bool setErr(const char *q, yap_error_descriptor_t *i, Term t) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define query_key_b(k, ks, q, i) \
|
#define query_key_b(k, ks, q, i) \
|
||||||
if (strcmp(ks, q) == 0) { \
|
if (strcmp(ks, q) == 0) { \
|
||||||
return i->k ? TermTrue : TermFalse; \
|
return i->k ? TermTrue : TermFalse; \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define query_key_i(k, ks, q, i) if (strcmp(ks, q) == 0) { \
|
#define query_key_i(k, ks, q, i) \
|
||||||
|
if (strcmp(ks, q) == 0) { \
|
||||||
return MkIntegerTerm(i->k); \
|
return MkIntegerTerm(i->k); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define query_key_s(k, ks, q, i) \
|
#define query_key_s(k, ks, q, i) \
|
||||||
if (strcmp(ks, q) == 0 && i->k) { \
|
if (strcmp(ks, q) == 0 ) \
|
||||||
return MkAtomTerm(Yap_LookupAtom(i->k)); } else {return TermNil;}
|
{ if (i->k) return MkAtomTerm(Yap_LookupAtom(i->k)); else return TermNil; }
|
||||||
|
|
||||||
|
|
||||||
#define query_key_t(k, ks, q, i) \
|
#define query_key_t(k, ks, q, i) \
|
||||||
if (strcmp(ks, q) == 0) { \
|
if (strcmp(ks, q) == 0) { \
|
||||||
|
if (i->k == NULL) return TermNil; \
|
||||||
Term t; if((t = Yap_BufferToTerm(i->k, TermNil) ) == 0 ) return TermNil; return t; }
|
Term t; if((t = Yap_BufferToTerm(i->k, TermNil) ) == 0 ) return TermNil; return t; }
|
||||||
|
|
||||||
static Term queryErr(const char *q, yap_error_descriptor_t *i) {
|
static Term queryErr(const char *q, yap_error_descriptor_t *i) {
|
||||||
@ -645,7 +648,7 @@ bool Yap_MkErrorRecord(yap_error_descriptor_t *r, const char *file,
|
|||||||
Term where, const char *s) {
|
Term where, const char *s) {
|
||||||
if (!Yap_pc_add_location(r, P, B, ENV))
|
if (!Yap_pc_add_location(r, P, B, ENV))
|
||||||
Yap_env_add_location(r, CP, B, ENV, 0);
|
Yap_env_add_location(r, CP, B, ENV, 0);
|
||||||
if (where == 0L || where == TermNil || type == INSTANTIATION_ERROR) {
|
if (where == 0L || where == TermNil) {
|
||||||
r->culprit = NULL;
|
r->culprit = NULL;
|
||||||
} else {
|
} else {
|
||||||
r->culprit = Yap_TermToBuffer(
|
r->culprit = Yap_TermToBuffer(
|
||||||
@ -662,7 +665,6 @@ bool Yap_MkErrorRecord(yap_error_descriptor_t *r, const char *file,
|
|||||||
r->errorLine = lineno;
|
r->errorLine = lineno;
|
||||||
r->errorFunction = function;
|
r->errorFunction = function;
|
||||||
r->errorFile = file;
|
r->errorFile = file;
|
||||||
Yap_prolog_add_culprit(r PASS_REGS1);
|
|
||||||
LOCAL_PrologMode |= InErrorMode;
|
LOCAL_PrologMode |= InErrorMode;
|
||||||
Yap_ClearExs();
|
Yap_ClearExs();
|
||||||
// first, obtain current location
|
// first, obtain current location
|
||||||
|
131
pl/messages.yap
131
pl/messages.yap
@ -205,7 +205,8 @@ compose_message(error(E, Exc), Level) -->
|
|||||||
caller( error(E, Exc), Level ),
|
caller( error(E, Exc), Level ),
|
||||||
extra_info( error(E, Exc), Level ),
|
extra_info( error(E, Exc), Level ),
|
||||||
!,
|
!,
|
||||||
[nl,nl].
|
[nl],
|
||||||
|
[nl].
|
||||||
compose_message( false, _Level) --> !,
|
compose_message( false, _Level) --> !,
|
||||||
[ 'false.'-[] ].
|
[ 'false.'-[] ].
|
||||||
compose_message( '$abort', _Level) --> !,
|
compose_message( '$abort', _Level) --> !,
|
||||||
@ -266,8 +267,9 @@ location( error(_,Info), Level, LC ) -->
|
|||||||
query_exception(prologPredArity, Desc, Ar)
|
query_exception(prologPredArity, Desc, Ar)
|
||||||
},
|
},
|
||||||
!,
|
!,
|
||||||
display_consulting( File, Level, Info, LC ),
|
display_consulting( File, Level, Info, LC ),
|
||||||
[ '~a:~d:0 ~a in ~a:~a/~d:'-[File, FilePos,Level,M,Na,Ar] ].
|
{simplify_pred(M:Na/Ar,FF)},
|
||||||
|
[ '~a:~d:0 ~a while executing ~q:'-[File, FilePos,Level,FF] ].
|
||||||
location( error(_,Info), Level, LC ) -->
|
location( error(_,Info), Level, LC ) -->
|
||||||
{ '$error_descriptor'(Info, Desc) },
|
{ '$error_descriptor'(Info, Desc) },
|
||||||
{
|
{
|
||||||
@ -277,13 +279,17 @@ location( error(_,Info), Level, LC ) -->
|
|||||||
},
|
},
|
||||||
!,
|
!,
|
||||||
display_consulting( File, Level, Info, LC ),
|
display_consulting( File, Level, Info, LC ),
|
||||||
[ '~a:~d:0 ~a in ~a():'-[File, FilePos,Level,F] ].
|
{simplify_pred(F,FF)},
|
||||||
|
[ '~a:~d:0 ~a while executing ~a():'-[File, FilePos,Level,FF] ].
|
||||||
location( _Ball, _Level, _LC ) --> [].
|
location( _Ball, _Level, _LC ) --> [].
|
||||||
|
|
||||||
|
simplify_pred(user:F, F) :- !.
|
||||||
|
simplify_pred(prolog:F, F) :- !.
|
||||||
|
simplify_pred(F, F).
|
||||||
|
|
||||||
%message(loaded(Past,AbsoluteFileName,user,Msec,Bytes), Prefix, Suffix) :- !,
|
%message(loaded(Past,AbsoluteFileName,user,Msec,Bytes), Prefix, Suffix) :- !,
|
||||||
main_message(error(Msg,In), _, _) --> {var(Msg)}, !,
|
main_message(error(Msg,In), _, _) --> {var(Msg)}, !,
|
||||||
[ 'ninstantiated message ~w~n.' - [error(Msg,In)], nl ].
|
[ 'Uninstantiated message ~w~n.' - [error(Msg,In)], nl ].
|
||||||
main_message( error(syntax_error(Msg),info(between(L0,LM,LF),_Stream, _Pos, Term)), Level, LC ) -->
|
main_message( error(syntax_error(Msg),info(between(L0,LM,LF),_Stream, _Pos, Term)), Level, LC ) -->
|
||||||
!,
|
!,
|
||||||
[' ~a: syntax error ~s' - [Level,Msg]],
|
[' ~a: syntax error ~s' - [Level,Msg]],
|
||||||
@ -303,45 +309,50 @@ main_message(style_check(singleton(SVs),_Pos,_File,P), _Level, _LC) -->
|
|||||||
!,
|
!,
|
||||||
% {writeln(ci)},
|
% {writeln(ci)},
|
||||||
{ clause_to_indicator(P, I) },
|
{ clause_to_indicator(P, I) },
|
||||||
[ nl, ' singleton variable~*c ~w in ~q.' - [ NVs, 0's, SVsL, I] ],
|
[ nl, '~*|singleton variable~*c ~w in ~q.' - [ 10, NVs, 0's, SVsL, I] ],
|
||||||
{ svs(SVs,SVs,SVsL),
|
{ svs(SVs,SVs,SVsL),
|
||||||
( SVs = [_] -> NVs = 0 ; NVs = 1 )
|
( SVs = [_] -> NVs = 0 ; NVs = 1 )
|
||||||
}.
|
}.
|
||||||
main_message(style_check(multiple(N,A,Mod,I0),_Pos,File,_P), _Level, _LC) -->
|
main_message(style_check(multiple(N,A,Mod,I0),_Pos,File,_P), _Level, _LC) -->
|
||||||
!,
|
!,
|
||||||
[ ' ~a redefines ~q, originally defined in ~a.' - [File, Mod:N/A, I0] ].
|
[ '~*|~a redefines ~q, originally defined in ~a.' - [ 10,File, Mod:N/A, I0] ].
|
||||||
main_message(style_check(discontiguous(N,A,Mod),_S,_W,_P) , _Level, _LC)-->
|
main_message(style_check(discontiguous(N,A,Mod),_S,_W,_P) , _Level, _LC)-->
|
||||||
!,
|
!,
|
||||||
[ ' discontiguous definition for ~p.' - [Mod:N/A] ].
|
[ '~*|discontiguous definition for ~p.' - [ 10,Mod:N/A] ].
|
||||||
main_message(error(consistency_error(Who)), Level, _LC) -->
|
main_message(error(ErrorInfo,_), _Level, _LC) -->
|
||||||
!,
|
[nl],
|
||||||
[ ' ~a: has argument ~a not consistent with type.'-[Level,Who] ].
|
main_error_message( ErrorInfo ),
|
||||||
main_message(error(domain_error(Who , Type), _Where), Level, _LC) -->
|
[nl].
|
||||||
!,
|
|
||||||
[ ' ~a: ~q does not belong to domain ~a,' - [Level,Type,Who], nl ].
|
|
||||||
main_message(error(evaluation_error(What), _Where), Level, _LC) -->
|
main_error_message(consistency_error(Who)) -->
|
||||||
!,
|
[ '~*|** argument ~a not consistent with type **'-[ 10,Who] ].
|
||||||
[ ' ~a: ~w during evaluation of arithmetic expressions,' - [Level,What], nl ].
|
main_error_message(domain_error(Who , Type)) -->
|
||||||
main_message(error(evaluation_error(What, Who), _Where), Level, _LC) -->
|
[ '~*|** ~q does not belong to domain ~a ** ' - [ 10,Type,Who], nl ].
|
||||||
!,
|
main_error_message(evaluation_error(What)) -->
|
||||||
[ ' ~a: ~w caused ~a during evaluation of arithmetic expressions,' - [Level,Who,What], nl ].
|
[ '~*|** found ~w during evaluation of arithmetic expression **' - [ 10,What], nl ].
|
||||||
main_message(error(existence_error(Type , Who), _Where), Level, _LC) -->
|
main_error_message(evaluation_error(What, Who)) -->
|
||||||
!,
|
[ '~*|** ~w caused ~a during evaluation of arithmetic expressions **' - [ 10,Who,What], nl ].
|
||||||
[ ' ~a: ~q ~q could not be found,' - [Level,Type, Who], nl ].
|
main_error_message(existence_error(Type , Who)) -->
|
||||||
main_message(error(permission_error(Op, Type, Id), _Where), Level, _LC) -->
|
[nl],
|
||||||
[ ' ~a: ~q is not allowed in ~a ~q,' - [Level, Op, Type,Id], nl ].
|
[ '~*|** ~q ~q could not be found **' - [ 10,Type, Who], nl ].
|
||||||
main_message(error(instantiation_error, _Where), Level, _LC) -->
|
main_error_message(permission_error(Op, Type, Id)) -->
|
||||||
[ ' ~a: unbound variable' - [Level], nl ].
|
[ '~*|** value ~q is not allowed in ~a ~q **' - [ 10, Op, Type,Id], nl ].
|
||||||
main_message(error(representation_error(Type)), Level, _LC) -->
|
main_error_message(instantiation_error) -->
|
||||||
[ ' ~a: ~a representation error ~a' - [Level, Type], nl ].
|
[ '~*|** unbound variable **' - [10], nl ].
|
||||||
main_message(error(type_error(Type,Who), _What), Level, _LC) -->
|
main_error_message(representation_error(Type)) -->
|
||||||
[ ' ~a: ~q should be of type ~a' - [Level,Who,Type]],
|
[ '~*|** YAP cannot represent ~w **' - [10, Type], nl ].
|
||||||
|
main_error_message(resource_error(Who)) -->
|
||||||
|
[ '~*|** ~q **' - [10,Who]],
|
||||||
[ nl ].
|
[ nl ].
|
||||||
main_message(error(system_error(Who), _What), Level, _LC) -->
|
main_error_message(type_error(Type,Who)) -->
|
||||||
[ ' ~a: ~q' - [Level,Who]],
|
[ '~*|** ~q should be of type ~a **' - [10,Who,Type]],
|
||||||
[ nl ].
|
[ nl ].
|
||||||
main_message(error(uninstantiation_error(T),_), Level, _LC) -->
|
main_error_message(system_error(Who)) -->
|
||||||
[ ' ~a: found ~q, expected unbound variable ' - [Level,T], nl ].
|
[ '~*|** ~q **' - [10,Who]],
|
||||||
|
[ nl ].
|
||||||
|
main_error_message(uninstantiation_error(T)) -->
|
||||||
|
[ '~*|** found ~q, expected unbound variable **' - [10,T], nl ].
|
||||||
|
|
||||||
display_consulting( F, Level, Info, LC) -->
|
display_consulting( F, Level, Info, LC) -->
|
||||||
{ LC > 0,
|
{ LC > 0,
|
||||||
@ -360,7 +371,7 @@ display_consulting( F, Level, _, LC) -->
|
|||||||
display_consulting(_F, _, _, _LC) -->
|
display_consulting(_F, _, _, _LC) -->
|
||||||
[].
|
[].
|
||||||
|
|
||||||
caller( Info, _) -->
|
c_goal( error(_,Info), _) -->
|
||||||
{ '$error_descriptor'(Info, Desc) },
|
{ '$error_descriptor'(Info, Desc) },
|
||||||
({ query_exception(errorGoal, Desc, Call),
|
({ query_exception(errorGoal, Desc, Call),
|
||||||
Call = M:(H :- G)
|
Call = M:(H :- G)
|
||||||
@ -376,31 +387,34 @@ caller( Info, _) -->
|
|||||||
;
|
;
|
||||||
[]
|
[]
|
||||||
),
|
),
|
||||||
{ query_exception(prologPredFile, Desc, File),
|
!.
|
||||||
File \= [],
|
c_goal(_,_) --> [].
|
||||||
query_exception(prologPredLine, Desc, FilePos),
|
|
||||||
query_exception(prologPredModule, Desc, M),
|
|
||||||
query_exception(prologPredName, Desc, Na),
|
|
||||||
query_exception(prologPredArity, Desc, Ar)
|
|
||||||
},
|
|
||||||
!,
|
|
||||||
[nl],
|
|
||||||
['~*| ~q:~d:0 ~a:~q'-[10,File, FilePos,M,Na,Ar]],
|
|
||||||
[nl].
|
|
||||||
caller( _, _) -->
|
|
||||||
[].
|
|
||||||
|
|
||||||
c_goal( Info, Level ) -->
|
caller( error(_,Info), Level ) -->
|
||||||
{ '$error_descriptor'(Info, Desc) },
|
{ '$error_descriptor'(Info, Desc) },
|
||||||
{ query_exception(errorFile, Desc, File),
|
{ query_exception(errorFile, Desc, File),
|
||||||
|
File \= [],
|
||||||
|
query_exception(errorFunction, Desc, Func),
|
||||||
Func \= [],
|
Func \= [],
|
||||||
query_exception(errorFunction, Desc, File),
|
|
||||||
query_exception(errorLine, Desc, Line)
|
query_exception(errorLine, Desc, Line)
|
||||||
},
|
},
|
||||||
!,
|
!,
|
||||||
['~*|~a raised at C-function ~a() in ~a:~d:0: '-[10, Level, Func, File, Line]],
|
['~*|~a raised by foreign-function ~a(), at ~a:~d:0: '-[10, Level, Func, File, Line]],
|
||||||
[nl].
|
[nl].
|
||||||
c_goal( _, _Level ) --> [].
|
caller( _, _Level ) --> [].
|
||||||
|
|
||||||
|
|
||||||
|
extra_info( error(_,Info), _ ) -->
|
||||||
|
{ '$error_descriptor'(Info, Desc) },
|
||||||
|
{
|
||||||
|
query_exception(errorMsg, Desc, Msg),
|
||||||
|
Msg \= []
|
||||||
|
},
|
||||||
|
!,
|
||||||
|
['~*|user provided data is: ~q' - [10,Msg]],
|
||||||
|
[nl].
|
||||||
|
extra_info( _, _ ) -->
|
||||||
|
[].
|
||||||
|
|
||||||
|
|
||||||
prolog_message(X) -->
|
prolog_message(X) -->
|
||||||
@ -622,17 +636,6 @@ domain_error(write_option, Opt) --> !,
|
|||||||
domain_error(Domain, Opt) -->
|
domain_error(Domain, Opt) -->
|
||||||
[ '~w not a valid element for ~w' - [Opt,Domain] ].
|
[ '~w not a valid element for ~w' - [Opt,Domain] ].
|
||||||
|
|
||||||
extra_info( error(_,Extra), _ ) -->
|
|
||||||
{
|
|
||||||
query_exception(prologPredFile, Extra, Msg),
|
|
||||||
Msg \= []
|
|
||||||
},
|
|
||||||
!,
|
|
||||||
['~*|user provided data is: ~q' - [10,Msg]],
|
|
||||||
[nl].
|
|
||||||
extra_info( _, _ ) -->
|
|
||||||
[].
|
|
||||||
|
|
||||||
object_name(array, array).
|
object_name(array, array).
|
||||||
object_name(atom, atom).
|
object_name(atom, atom).
|
||||||
object_name(atomic, atomic).
|
object_name(atomic, atomic).
|
||||||
|
Reference in New Issue
Block a user