inline
: assoc-push-if ( key value quot accum -- )
- >r 2over 2slip r> roll
+ >r 2keep r> roll
[ >r 2array r> push ] [ 3drop ] if ; inline
: assoc-pusher ( quot -- quot' accum )
over >r assoc-pusher >r assoc-each r> r> assoc-like ; inline
: assoc-all? ( assoc quot -- ? )
- [ not ] compose assoc-find 2nip not ; inline
+ [ not ] compose assoc-contains? not ; inline
: assoc-contains? ( assoc quot -- ? )
assoc-find 2nip ; inline
: stop ( -- )
walker-hook [
- f swap continue-with
+ continue
] [
run-queue pop-back dup array?
[ first2 continue-with ] [ continue ] if
UNION: vocab-spec vocab vocab-link ;
: forget-vocab ( vocab -- )
- dup vocab-words values forget-all
+ dup words forget-all
vocab-name dictionary get delete-at ;
M: vocab-spec forget* forget-vocab ;
: nsieve-bits-main ( n -- )
dup 2^ 10000 * nsieve-bits.
- dup 1 - 2^ 10000 * nsieve-bits.
+ dup 1- 2^ 10000 * nsieve-bits.
2 - 2^ 10000 * nsieve-bits. ;
: nsieve-bits-main* 11 nsieve-bits-main ;
: zero-dt ( -- <dt> ) 0 0 0 0 0 0 <dt> ;
: years ( n -- dt ) zero-dt [ set-dt-year ] keep ;
: months ( n -- dt ) zero-dt [ set-dt-month ] keep ;
-: weeks ( n -- dt ) 7 * zero-dt [ set-dt-day ] keep ;
: days ( n -- dt ) zero-dt [ set-dt-day ] keep ;
+: weeks ( n -- dt ) 7 * days ;
: hours ( n -- dt ) zero-dt [ set-dt-hour ] keep ;
: minutes ( n -- dt ) zero-dt [ set-dt-minute ] keep ;
: seconds ( n -- dt ) zero-dt [ set-dt-second ] keep ;
-: milliseconds ( n -- dt ) 1000 /f zero-dt [ set-dt-second ] keep ;
+: milliseconds ( n -- dt ) 1000 /f seconds ;
: julian-day-number>timestamp ( n -- timestamp )
julian-day-number>date 0 0 0 0 <timestamp> ;
1+ + 7 mod ;
: day-of-week ( timestamp -- n )
- [ timestamp-year ] keep
- [ timestamp-month ] keep
- timestamp-day
- zeller-congruence ;
+ >date< zeller-congruence ;
: day-of-year ( timestamp -- n )
[
] "" make 64 group ;
: shift-mod ( n s w -- n )
- >r shift r> 1 swap shift 1 - bitand ; inline
+ >r shift r> 2^ 1- bitand ; inline
: update-old-new ( old new -- )
[ get >r get r> ] 2keep >r >r w+ dup r> set r> set ; inline
: crlf "\r\n" write ;
: http-request ( host resource method -- )
- write " " write write " HTTP/1.0" write crlf
+ write bl write " HTTP/1.0" write crlf
"Host: " write write crlf ;
: get-request ( host resource -- )
>odd (find-relative-prime) ;
: find-relative-prime ( n -- p )
- dup random >odd (find-relative-prime) ;
+ dup random (find-relative-prime*) ;
: unique-primes ( numbits n -- seq )
#! generate two primes