Remove optimization nutbaggery and fix the sound init main thread bullshit
author |
Steve Losh <steve@stevelosh.com> |
date |
Tue, 22 Nov 2016 11:55:23 +0000 (2016-11-22) |
parents |
e20d9e9b90b3
|
children |
503bfe5cd173
|
branches/tags |
(none) |
files |
cl-chip8.asd src/emulator.lisp src/gui.lisp |
Changes
--- a/cl-chip8.asd Mon Nov 21 20:59:38 2016 +0000
+++ b/cl-chip8.asd Tue Nov 22 11:55:23 2016 +0000
@@ -7,16 +7,18 @@
:license "MIT/X11"
:version "1.0.0"
- :depends-on (:iterate
- :losh
+ :depends-on (
+ :bordeaux-threads
:cl-arrows
- :bordeaux-threads
+ :cl-opengl
:cl-portaudio
- :qtools
+ :iterate
+ :losh
:qtcore
:qtgui
+ :qtools
:qtopengl
- :cl-opengl)
+ )
:serial t
:components ((:module "vendor" :serial t
--- a/src/emulator.lisp Mon Nov 21 20:59:38 2016 +0000
+++ b/src/emulator.lisp Tue Nov 22 11:55:23 2016 +0000
@@ -26,7 +26,6 @@
(deftype int16 () '(unsigned-byte 16))
(deftype x-coord () `(integer 0 (,+screen-width+)))
(deftype y-coord () `(integer 0 (,+screen-height+)))
-(deftype memory-index () `(integer 0 (,+memory-size+)))
(deftype basic-array (element-type size)
`(simple-array ,(upgraded-array-element-type element-type) (,size)))
@@ -298,9 +297,7 @@
;;;; Graphics -----------------------------------------------------------------
(declaim (inline font-location vref (setf vref))
- (ftype (function (chip int8 int8 int4) null) draw-sprite)
- (ftype (function (chip x-coord y-coord) fixnum) vref)
- (ftype (function (fixnum chip x-coord y-coord) fixnum) (setf vref)))
+ (ftype (function (chip int8 int8 int4) null) draw-sprite))
(defun vref (chip x y)
@@ -341,37 +338,30 @@
(assert (< (+ index size) +memory-size+) (index)
"Sprite data of size ~D starting at #x~4,'0X would be out of bounds"
size index)
- ; (format t "Drawing sprite at ~d ~d~%" start-x start-y)
(setf flag 0)
(iterate
- (declare (iterate:declare-variables))
- (for (the fixnum y) :from start-y :below (+ start-y size))
- (for (the y-coord screen-y) = (mod y 32))
- (for (the fixnum i) :from index)
+ (for y :from start-y :below (+ start-y size))
+ (for screen-y = (mod y +screen-height+))
+ (for i :from index)
(for sprite = (aref memory i))
- (iterate (declare (iterate:declare-variables))
- (for (the fixnum x) :from start-x)
- (for (the x-coord screen-x) = (mod x 64))
- (for (the fixnum col) :from 7 :downto 0)
- (for (the fixnum old-pixel) = (vref chip screen-x screen-y))
- (for (the fixnum new-pixel) = (get-bit col sprite))
- ; (when (= old-pixel new-pixel 1)
- ; (setf flag 1))
- (when (and (plusp old-pixel) (plusp new-pixel))
+ (iterate (for x :from start-x)
+ (for screen-x = (mod x +screen-width+))
+ (for col :from 7 :downto 0)
+ (for old-pixel = (plusp (vref chip screen-x screen-y)))
+ (for new-pixel = (plusp (get-bit col sprite)))
+ (when (and old-pixel new-pixel)
(setf flag 1))
- ; (setf (vref chip screen-x screen-y)
- ; (logxor old-pixel new-pixel))
(setf (vref chip screen-x screen-y)
- (cond
- ((and (plusp old-pixel) (plusp new-pixel)) 0)
- ((or (plusp old-pixel) (plusp new-pixel)) 255)
- (t 0)))))
+ (if (eql old-pixel new-pixel)
+ 0
+ 255))))
(setf video-dirty t))
nil)
;;;; Keyboard -----------------------------------------------------------------
-(declaim (ftype (function (chip (integer 0 (16)))) keydown keyup))
+(declaim
+ (ftype (function (chip (integer 0 (16)))) keydown keyup))
(defun keydown (chip key)
(setf (aref (chip-keys chip) key) t))
@@ -720,13 +710,10 @@
(let ((chip (make-chip)))
(setf *c* chip)
(load-rom chip rom-filename)
- (bt:make-thread (curry #'run-cpu chip))
- (bt:make-thread (curry #'run-timers chip))
- (bt:make-thread (curry #'run-sound chip))
- (chip8.gui::run-gui chip)))
-
-
-;;;; Scratch ------------------------------------------------------------------
-
-; (-<> *c* chip-debugger debugger-callbacks-arrived
-; (push (lambda (pc) (pr 'hello pc)) <>))
+ (chip8.gui::run-gui
+ chip
+ (lambda ()
+ ;; Really it's just the sound that needs to be here...
+ (bt:make-thread (curry #'run-cpu chip))
+ (bt:make-thread (curry #'run-timers chip))
+ (bt:make-thread (curry #'run-sound chip))))))
--- a/src/gui.lisp Mon Nov 21 20:59:38 2016 +0000
+++ b/src/gui.lisp Tue Nov 22 11:55:23 2016 +0000
@@ -197,8 +197,9 @@
;;;; Main ---------------------------------------------------------------------
-(defun run-gui (chip)
+(defun run-gui (chip thunk)
(with-main-window
- (window (make-screen chip))))
+ (window (make-screen chip))
+ (funcall thunk)))