check for overflow in big strings
This commit is contained in:
parent
610ca06883
commit
503bdcc8b3
46
C/stdpreds.c
46
C/stdpreds.c
@ -932,6 +932,8 @@ p_name( USES_REGS1 )
|
|||||||
Atom at = AtomOfTerm(AtomNameT);
|
Atom at = AtomOfTerm(AtomNameT);
|
||||||
if (IsWideAtom(at)) {
|
if (IsWideAtom(at)) {
|
||||||
NewT = Yap_WideStringToList((wchar_t *)(RepAtom(at)->StrOfAE));
|
NewT = Yap_WideStringToList((wchar_t *)(RepAtom(at)->StrOfAE));
|
||||||
|
if (NewT == 0L)
|
||||||
|
goto expand_global;
|
||||||
return Yap_unify(NewT, ARG2);
|
return Yap_unify(NewT, ARG2);
|
||||||
} else
|
} else
|
||||||
String = RepAtom(at)->StrOfAE;
|
String = RepAtom(at)->StrOfAE;
|
||||||
@ -1052,6 +1054,15 @@ p_name( USES_REGS1 )
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* error handling */
|
/* error handling */
|
||||||
|
expand_global:
|
||||||
|
if (!Yap_gc(2, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, LOCAL_ErrorMessage);
|
||||||
|
return(FALSE);
|
||||||
|
}
|
||||||
|
AtomNameT = Deref(ARG1);
|
||||||
|
t = Deref(ARG2);
|
||||||
|
goto restart_aux;
|
||||||
|
|
||||||
expand_auxsp:
|
expand_auxsp:
|
||||||
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
||||||
if (String + 1024 > (char *)AuxSp) {
|
if (String + 1024 > (char *)AuxSp) {
|
||||||
@ -1190,6 +1201,8 @@ p_string_to_list( USES_REGS1 )
|
|||||||
|
|
||||||
if (Yap_IsWideStringTerm(t)) {
|
if (Yap_IsWideStringTerm(t)) {
|
||||||
StringT = Yap_WideStringToList(Yap_BlobWideStringOfTerm(t));
|
StringT = Yap_WideStringToList(Yap_BlobWideStringOfTerm(t));
|
||||||
|
if (StringT == 0L)
|
||||||
|
goto expand_global;
|
||||||
} else if (Yap_IsStringTerm(t)) {
|
} else if (Yap_IsStringTerm(t)) {
|
||||||
StringT = Yap_StringToList(Yap_BlobStringOfTerm(t));
|
StringT = Yap_StringToList(Yap_BlobStringOfTerm(t));
|
||||||
} else if (IsAtomTerm(t)) {
|
} else if (IsAtomTerm(t)) {
|
||||||
@ -1198,6 +1211,8 @@ p_string_to_list( USES_REGS1 )
|
|||||||
StringT = Yap_WideStringToList(RepAtom(at)->WStrOfAE);
|
StringT = Yap_WideStringToList(RepAtom(at)->WStrOfAE);
|
||||||
else
|
else
|
||||||
StringT = Yap_StringToList(RepAtom(at)->StrOfAE);
|
StringT = Yap_StringToList(RepAtom(at)->StrOfAE);
|
||||||
|
if (StringT == 0L)
|
||||||
|
goto expand_global;
|
||||||
} else if (IsIntTerm(t)) {
|
} else if (IsIntTerm(t)) {
|
||||||
char *String = Yap_PreAllocCodeSpace();
|
char *String = Yap_PreAllocCodeSpace();
|
||||||
if (String + 1024 > (char *)AuxSp)
|
if (String + 1024 > (char *)AuxSp)
|
||||||
@ -1309,6 +1324,15 @@ p_string_to_list( USES_REGS1 )
|
|||||||
return(FALSE);
|
return(FALSE);
|
||||||
|
|
||||||
/* error handling */
|
/* error handling */
|
||||||
|
expand_global:
|
||||||
|
if (!Yap_gc(2, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, LOCAL_ErrorMessage);
|
||||||
|
return(FALSE);
|
||||||
|
}
|
||||||
|
NameT = Deref(ARG1);
|
||||||
|
t = Deref(ARG2);
|
||||||
|
goto restart_aux;
|
||||||
|
|
||||||
expand_auxsp:
|
expand_auxsp:
|
||||||
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
||||||
if (String + 1024 > (char *)AuxSp) {
|
if (String + 1024 > (char *)AuxSp) {
|
||||||
@ -1344,6 +1368,8 @@ p_atom_chars( USES_REGS1 )
|
|||||||
} else {
|
} else {
|
||||||
NewT = Yap_WideStringToListOfAtoms((wchar_t *)RepAtom(AtomOfTerm(t1))->StrOfAE);
|
NewT = Yap_WideStringToListOfAtoms((wchar_t *)RepAtom(AtomOfTerm(t1))->StrOfAE);
|
||||||
}
|
}
|
||||||
|
if (NewT == 0L)
|
||||||
|
goto expand_global;
|
||||||
} else {
|
} else {
|
||||||
if (yap_flags[YAP_TO_CHARS_FLAG] == QUINTUS_TO_CHARS) {
|
if (yap_flags[YAP_TO_CHARS_FLAG] == QUINTUS_TO_CHARS) {
|
||||||
NewT = Yap_StringToList(RepAtom(at)->StrOfAE);
|
NewT = Yap_StringToList(RepAtom(at)->StrOfAE);
|
||||||
@ -1514,6 +1540,14 @@ p_atom_chars( USES_REGS1 )
|
|||||||
return Yap_unify_constant(ARG1, MkAtomTerm(at));
|
return Yap_unify_constant(ARG1, MkAtomTerm(at));
|
||||||
}
|
}
|
||||||
/* error handling */
|
/* error handling */
|
||||||
|
expand_global:
|
||||||
|
if (!Yap_gc(2, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, LOCAL_ErrorMessage);
|
||||||
|
return(FALSE);
|
||||||
|
}
|
||||||
|
t1 = Deref(ARG1);
|
||||||
|
goto restart_aux;
|
||||||
|
|
||||||
expand_auxsp:
|
expand_auxsp:
|
||||||
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
||||||
if (String + 1024 > (char *)AuxSp) {
|
if (String + 1024 > (char *)AuxSp) {
|
||||||
@ -1919,6 +1953,8 @@ p_atom_codes( USES_REGS1 )
|
|||||||
} else {
|
} else {
|
||||||
NewT = Yap_StringToList(Yap_BlobStringOfTerm(t1));
|
NewT = Yap_StringToList(Yap_BlobStringOfTerm(t1));
|
||||||
}
|
}
|
||||||
|
if (NewT == 0L)
|
||||||
|
goto expand_global;
|
||||||
} else if (!IsAtomTerm(t1)) {
|
} else if (!IsAtomTerm(t1)) {
|
||||||
Yap_Error(TYPE_ERROR_ATOM, t1, "atom_codes/2");
|
Yap_Error(TYPE_ERROR_ATOM, t1, "atom_codes/2");
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
@ -1929,6 +1965,8 @@ p_atom_codes( USES_REGS1 )
|
|||||||
} else {
|
} else {
|
||||||
NewT = Yap_StringToList(RepAtom(at)->StrOfAE);
|
NewT = Yap_StringToList(RepAtom(at)->StrOfAE);
|
||||||
}
|
}
|
||||||
|
if (NewT == 0L)
|
||||||
|
goto expand_global;
|
||||||
}
|
}
|
||||||
return (Yap_unify(NewT, ARG2));
|
return (Yap_unify(NewT, ARG2));
|
||||||
} else {
|
} else {
|
||||||
@ -2001,6 +2039,14 @@ p_atom_codes( USES_REGS1 )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* error handling */
|
/* error handling */
|
||||||
|
expand_global:
|
||||||
|
if (!Yap_gc(2, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, LOCAL_ErrorMessage);
|
||||||
|
return(FALSE);
|
||||||
|
}
|
||||||
|
t1 = Deref(ARG1);
|
||||||
|
goto restart_pred;
|
||||||
|
|
||||||
expand_auxsp:
|
expand_auxsp:
|
||||||
if (String + 1024 > (char *)AuxSp) {
|
if (String + 1024 > (char *)AuxSp) {
|
||||||
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
String = Yap_ExpandPreAllocCodeSpace(0,NULL, TRUE);
|
||||||
|
Reference in New Issue
Block a user