changeset 106:3a60bb14a64a

better functional assembly interface; removed frame numbers from SaveStates
author Robert McIntyre <rlm@mit.edu>
date Wed, 14 Mar 2012 21:37:37 -0500 (2012-03-15)
parents 2f8089eacab9
children ad96e9464d6a
files clojure/com/aurellem/assembly.clj clojure/com/aurellem/experiments/items.clj clojure/com/aurellem/gb_driver.clj clojure/com/aurellem/items.clj java/src/com/aurellem/gb/Gb.java
diffstat 5 files changed, 227 insertions(+), 197 deletions(-) [+]
line wrap: on
line diff
     1.1 --- a/clojure/com/aurellem/assembly.clj	Tue Mar 13 14:40:01 2012 -0500
     1.2 +++ b/clojure/com/aurellem/assembly.clj	Wed Mar 14 21:37:37 2012 -0500
     1.3 @@ -2,14 +2,13 @@
     1.4    (:use (com.aurellem gb-driver vbm title items))
     1.5    (:import [com.aurellem.gb_driver SaveState]))
     1.6  
     1.7 -
     1.8 -
     1.9 +(defn mid-game []
    1.10 +  (read-state "mid-game"))
    1.11  
    1.12  (defn inject-assembly
    1.13    [^SaveState state
    1.14     program-counter registers
    1.15     assembly-code]
    1.16 -  (set-state! state)
    1.17    (let [scratch-memory (memory state)]
    1.18      ;; inject assembly code
    1.19      (dorun (map (fn [index val]
    1.20 @@ -17,12 +16,11 @@
    1.21                  (range program-counter
    1.22                         (+ program-counter (count assembly-code)))
    1.23                  assembly-code))
    1.24 -    (write-memory! scratch-memory)
    1.25 -    (set-state! (update-state))
    1.26 -    (write-registers! registers)
    1.27 -    (set-state! (update-state))
    1.28 -    (PC! program-counter)
    1.29 -    (update-state)))
    1.30 +    (-> state
    1.31 +        (write-memory! scratch-memory)
    1.32 +        (write-registers! registers)
    1.33 +        (PC! program-counter))))
    1.34 +        
    1.35  
    1.36  (defn inject-item-assembly
    1.37    ([^SaveState state assembly-code]
    1.38 @@ -34,19 +32,17 @@
    1.39  
    1.40  (defn info
    1.41    ([^SaveState state]
    1.42 -     (set-state! state)
    1.43 -     (println "PC: " (PC))
    1.44 -     (println "Instruction:" (format "0x%02X" (aget (memory state) (PC))))
    1.45 +     (println "PC: " (PC state))
    1.46 +     (println "Instruction:"
    1.47 +              (format "0x%02X" (aget (memory state) (PC state))))
    1.48       state))    
    1.49  
    1.50 -(defn irony [] (read-state 578544))
    1.51 -
    1.52  (defn run-assembly
    1.53    ([info-fn assembly n]
    1.54       (let [final-state
    1.55             (reduce (fn [state _]
    1.56                       (tick (info-fn state)))
    1.57 -                   (inject-item-assembly (tick (tick (tick (irony)))) assembly)
    1.58 +                   (inject-item-assembly (tick (tick (tick (mid-game)))) assembly)
    1.59                     (range n))]
    1.60         (shutdown!)
    1.61         final-state))
     2.1 --- a/clojure/com/aurellem/experiments/items.clj	Tue Mar 13 14:40:01 2012 -0500
     2.2 +++ b/clojure/com/aurellem/experiments/items.clj	Wed Mar 14 21:37:37 2012 -0500
     2.3 @@ -1,3 +1,7 @@
     2.4 +(ns com.aurellem.experiments.items
     2.5 +   (:use (com.aurellem gb-driver vbm title items))
     2.6 +   (:import [com.aurellem.gb_driver SaveState]))
     2.7 +
     2.8  ;; try just buying five potions in sequence and see what changes
     2.9  ;; each time.
    2.10  
    2.11 @@ -10,28 +14,27 @@
    2.12  
    2.13  ;; trying to find how items are represented in memory
    2.14  
    2.15 -(comment
    2.16 -  (def empty-inventory @current-state)
    2.17 -  
    2.18 -  (def one-potion @current-state)
    2.19 -  
    2.20 -  (def two-potions @current-state)
    2.21 -  
    2.22 -  (def three-potions @current-state)
    2.23 -  
    2.24 -  (def four-potions @current-state)
    2.25 -  
    2.26 -  (def five-potions @current-state)
    2.27 +(def zero-potions (read-state "zero-potions"))
    2.28 +
    2.29 +(def one-potion (read-state "one-potion"))
    2.30 +
    2.31 +(def two-potions (read-state "two-potions"))
    2.32 +
    2.33 +(def three-potions (read-state "three-potions"))
    2.34 +
    2.35 +(def four-potions (read-state "four-potions"))
    2.36 +
    2.37 +(def five-potions (read-state "five-potions"))
    2.38    
    2.39    
    2.40    ;; result
    2.41 -  (def canidates
    2.42 -    (apply common-differences
    2.43 -           (map (comp vec memory)
    2.44 -                [empty-inventory one-potion two-potions three-potions
    2.45 -                 four-potions five-potions])))
    2.46 +(defn canidates []
    2.47 +  (apply common-differences
    2.48 +         (map (comp vec memory)
    2.49 +              [zero-potions one-potion two-potions three-potions
    2.50 +               four-potions five-potions])))
    2.51  
    2.52 -  [55875 (37 15 49 27 14 44)]
    2.53 + (comment [55875 (37 15 49 27 14 44)]
    2.54    [55876 (30 1 49 56 55 23)]
    2.55    [49158 (154 191 78 135 70 73)]
    2.56    [54087 (49 40 37 34 25 22)]
    2.57 @@ -53,10 +56,6 @@
    2.58  
    2.59  
    2.60  
    2.61 -(def item-hack (read-state 7999))
    2.62 -
    2.63 -(def item-hack2 (read-state 75882))
    2.64 -
    2.65  (defn get-mem []
    2.66    (subvec (vec (memory @current-state)) 54040 (+ 54046 100)))
    2.67  
    2.68 @@ -92,14 +91,19 @@
    2.69  
    2.70  ;; now it's time to learn the item codes
    2.71  
    2.72 -(def item-hack-3 (read-state 77557))
    2.73 +(def inventory-begin
    2.74 +  (read-state "inventory-begin"))
    2.75 +
    2.76  (defn show-item
    2.77    "Run a saved pokemon with the first item replaced by the item named
    2.78     by n."
    2.79    [n]
    2.80 -  (set-state! item-hack-3)
    2.81 +  (set-state! inventory-begin)
    2.82    (let [mem (memory)]
    2.83 +    (aset mem 54044 1)
    2.84      (aset mem 54045 n)
    2.85 +    (aset mem 54046 1)
    2.86 +    (aset mem 54047 255)
    2.87      (write-memory! mem))
    2.88    (step)
    2.89    (->> [[] @current-state]
    2.90 @@ -372,3 +376,128 @@
    2.91  ;; 253   TM53
    2.92  ;; 254   TM54
    2.93  ;; 255   end-of-list-sentinel   
    2.94 +
    2.95 +
    2.96 +
    2.97 +(defn run-item-program
    2.98 +  "This is my first assembly/item program!
    2.99 +   it just increments BC by one.
   2.100 +
   2.101 +   The code places a 3 'great balls' at the beginning of the
   2.102 +   inventory, then directly sets the program counter to start
   2.103 +   executing at the position of the 'great balls' in memory.
   2.104 +
   2.105 +   Since a 'great ball' is represented in memory as 0x03, which
   2.106 +   corresponts to the opcode which increments BC by one, that is
   2.107 +   what happens. Then the program counter to the 0x03 quantity entry
   2.108 +   and BC is incremented again.
   2.109 +
   2.110 +   Obviously, the game crashes more or less immediately after the
   2.111 +   program counter advances past the 'great balls' into the next items
   2.112 +   in the inventory, thus I call shutdown! before anything bad happens."
   2.113 +  []
   2.114 +  (set-inventory (read-state "mid-game") [[:great-ball 3]])
   2.115 +  (print-inventory)
   2.116 +  (println "3 ticks") (tick) (tick) (tick)
   2.117 +  (println "PC before:" (PC))
   2.118 +  (println "BC before:" (BC))
   2.119 +  (PC! (inc item-list-start))
   2.120 +  (println "PC after setting:" (PC))
   2.121 +  (println "data at PC:" (aget (memory) (PC)))
   2.122 +  (println "one tick")
   2.123 +  (tick)
   2.124 +  (println "PC after one tick:" (PC))
   2.125 +  (println "BC after one tick:" (BC))
   2.126 +  (tick)
   2.127 +  (println "PC after two ticks:" (PC))
   2.128 +  (println "BC after two ticks:" (BC))
   2.129 +
   2.130 +  (shutdown!))
   2.131 +
   2.132 +
   2.133 +
   2.134 +
   2.135 +(defn test-opcodes-1
   2.136 +  []
   2.137 +  (let [final-state
   2.138 +        (->
   2.139 +         (read-state "mid-game")
   2.140 +         (set-inv-mem 
   2.141 +          [20 0x02 0x00 0x00 0x02 0x00 0x00
   2.142 +           0x00 0x0 0xFF])
   2.143 +         (print-inventory)
   2.144 +         ;;((fn [_] (println "3 ticks") _))
   2.145 +         (tick) (tick) (tick)
   2.146 +         
   2.147 +         ;;(println "PC before:" (PC))
   2.148 +         ;;(println "BC before:" (BC))
   2.149 +         ;;(println "AF:" (AF))
   2.150 +         (PC! (inc item-list-start))
   2.151 +         (BC! (+ 1 item-list-start))
   2.152 +         ;;(println "PC after setting:" (PC))
   2.153 +         ;;(println "data at PC:" (aget (memory) (PC)))
   2.154 +         ;;(println "data at " (BC) "(BC):" (aget (memory) (BC)))
   2.155 +         
   2.156 +         ;;(println "one tick")
   2.157 +         (tick)
   2.158 +         ;;(println "PC after one tick:" (PC))
   2.159 +         ;;(println "BC after one tick:" (BC))
   2.160 +         ;;(println "data at PC:" (aget (memory) (PC)))
   2.161 +         ;;(println "data at " (BC) "(BC):" (aget (memory) (BC)))
   2.162 +         (tick)
   2.163 +         (AF! 0xFFFF)
   2.164 +         ;;(println "PC after two ticks:" (PC))
   2.165 +         ;;(println "BC after two ticks:" (BC))
   2.166 +         ;;(println "data at PC:" (aget (memory) (PC)))
   2.167 +         ;;(println "data at " (BC) "(BC):" (aget (memory) (BC)))
   2.168 +         (tick)
   2.169 +         ;;(println "PC after three ticks:" (PC))
   2.170 +         ;;(println "BC after three ticks:" (BC))
   2.171 +         ;;(println "data at PC:" (aget (memory) (PC)))
   2.172 +         ;;(println "data at " (BC) "(BC):" (aget (memory) (BC)))
   2.173 +         (tick)
   2.174 +         ;;(println "PC after four ticks:" (PC))
   2.175 +         ;;(println "BC after four ticks:" (BC))
   2.176 +         ;;(println "data at PC:" (aget (memory) (PC)))
   2.177 +         ;;(println "data at " (BC) "(BC):" (aget (memory) (BC)))
   2.178 +         (tick)
   2.179 +         ;;(println "PC after five ticks:" (PC))
   2.180 +         ;;(println "BC after five ticks:" (BC))
   2.181 +         ;;(println "data at PC:" (aget (memory) (PC)))
   2.182 +         ;;(println "data at " (BC) "(BC):" (aget (memory) (BC)))
   2.183 +         (print-inventory)
   2.184 +         )]
   2.185 +    
   2.186 +    (shutdown!)
   2.187 +    final-state))
   2.188 +
   2.189 +
   2.190 +
   2.191 +(defn test-opcodes-2
   2.192 +  []
   2.193 +  (set-inv-mem (read-state "mid-game")
   2.194 +               [20 0x08 0x1D 0xD3 0x00 0x00 0x00
   2.195 +                0x00 0x0 0xFF])
   2.196 +  (print-inventory)
   2.197 +  (println "3 ticks") (tick) (tick) (tick)
   2.198 +  (println "PC before:" (PC))
   2.199 +  (println "SP:" (SP))
   2.200 +  (PC! (inc item-list-start))
   2.201 +  (println "PC after setting:" (PC))
   2.202 +  (println "SP:" (Integer/toBinaryString (SP)))
   2.203 +  (println "data at PC:" (aget (memory) (PC)))
   2.204 +  (println "data at 0xD31D:" (Integer/toBinaryString (aget (memory) 0xD31D)))
   2.205 +  (println "data at 0xD31E:" (Integer/toBinaryString (aget (memory) 0xD31E)))
   2.206 +  (println "one tick")
   2.207 +  (tick)
   2.208 +  (println "PC after one tick:" (PC))
   2.209 +  (println "data at PC:" (aget (memory) (PC)))
   2.210 +  (println "data at 0xD31D:" (Integer/toBinaryString (aget (memory) 0xD31D)))
   2.211 +  (println "data at 0xD31E:" (Integer/toBinaryString (aget (memory) 0xD31E)))
   2.212 +  (tick) (tick) (tick)
   2.213 +  (println "PC aftter four tick:" (PC))
   2.214 +  (println "data at PC:" (aget (memory) (PC)))
   2.215 +  (println "data at 0xD31D:" (aget (memory) 0xD31D))
   2.216 +  
   2.217 +  (print-inventory)
   2.218 +  (shutdown!))
     3.1 --- a/clojure/com/aurellem/gb_driver.clj	Tue Mar 13 14:40:01 2012 -0500
     3.2 +++ b/clojure/com/aurellem/gb_driver.clj	Wed Mar 14 21:37:37 2012 -0500
     3.3 @@ -5,31 +5,36 @@
     3.4      (:import (java.nio IntBuffer ByteOrder)))
     3.5  
     3.6  ;; Savestates
     3.7 -(defrecord SaveState [frame data])
     3.8 +(defrecord SaveState [data])
     3.9  
    3.10  (def ^:dynamic *save-state-cache*
    3.11    (File. "/home/r/proj/pokemon-escape/save-states/"))
    3.12  
    3.13 -(defn frame->filename [frame]
    3.14 -  (File. *save-state-cache* (format "%07d.sav" frame)))
    3.15 -  
    3.16 -(defn write-state! [^SaveState save]
    3.17 -  (let [buf (:data save)
    3.18 -        bytes (byte-array (.limit buf))
    3.19 -        dest (frame->filename (:frame save))]
    3.20 -    (.get buf bytes)
    3.21 -    (FileUtils/writeByteArrayToFile dest bytes)
    3.22 -    (.rewind buf)
    3.23 -    dest))
    3.24 +(def current-state (atom nil))
    3.25  
    3.26 -(defn read-state [frame]
    3.27 -  (let [save (frame->filename frame)]
    3.28 +(defn state-cache-file [name]
    3.29 +  (File. *save-state-cache* (str name ".sav")))
    3.30 +
    3.31 +(defn write-state!
    3.32 +  ([^SaveState name]
    3.33 +     (write-state! @current-state name))
    3.34 +  ([^SaveState save ^String name]
    3.35 +     (let [buffer (:data save)
    3.36 +           bytes (byte-array (.limit buffer))
    3.37 +           dest (state-cache-file name)]
    3.38 +       (.get buffer bytes)
    3.39 +       (FileUtils/writeByteArrayToFile dest bytes)
    3.40 +       (.rewind buffer)
    3.41 +       dest)))
    3.42 +
    3.43 +(defn read-state [name]
    3.44 +  (let [save (state-cache-file name)]
    3.45      (if (.exists save)
    3.46 -      (let [buf (Gb/saveBuffer)
    3.47 +      (let [buffer (Gb/saveBuffer)
    3.48              bytes (FileUtils/readFileToByteArray save)]
    3.49 -        (.put buf bytes)
    3.50 -        (.flip buf)
    3.51 -        (SaveState. frame buf)))))
    3.52 +        (.put buffer bytes)
    3.53 +        (.flip buffer)
    3.54 +        (SaveState. buffer)))))
    3.55  ;;;;;;;;;;;;;;;;
    3.56  
    3.57  ;; Gameboy management
    3.58 @@ -54,13 +59,12 @@
    3.59  ;;; The first state!
    3.60  (defn gen-root! []
    3.61    (restart!)
    3.62 -  (let [state (SaveState. 0  (Gb/saveState))]
    3.63 -    (write-state! state)
    3.64 -    state))
    3.65 +  (let [state (SaveState. (Gb/saveState))]
    3.66 +    (write-state! state "root" ) state))
    3.67  
    3.68  (defn root []
    3.69 -  (if (.exists (frame->filename 0))
    3.70 -    (read-state 0)
    3.71 +  (if (.exists (state-cache-file "root"))
    3.72 +    (read-state "root")
    3.73      (gen-root!)))
    3.74  
    3.75  ;;;; Press Buttons
    3.76 @@ -88,27 +92,24 @@
    3.77  (defn button-mask [buttons]
    3.78    (reduce bit-or 0x0000 (map button-code buttons)))
    3.79  
    3.80 -(def current-state (atom nil))
    3.81 -
    3.82  (defn set-state! [^SaveState state]
    3.83    (assert (:data state) "Not a valid state!")
    3.84    (if (not @on?) (restart!))
    3.85 -  (Gb/loadState (:data state))
    3.86 -  (reset! current-state state))
    3.87 -
    3.88 -(defrecord Move [keys state])
    3.89 +  (if (not= state @current-state)
    3.90 +    (do 
    3.91 +      (Gb/loadState (:data state))
    3.92 +      (reset! current-state state))))
    3.93  
    3.94  (defn update-state []
    3.95    (reset! current-state
    3.96 -          (SaveState. (:frame @current-state)
    3.97 -                      (Gb/saveState))))
    3.98 +          (SaveState. (Gb/saveState))))
    3.99  
   3.100  (defn step
   3.101    ([^SaveState state buttons]
   3.102       (set-state! state)
   3.103       (Gb/step (button-mask buttons))
   3.104       (reset! current-state 
   3.105 -             (SaveState. (inc (:frame state))(Gb/saveState))))
   3.106 +             (SaveState. (Gb/saveState))))
   3.107    ([^SaveState state]
   3.108       (step state [:listen]))
   3.109    ([] (step (if @current-state @current-state (root)))))
   3.110 @@ -120,18 +121,24 @@
   3.111       (Gb/tick)
   3.112       (update-state)))
   3.113  
   3.114 -(defn move
   3.115 -  [^Move move buttons]
   3.116 -  (Move. (step (:state move) buttons) buttons))
   3.117 -
   3.118  (defn play
   3.119    ([^SaveState state n]
   3.120 -     (reduce (fn [s _] (step s)) state (range n)))
   3.121 +     (try
   3.122 +       (set-state! state)
   3.123 +       (dorun (dotimes [_ n]
   3.124 +                (Thread/sleep 1)
   3.125 +                (Gb/step)))
   3.126 +
   3.127 +       (finally
   3.128 +             (update-state))))
   3.129    ([n]
   3.130       (play @current-state n)))
   3.131  
   3.132 -(defn continue! []
   3.133 -  (play @current-state Integer/MAX_VALUE))
   3.134 +(defn continue!
   3.135 +  ([state]
   3.136 +     (play state Integer/MAX_VALUE))
   3.137 +  ([]
   3.138 +    (continue! @current-state)))
   3.139  
   3.140  (defn play-moves
   3.141    ([moves [prev state]]
   3.142 @@ -152,10 +159,16 @@
   3.143           (set-state! state) (arr-fn store) store))))
   3.144  
   3.145  (defn write-cpu-data [size store-fn]
   3.146 -  (fn [new-data]
   3.147 -    (let [store (int-array new-data)]
   3.148 -      (assert (= size (count new-data)))
   3.149 -      (store-fn store))))
   3.150 +  (fn store-data
   3.151 +    ([state new-data]
   3.152 +       (set-state! state)
   3.153 +       (let [store (int-array new-data)]
   3.154 +         (assert (= size (count new-data)))
   3.155 +         (store-fn store)
   3.156 +         (update-state)))
   3.157 +    ([new-data]
   3.158 +       (store-data @current-state new-data))))
   3.159 +    
   3.160  
   3.161  (def memory
   3.162    (cpu-data Gb/GB_MEMORY #(Gb/getMemory %)))
     4.1 --- a/clojure/com/aurellem/items.clj	Tue Mar 13 14:40:01 2012 -0500
     4.2 +++ b/clojure/com/aurellem/items.clj	Wed Mar 14 21:37:37 2012 -0500
     4.3 @@ -214,7 +214,8 @@
     4.4                    (aset mem index val))
     4.5                  (range item-list-start
     4.6                         (+ item-list-start (count inv-codes))) inv-codes))
     4.7 -    (write-memory! mem)))
     4.8 +    (write-memory! mem)
     4.9 +    (update-state)))
    4.10    
    4.11    
    4.12  (defn set-inventory [^SaveState state new-inventory]
    4.13 @@ -235,7 +236,11 @@
    4.14                      (concat items (inventory state))))
    4.15    ([items]
    4.16       (give @current-state items)))
    4.17 -  
    4.18 +
    4.19 +(defn clear-inventory
    4.20 +  ([^SaveState state]
    4.21 +     (set-inventory state []))
    4.22 +  ([] (clear-inventory @current-state)))
    4.23  
    4.24  (def gliched-tms
    4.25    [[:TM51 1]
    4.26 @@ -264,115 +269,3 @@
    4.27     [:soulbadge 1]    
    4.28     ])
    4.29    
    4.30 -(defn run-item-program
    4.31 -  "This is my first assembly/item program!
    4.32 -   it just increments BC by one.
    4.33 -
    4.34 -   The code places a 3 'great balls' at the beginning of the
    4.35 -   inventory, then directly sets the program counter to start
    4.36 -   executing at the position of the 'great balls' in memory.
    4.37 -
    4.38 -   Since a 'great ball' is represented in memory as 0x03, which
    4.39 -   corresponts to the opcode which increments BC by one, that is
    4.40 -   what happens. Then the program counter to the 0x03 quantity entry
    4.41 -   and BC is incremented again.
    4.42 -
    4.43 -   Obviously, the game crashes more or less immediately after the
    4.44 -   program counter advances past the 'great balls' into the next items
    4.45 -   in the inventory, thus I call shutdown! before anything bad happens."
    4.46 -  []
    4.47 -  (set-inventory (read-state 578544) [[:great-ball 3]])
    4.48 -  (print-inventory)
    4.49 -  (println "3 ticks") (tick) (tick) (tick)
    4.50 -  (println "PC before:" (PC))
    4.51 -  (println "BC before:" (BC))
    4.52 -  (PC! (inc item-list-start))
    4.53 -  (println "PC after setting:" (PC))
    4.54 -  (println "data at PC:" (aget (memory) (PC)))
    4.55 -  (println "one tick")
    4.56 -  (tick)
    4.57 -  (println "PC after one tick:" (PC))
    4.58 -  (println "BC after one tick:" (BC))
    4.59 -  (tick)
    4.60 -  (println "PC after two ticks:" (PC))
    4.61 -  (println "BC after two ticks:" (BC))
    4.62 -
    4.63 -  (shutdown!))
    4.64 -
    4.65 -
    4.66 -(defn test-opcodes-1
    4.67 -  []
    4.68 -  (set-inv-mem (read-state 578544)
    4.69 -               [20 0x02 0x00 0x00 0x02 0x00 0x00
    4.70 -                0x00 0x0 0xFF])
    4.71 -  (print-inventory)
    4.72 -  (println "3 ticks") (tick) (tick) (tick)
    4.73 -  (println "PC before:" (PC))
    4.74 -  (println "BC before:" (BC))
    4.75 -  (println "AF:" (AF))
    4.76 -  (PC! (inc item-list-start))
    4.77 -  (BC! (+ 1 item-list-start))
    4.78 -  (println "PC after setting:" (PC))
    4.79 -  (println "data at PC:" (aget (memory) (PC)))
    4.80 -  (println "data at " (BC) "(BC):" (aget (memory) (BC)))
    4.81 -  
    4.82 -  (println "one tick")
    4.83 -  (tick)
    4.84 -  (println "PC after one tick:" (PC))
    4.85 -  (println "BC after one tick:" (BC))
    4.86 -  (println "data at PC:" (aget (memory) (PC)))
    4.87 -  (println "data at " (BC) "(BC):" (aget (memory) (BC)))
    4.88 -  (tick)
    4.89 -  (AF! 0xFFFF)
    4.90 -  (println "PC after two ticks:" (PC))
    4.91 -  (println "BC after two ticks:" (BC))
    4.92 -  (println "data at PC:" (aget (memory) (PC)))
    4.93 -  (println "data at " (BC) "(BC):" (aget (memory) (BC)))
    4.94 -  (tick)
    4.95 -  (println "PC after three ticks:" (PC))
    4.96 -  (println "BC after three ticks:" (BC))
    4.97 -  (println "data at PC:" (aget (memory) (PC)))
    4.98 -  (println "data at " (BC) "(BC):" (aget (memory) (BC)))
    4.99 -  (tick)
   4.100 -  (println "PC after four ticks:" (PC))
   4.101 -  (println "BC after four ticks:" (BC))
   4.102 -  (println "data at PC:" (aget (memory) (PC)))
   4.103 -  (println "data at " (BC) "(BC):" (aget (memory) (BC)))
   4.104 -  (tick)
   4.105 -  (println "PC after five ticks:" (PC))
   4.106 -  (println "BC after five ticks:" (BC))
   4.107 -  (println "data at PC:" (aget (memory) (PC)))
   4.108 -  (println "data at " (BC) "(BC):" (aget (memory) (BC)))
   4.109 -  (print-inventory)
   4.110 -  (shutdown!))
   4.111 -
   4.112 -
   4.113 -
   4.114 -(defn test-opcodes-2
   4.115 -  []
   4.116 -  (set-inv-mem (read-state 578544)
   4.117 -               [20 0x08 0x1D 0xD3 0x00 0x00 0x00
   4.118 -                0x00 0x0 0xFF])
   4.119 -  (print-inventory)
   4.120 -  (println "3 ticks") (tick) (tick) (tick)
   4.121 -  (println "PC before:" (PC))
   4.122 -  (println "SP:" (SP))
   4.123 -  (PC! (inc item-list-start))
   4.124 -  (println "PC after setting:" (PC))
   4.125 -  (println "SP:" (Integer/toBinaryString (SP)))
   4.126 -  (println "data at PC:" (aget (memory) (PC)))
   4.127 -  (println "data at 0xD31D:" (Integer/toBinaryString (aget (memory) 0xD31D)))
   4.128 -  (println "data at 0xD31E:" (Integer/toBinaryString (aget (memory) 0xD31E)))
   4.129 -  (println "one tick")
   4.130 -  (tick)
   4.131 -  (println "PC after one tick:" (PC))
   4.132 -  (println "data at PC:" (aget (memory) (PC)))
   4.133 -  (println "data at 0xD31D:" (Integer/toBinaryString (aget (memory) 0xD31D)))
   4.134 -  (println "data at 0xD31E:" (Integer/toBinaryString (aget (memory) 0xD31E)))
   4.135 -  (tick) (tick) (tick)
   4.136 -  (println "PC aftter four tick:" (PC))
   4.137 -  (println "data at PC:" (aget (memory) (PC)))
   4.138 -  (println "data at 0xD31D:" (aget (memory) 0xD31D))
   4.139 -  
   4.140 -  (print-inventory)
   4.141 -  (shutdown!))
     5.1 --- a/java/src/com/aurellem/gb/Gb.java	Tue Mar 13 14:40:01 2012 -0500
     5.2 +++ b/java/src/com/aurellem/gb/Gb.java	Wed Mar 14 21:37:37 2012 -0500
     5.3 @@ -20,7 +20,6 @@
     5.4       * @param rom - the name of the rom.
     5.5       */
     5.6      public static native void startEmulator(String rom);
     5.7 -
     5.8      
     5.9      public static void loadVBA(){
    5.10  	System.loadLibrary("vba");