only evaluate lists with a single character.
git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@2214 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
parent
12e18227bb
commit
516a349aad
12
C/eval.c
12
C/eval.c
@ -108,6 +108,12 @@ Eval(Term t, E_ARGS)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (IsPairTerm(t)) {
|
} else if (IsPairTerm(t)) {
|
||||||
|
if (TailOfTerm(t) != TermNil) {
|
||||||
|
Yap_Error(TYPE_ERROR_EVALUABLE, t,
|
||||||
|
"string must contain a single character to be evaluated as an arithmetic expression");
|
||||||
|
P = (yamop *)FAILCODE;
|
||||||
|
RERROR();
|
||||||
|
}
|
||||||
return(Eval(HeadOfTerm(t), USE_E_ARGS));
|
return(Eval(HeadOfTerm(t), USE_E_ARGS));
|
||||||
} else if (IsIntTerm(t)) {
|
} else if (IsIntTerm(t)) {
|
||||||
RINT(IntOfTerm(t));
|
RINT(IntOfTerm(t));
|
||||||
@ -182,6 +188,12 @@ Yap_Eval(Term t, E_ARGS)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (IsPairTerm(t)) {
|
} else if (IsPairTerm(t)) {
|
||||||
|
if (TailOfTerm(t) != TermNil) {
|
||||||
|
Yap_Error(TYPE_ERROR_EVALUABLE, t,
|
||||||
|
"string must contain a single character to be evaluated as an arithmetic expression");
|
||||||
|
P = (yamop *)FAILCODE;
|
||||||
|
RERROR();
|
||||||
|
}
|
||||||
return(Eval(HeadOfTerm(t), USE_E_ARGS));
|
return(Eval(HeadOfTerm(t), USE_E_ARGS));
|
||||||
} else if (IsIntTerm(t)) {
|
} else if (IsIntTerm(t)) {
|
||||||
RINT(IntOfTerm(t));
|
RINT(IntOfTerm(t));
|
||||||
|
14
C/threads.c
14
C/threads.c
@ -101,7 +101,6 @@ kill_thread_engine (int wid)
|
|||||||
Yap_KillStacks(wid);
|
Yap_KillStacks(wid);
|
||||||
Yap_FreeCodeSpace((ADDR)(ThreadHandle[wid].tgoal));
|
Yap_FreeCodeSpace((ADDR)(ThreadHandle[wid].tgoal));
|
||||||
Yap_heap_regs->wl[wid].active_signals = 0L;
|
Yap_heap_regs->wl[wid].active_signals = 0L;
|
||||||
pthread_mutex_lock(&(ThreadHandle[wid].tlock));
|
|
||||||
free(Yap_heap_regs->wl[wid].scratchpad.ptr);
|
free(Yap_heap_regs->wl[wid].scratchpad.ptr);
|
||||||
free(ThreadHandle[wid].default_yaam_regs);
|
free(ThreadHandle[wid].default_yaam_regs);
|
||||||
ThreadHandle[wid].current_yaam_regs = NULL;
|
ThreadHandle[wid].current_yaam_regs = NULL;
|
||||||
@ -356,7 +355,6 @@ Yap_thread_detach_engine(int wid)
|
|||||||
Int
|
Int
|
||||||
Yap_thread_destroy_engine(int wid)
|
Yap_thread_destroy_engine(int wid)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(&(ThreadHandle[wid].tlock));
|
|
||||||
if (ThreadHandle[wid].ref_count == 0) {
|
if (ThreadHandle[wid].ref_count == 0) {
|
||||||
kill_thread_engine(wid);
|
kill_thread_engine(wid);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -382,6 +380,7 @@ p_thread_join(void)
|
|||||||
UNLOCK(ThreadHandlesLock);
|
UNLOCK(ThreadHandlesLock);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
pthread_mutex_lock(&(ThreadHandle[tid].tlock));
|
||||||
UNLOCK(ThreadHandlesLock);
|
UNLOCK(ThreadHandlesLock);
|
||||||
/* make sure this lock is accessible */
|
/* make sure this lock is accessible */
|
||||||
if (pthread_join(ThreadHandle[tid].handle, NULL) < 0) {
|
if (pthread_join(ThreadHandle[tid].handle, NULL) < 0) {
|
||||||
@ -413,7 +412,6 @@ p_thread_detach(void)
|
|||||||
}
|
}
|
||||||
ThreadHandle[tid].tdetach =
|
ThreadHandle[tid].tdetach =
|
||||||
MkAtomTerm(AtomTrue);
|
MkAtomTerm(AtomTrue);
|
||||||
pthread_mutex_unlock(&(ThreadHandle[tid].tlock));
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -670,9 +668,10 @@ p_thread_runtime(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
p_thread_self_lock(void)
|
p_thread_unlock(void)
|
||||||
{ /* '$thread_self_lock' */
|
{ /* '$thread_self_lock' */
|
||||||
pthread_mutex_lock(&(ThreadHandle[worker_id].tlock));
|
Int wid = IntegerOfTerm(Deref(ARG1));
|
||||||
|
pthread_mutex_unlock(&(ThreadHandle[wid].tlock));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -708,6 +707,7 @@ void Yap_InitThreadPreds(void)
|
|||||||
Yap_InitCPred("$nof_threads_created", 1, p_nof_threads_created, SafePredFlag|HiddenPredFlag);
|
Yap_InitCPred("$nof_threads_created", 1, p_nof_threads_created, SafePredFlag|HiddenPredFlag);
|
||||||
Yap_InitCPred("$thread_sleep", 4, p_thread_sleep, SafePredFlag|HiddenPredFlag);
|
Yap_InitCPred("$thread_sleep", 4, p_thread_sleep, SafePredFlag|HiddenPredFlag);
|
||||||
Yap_InitCPred("$thread_runtime", 1, p_thread_runtime, SafePredFlag|HiddenPredFlag);
|
Yap_InitCPred("$thread_runtime", 1, p_thread_runtime, SafePredFlag|HiddenPredFlag);
|
||||||
|
Yap_InitCPred("$thread_unlock", 1, p_thread_unlock, SafePredFlag);
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
@ -749,7 +749,7 @@ p_thread_self(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
p_thread_self_lock(void)
|
p_thread_unlock(void)
|
||||||
{ /* '$thread_runtime'(+P) */
|
{ /* '$thread_runtime'(+P) */
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -762,7 +762,7 @@ void Yap_InitThreadPreds(void)
|
|||||||
Yap_InitCPred("$nof_threads", 1, p_nof_threads, SafePredFlag|HiddenPredFlag);
|
Yap_InitCPred("$nof_threads", 1, p_nof_threads, SafePredFlag|HiddenPredFlag);
|
||||||
Yap_InitCPred("$nof_threads_created", 1, p_nof_threads_created, SafePredFlag|HiddenPredFlag);
|
Yap_InitCPred("$nof_threads_created", 1, p_nof_threads_created, SafePredFlag|HiddenPredFlag);
|
||||||
Yap_InitCPred("$thread_runtime", 1, p_thread_runtime, SafePredFlag|HiddenPredFlag);
|
Yap_InitCPred("$thread_runtime", 1, p_thread_runtime, SafePredFlag|HiddenPredFlag);
|
||||||
Yap_InitCPred("$self_thread_lock", 0, p_thread_self_lock, SafePredFlag);
|
Yap_InitCPred("$thread_unlock", 1, p_thread_unlock, SafePredFlag);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3445,7 +3445,8 @@ the call.
|
|||||||
@var{Char} is a lower-case letter.
|
@var{Char} is a lower-case letter.
|
||||||
|
|
||||||
@item lower(Upper)
|
@item lower(Upper)
|
||||||
@var{Char} is a lower-case version of Upper. Only true if @var{Char} is lowercase and Upper uppercase.
|
@var{Char} is a lower-case version of @var{Upper}. Only true if
|
||||||
|
@var{Char} is lowercase and @var{Upper} uppercase.
|
||||||
|
|
||||||
@item to_lower(Upper)
|
@item to_lower(Upper)
|
||||||
@var{Char} is a lower-case version of Upper. For non-letters, or letter without case, @var{Char} and Lower are the same. See also upcase_atom/2 and downcase_atom/2.
|
@var{Char} is a lower-case version of Upper. For non-letters, or letter without case, @var{Char} and Lower are the same. See also upcase_atom/2 and downcase_atom/2.
|
||||||
|
@ -337,7 +337,8 @@ thread_detach(Id) :-
|
|||||||
( recorded('$thread_exit_status', [Id0|_], _) ->
|
( recorded('$thread_exit_status', [Id0|_], _) ->
|
||||||
'$erase_thread_info'(Id0),
|
'$erase_thread_info'(Id0),
|
||||||
'$thread_destroy'(Id0)
|
'$thread_destroy'(Id0)
|
||||||
; true
|
;
|
||||||
|
'$thread_unlock'(Id0)
|
||||||
).
|
).
|
||||||
|
|
||||||
thread_exit(Term) :-
|
thread_exit(Term) :-
|
||||||
@ -637,6 +638,7 @@ message_queue_destroy(Queue) :-
|
|||||||
recorded('$queue',q(Queue,Mutex,Cond,_,QKey),R), !,
|
recorded('$queue',q(Queue,Mutex,Cond,_,QKey),R), !,
|
||||||
erase(R),
|
erase(R),
|
||||||
'$cond_destroy'(Cond),
|
'$cond_destroy'(Cond),
|
||||||
|
write(Queue:Mutex),nl,
|
||||||
'$destroy_mutex'(Mutex),
|
'$destroy_mutex'(Mutex),
|
||||||
'$unlock_mutex'(QMutex),
|
'$unlock_mutex'(QMutex),
|
||||||
'$clean_mqueue'(QKey).
|
'$clean_mqueue'(QKey).
|
||||||
|
Reference in New Issue
Block a user