X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcode%2Ftarget-random.lisp;h=9937cd7d36b0f60a386c634b96444cec83a6a085;hb=b5703d98da9ebfd688c87e14862ab4e26dc94d14;hp=46b33d71dfea07fcbfd90302b18d5bc487531422;hpb=0b5610d8a220a4b20cbeac958953ca4d67c00038;p=sbcl.git diff --git a/src/code/target-random.lisp b/src/code/target-random.lisp index 46b33d7..9937cd7 100644 --- a/src/code/target-random.lisp +++ b/src/code/target-random.lisp @@ -61,21 +61,30 @@ of the default random state. If STATE is a random state, then return a copy of it. If STATE is T then return a random state generated from the universal time." + (/show0 "entering !RANDOM-COLD-INIT") (flet ((copy-random-state (state) + (/show0 "entering COPY-RANDOM-STATE") (let ((state (random-state-state state)) (new-state (make-array 627 :element-type '(unsigned-byte 32)))) + (/show0 "made NEW-STATE, about to DOTIMES") (dotimes (i 627) (setf (aref new-state i) (aref state i))) + (/show0 "falling through to %MAKE-RANDOM-STATE") (%make-random-state :state new-state)))) - (cond ((not state) (copy-random-state *random-state*)) - ((random-state-p state) (copy-random-state state)) - ((eq state t) - (%make-random-state :state (init-random-state - (logand (get-universal-time) - #xffffffff)))) - ;; FIXME: should be TYPE-ERROR? - (t (error "Argument is not a RANDOM-STATE, T or NIL: ~S" state))))) + (/show0 "at head of ETYPECASE in MAKE-RANDOM-STATE") + (etypecase state + (null + (/show0 "NULL case") + (copy-random-state *random-state*)) + (random-state + (/show0 "RANDOM-STATE-P clause") + (copy-random-state state)) + ((member t) + (/show0 "T clause") + (%make-random-state :state (init-random-state + (logand (get-universal-time) + #xffffffff))))))) ;;;; random entries