- 0 char (from P Moura);

- stack shifting
- uninitialized pointers in jpl
This commit is contained in:
Vítor Santos Costa 2019-05-21 20:37:16 +01:00
parent e7535dd2ee
commit 1a6e97655b
6 changed files with 42 additions and 25 deletions

View File

@ -632,8 +632,8 @@ overflow:
*pt0 = to_visit->oldv; *pt0 = to_visit->oldv;
} }
#endif #endif
reset_trail(TR0); clean_dirty_tr(TR0 PASS_REGS);
pop_text_stack(lvl); pop_text_stack(lvl);
return -1; return -1;
trail_overflow: trail_overflow:

View File

@ -293,8 +293,11 @@ static void *codes2buf(Term t0, void *b0, bool get_codes,
Yap_ThrowError(REPRESENTATION_ERROR_CHARACTER_CODE, hd, Yap_ThrowError(REPRESENTATION_ERROR_CHARACTER_CODE, hd,
"scanning list of character codes, found %d", code); "scanning list of character codes, found %d", code);
return NULL; return NULL;
} }else if (code == 0) {
length += 2;
} else {
length += put_utf8(ar, code); length += put_utf8(ar, code);
}
t = TailOfTerm(t); t = TailOfTerm(t);
if (IsVarTerm(t)) { if (IsVarTerm(t)) {
Yap_ThrowError(INSTANTIATION_ERROR, t, "scanning list of codes"); Yap_ThrowError(INSTANTIATION_ERROR, t, "scanning list of codes");
@ -320,8 +323,11 @@ static void *codes2buf(Term t0, void *b0, bool get_codes,
if (code < 0) { if (code < 0) {
Yap_ThrowError(TYPE_ERROR_CHARACTER, hd, "scanning list of atoms"); Yap_ThrowError(TYPE_ERROR_CHARACTER, hd, "scanning list of atoms");
return NULL; return NULL;
} else if (code == 0) {
length += 2;
} else {
length += strlen(code);
} }
length += strlen(code);
t = TailOfTerm(t); t = TailOfTerm(t);
if (IsVarTerm(t)) { if (IsVarTerm(t)) {
Yap_ThrowError(INSTANTIATION_ERROR, t, "scanning list of codes"); Yap_ThrowError(INSTANTIATION_ERROR, t, "scanning list of codes");
@ -348,6 +354,11 @@ static void *codes2buf(Term t0, void *b0, bool get_codes,
Term hd = HeadOfTerm(t); Term hd = HeadOfTerm(t);
Int code = IntegerOfTerm(hd); Int code = IntegerOfTerm(hd);
if (code == 0) {
st[0] = 0xC0;
st[1] = 0x80;
st +=2;
} else
st = st + put_utf8(st, code); st = st + put_utf8(st, code);
t = TailOfTerm(t); t = TailOfTerm(t);
} }

View File

@ -476,10 +476,10 @@ AtomIsSymbols(unsigned char *s) /* Is this atom just formed by symbols ? */
static void write_quoted(wchar_t ch, wchar_t quote, wrf stream) { static void write_quoted(wchar_t ch, wchar_t quote, wrf stream) {
CACHE_REGS CACHE_REGS
if (!(Yap_GetModuleEntry(CurrentModule)->flags & M_CHARESCAPE)) { if (!(Yap_GetModuleEntry(CurrentModule)->flags & M_CHARESCAPE)) {
wrputc(ch, stream); wrputc(ch, stream);
if (ch == '\'') if (ch == '\'')
wrputc('\'', stream); /* be careful about quotes */ wrputc('\'', stream); /* be careful about quotes */
return; return;
} }
if (!(ch < 0xff && chtype(ch) == BS) && ch != '\'' && ch != '\\' && if (!(ch < 0xff && chtype(ch) == BS) && ch != '\'' && ch != '\\' &&
ch != '`') { ch != '`') {

View File

@ -43,7 +43,11 @@ INLINE_ONLY utf8proc_ssize_t get_utf8(const utf8proc_uint8_t *ptr,
INLINE_ONLY utf8proc_ssize_t get_utf8(const utf8proc_uint8_t *ptr, INLINE_ONLY utf8proc_ssize_t get_utf8(const utf8proc_uint8_t *ptr,
size_t n, size_t n,
utf8proc_int32_t *valp) { utf8proc_int32_t *valp) {
utf8proc_ssize_t rc = utf8proc_iterate(ptr, n, valp); if (ptr[0] == 0xC0 && ptr[1] == 0x80) {
*valp = 0;
return 2;
}
utf8proc_ssize_t rc = utf8proc_iterate(ptr, n, valp);
if (rc < 0) { if (rc < 0) {
// LOCAL_ActiveError->errorNo = REPRESENTATION_ERROR_IN_CHARACTER_CODE; // LOCAL_ActiveError->errorNo = REPRESENTATION_ERROR_IN_CHARACTER_CODE;
} }
@ -55,9 +59,9 @@ INLINE_ONLY utf8proc_ssize_t put_utf8(utf8proc_uint8_t *ptr,
INLINE_ONLY utf8proc_ssize_t put_utf8(utf8proc_uint8_t *ptr, INLINE_ONLY utf8proc_ssize_t put_utf8(utf8proc_uint8_t *ptr,
utf8proc_int32_t val) { utf8proc_int32_t val) {
utf8proc_ssize_t rc = utf8proc_encode_char(val, ptr); utf8proc_ssize_t rc = utf8proc_encode_char(val, ptr);
if (rc < 0) { if (rc < 0) {
// LOCAL_ActiveError->errorNo = REPRESENTATION_ERROR_CHARACTER_CODE; // LOCAL_ActiveError->errorNo = REPRESENTATION_ERROR_CHARACTER_CODE;
} }
return rc < 1 ? 1 : rc; return rc < 1 ? 1 : rc;
} }

View File

@ -641,18 +641,20 @@ X_API int PL_get_atom_chars(term_t ts, char **a) /* SAM check type */
return 0; return 0;
} }
src = (char *)RepAtom(AtomOfTerm(t))->StrOfAE; src = (char *)RepAtom(AtomOfTerm(t))->StrOfAE;
if (!a) if (!src)
return 0; return 0;
if (*a && *a != src) if ( !*a ) {
strcpy(*a, src); *a = src;
else } else if (src[0] == '\0') {
*a = src; (*a)[0] = src[0];
} else {
strcpy(*a, src);
}
return 1; return 1;
} }
/** @brief *a is assigned the string representation of the atom in term ts, and
/** @brief *a is assigned the string representation of the atom in term ts, and * *len its size, or the operation fails
* *len its size, or the operation fails *
*
*/ */
X_API int PL_get_atom_nchars(term_t ts, size_t *len, X_API int PL_get_atom_nchars(term_t ts, size_t *len,
char **s) /* SAM check type */ char **s) /* SAM check type */

View File

@ -2600,7 +2600,7 @@ jni_func_1_plc(
jobject j; /* " */ jobject j; /* " */
/* jlong jl; // " */ /* jlong jl; // " */
void *p1; /* temp for converted (JVM) arg */ void *p1; /* temp for converted (JVM) arg */
char *c1; /* " */ char *c1 = NULL; /* " */
int i1; /* " */ int i1; /* " */
/* jlong l1; // " */ /* jlong l1; // " */
/* double d1; // " */ /* double d1; // " */
@ -2950,8 +2950,8 @@ jni_func_3_plc(
void *p2; /* " */ void *p2; /* " */
void *p3; /* " */ void *p3; /* " */
/* char *c1; // " */ /* char *c1; // " */
char *c2; /* " */ char *c2 = NULL; /* " */
char *c3; /* " */ char *c3 = NULL; /* " */
int i1; /* " */ int i1; /* " */
/* int i2; // " */ /* int i2; // " */
/* int i3; // " */ /* int i3; // " */
@ -3297,7 +3297,7 @@ jpl_do_jpl_init( /* to be called once only, after PL init, before any JPL calls
{ {
jclass tc; /* temporary class ref */ jclass tc; /* temporary class ref */
jobject ta; /* temporary array ref */ jobject ta; /* temporary array ref */
char *msg; /* error message for exceptions thrown here */ char *msg = NULL; /* error message for exceptions thrown here */
int i; /* loop counter */ int i; /* loop counter */
jobject to; /* temporary (String) object ref */ jobject to; /* temporary (String) object ref */