Another inconclusive session: still nothing works, still making progress.
This commit is contained in:
parent
ef59563e25
commit
eed4711fee
35 changed files with 317 additions and 232 deletions
|
|
@ -27,21 +27,10 @@
|
|||
* @return true if `p` points to `nil`.
|
||||
* @return false otherwise.
|
||||
*/
|
||||
bool nilp( struct pso_pointer p ) {
|
||||
bool c_nilp(struct pso_pointer p) {
|
||||
return ( p.page == 0 && p.offset == 0 );
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Return `true` if `p` points to `nil`, else `false`.
|
||||
*
|
||||
* @param p a pointer
|
||||
* @return true if `p` points to `nil`;
|
||||
* @return false otherwise.
|
||||
*/
|
||||
bool not( struct pso_pointer p ) {
|
||||
return !nilp( p );
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief `true` if `p` points to `t`, else `false`.
|
||||
*
|
||||
|
|
@ -56,52 +45,82 @@ bool not( struct pso_pointer p ) {
|
|||
* @return true if `p` points to `t`.
|
||||
* @return false otherwise.
|
||||
*/
|
||||
bool truep( struct pso_pointer p ) {
|
||||
bool c_truep( struct pso_pointer p ) {
|
||||
return ( p.page == 0 && p.offset == 4 );
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief return `t` if the first argument in this frame is `nil`, else `t`.
|
||||
*
|
||||
* @param frame The current stack frame;
|
||||
* @param frame_pointer A pointer to the current stack frame;
|
||||
* @param env the evaluation environment.
|
||||
* @return `t` if the first argument in this frame is `nil`, else `t`
|
||||
*/
|
||||
struct pso_pointer lisp_nilp( struct pso_pointer frame_pointer,
|
||||
struct pso_pointer env ) {
|
||||
struct pso_pointer nilp( struct pso_pointer frame_pointer ) {
|
||||
struct pso4 *frame = pointer_to_pso4( frame_pointer );
|
||||
|
||||
return ( nilp( fetch_arg( frame, 0 ) ) ? t : nil );
|
||||
return ( c_nilp( fetch_arg( frame, 0 ) ) ? t : nil );
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief return `t` if the first argument in this frame is `t`, else `nil`.
|
||||
*
|
||||
* @param frame The current stack frame;
|
||||
* @param frame_pointer A pointer to the current stack frame;
|
||||
* @param env the evaluation environment.
|
||||
* @return `t` if the first argument in this frame is `t`, else `nil`.
|
||||
*/
|
||||
struct pso_pointer lisp_truep( struct pso_pointer frame_pointer,
|
||||
struct pso_pointer env ) {
|
||||
struct pso_pointer truep( struct pso_pointer frame_pointer ) {
|
||||
struct pso4 *frame = pointer_to_pso4( frame_pointer );
|
||||
|
||||
return ( truep( fetch_arg( frame, 0 ) ) ? t : nil );
|
||||
return ( c_truep( fetch_arg( frame, 0 ) ) ? t : nil );
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief return `t` if the first argument in this frame is not `nil`, else
|
||||
* `t`.
|
||||
*
|
||||
* @param frame The current stack frame;
|
||||
* @param frame_pointer A pointer to the current stack frame;
|
||||
* @param env the evaluation environment.
|
||||
* @return `t` if the first argument in this frame is not `nil`, else `t`.
|
||||
*/
|
||||
struct pso_pointer lisp_not( struct pso_pointer frame_pointer,
|
||||
struct pso_pointer env ) {
|
||||
struct pso_pointer not( struct pso_pointer frame_pointer) {
|
||||
struct pso4 *frame = pointer_to_pso4( frame_pointer );
|
||||
|
||||
return ( not( fetch_arg( frame, 0 ) ) ? t : nil );
|
||||
return ( !c_nilp( fetch_arg( frame, 0 ) ) ? t : nil );
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief (and args...)
|
||||
*
|
||||
* @return `nil` if any `arg` is `nil`, else `t`.
|
||||
*/
|
||||
struct pso_pointer and( struct pso_pointer frame_pointer) {
|
||||
struct pso4* frame = pointer_to_pso4( frame_pointer);
|
||||
struct pso_pointer result = t;
|
||||
|
||||
for (int arg = 0; c_truep(result) && arg < frame->payload.stack_frame.args; arg++) {
|
||||
if (c_nilp(fetch_arg(frame, arg))) {
|
||||
result = nil;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @brief (or args...)
|
||||
*
|
||||
* @return `t` if any `arg` is non-nil, else `nil`.
|
||||
*/
|
||||
struct pso_pointer or( struct pso_pointer frame_pointer) {
|
||||
struct pso4* frame = pointer_to_pso4( frame_pointer);
|
||||
struct pso_pointer result = nil;
|
||||
|
||||
for (int arg = 0; c_truep(result) && arg < frame->payload.stack_frame.args; arg++) {
|
||||
if (!c_nilp(fetch_arg(frame, arg))) {
|
||||
result = t;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue