Refactor ALL the things!!
author |
Steve Losh <steve@stevelosh.com> |
date |
Sun, 26 Jun 2011 18:47:29 -0400 (2011-06-26) |
parents |
fc293cb5f83e
|
children |
b9f9991e6175
|
branches/tags |
(none) |
files |
src/clojurecraft/core.clj src/clojurecraft/in.clj src/clojurecraft/out.clj |
Changes
--- a/src/clojurecraft/core.clj Fri Jun 24 21:05:15 2011 -0400
+++ b/src/clojurecraft/core.clj Sun Jun 26 18:47:29 2011 -0400
@@ -3,7 +3,8 @@
(:use [clojurecraft.in])
(:use [clojurecraft.out])
(:import (java.net Socket)
- (java.io DataOutputStream DataInputStream)))
+ (java.io DataOutputStream DataInputStream)
+ (java.util.concurrent LinkedBlockingQueue)))
(def minecraft-local {:name "localhost" :port 25565})
@@ -30,13 +31,33 @@
(read-packet bot)))
(println "done"))
+(defn location-handler [bot]
+ (let [conn (:connection bot)
+ outqueue (:outqueue bot)]
+ (while (nil? (:exit @conn))
+ (let [player (:player bot)
+ location (:location @player)]
+ (when (not (nil? location))
+ (.put outqueue [:playerpositionlook location]))
+ (Thread/sleep 50)))))
+
+(defn output-handler [bot]
+ (let [conn (:connection bot)
+ outqueue (:outqueue bot)]
+ (while (nil? (:exit @conn))
+ (let [[packet-type, payload] (.take outqueue)]
+ (write-packet bot packet-type payload)))))
+
(defn connect [server]
(let [socket (Socket. (:name server) (:port server))
in (DataInputStream. (.getInputStream socket))
out (DataOutputStream. (.getOutputStream socket))
conn (ref {:in in :out out})
- bot {:connection conn}]
+ outqueue (LinkedBlockingQueue.)
+ player (ref {:location nil})
+ world (ref {})
+ bot {:connection conn, :outqueue outqueue, :player player, :world world}]
(println "connecting")
(login bot)
@@ -45,6 +66,15 @@
(println "starting read handler")
(doto (Thread. #(input-handler bot)) (.start))
+ (println "starting write handler")
+ (doto (Thread. #(output-handler bot)) (.start))
+
+ (println "starting location updating handler")
+ (doto (Thread. #(location-handler bot)) (.start))
+
+ (println "writing initial keepalive packet")
+ (.put outqueue [:keepalive {}])
+
(println "all systems go, returning bot")
bot))
@@ -54,6 +84,6 @@
; Scratch --------------------------------------------------------------------------
-;(def bot (connect minecraft-local))
-;(disconnect bot)
+(def bot (connect minecraft-local))
+(disconnect bot)
--- a/src/clojurecraft/in.clj Fri Jun 24 21:05:15 2011 -0400
+++ b/src/clojurecraft/in.clj Sun Jun 26 18:47:29 2011 -0400
@@ -67,385 +67,490 @@
; Reading Packets ------------------------------------------------------------------
-(defn- read-packet-keepalive [conn]
- nil)
+(defn- read-packet-keepalive [bot]
+ {})
-(defn- read-packet-handshake [conn]
- (assoc {}
- :hash (-read-string-ucs2 conn)))
+(defn- read-packet-handshake [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :hash (-read-string-ucs2 conn))]
+ payload))
-(defn- read-packet-login [conn]
- (assoc {}
- :eid (-read-int conn)
- :unknown (-read-string-ucs2 conn)
- :seed (-read-long conn)
- :dimension (-read-byte conn)))
+(defn- read-packet-login [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :unknown (-read-string-ucs2 conn)
+ :seed (-read-long conn)
+ :dimension (-read-byte conn))]
+ payload))
-(defn- read-packet-chat [conn]
- (assoc {}
- :message (-read-string-ucs2 conn)))
+(defn- read-packet-chat [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :message (-read-string-ucs2 conn))]
+ payload))
-(defn- read-packet-timeupdate [conn]
- (assoc {}
- :time (-read-long conn)))
+(defn- read-packet-timeupdate [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :time (-read-long conn))]
+ payload))
-(defn- read-packet-equipment [conn]
- (assoc {}
- :eid (-read-int conn)
- :slot (-read-short conn)
- :itemid (-read-short conn)
- :unknown (-read-short conn)))
+(defn- read-packet-equipment [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :slot (-read-short conn)
+ :itemid (-read-short conn)
+ :unknown (-read-short conn))]
+ payload))
-(defn- read-packet-spawnposition [conn]
- (assoc {}
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)))
+(defn- read-packet-spawnposition [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn))]
+ payload))
-(defn- read-packet-useentity [conn]
- (assoc {}
- :user (-read-int conn)
- :target (-read-int conn)
- :leftclick (-read-bool conn)))
+(defn- read-packet-useentity [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :user (-read-int conn)
+ :target (-read-int conn)
+ :leftclick (-read-bool conn))]
+ payload))
-(defn- read-packet-updatehealth [conn]
- (assoc {}
- :health (-read-short conn)))
+(defn- read-packet-updatehealth [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :health (-read-short conn))]
+ payload))
-(defn- read-packet-respawn [conn]
- (assoc {}
- :world (-read-byte conn)))
+(defn- read-packet-respawn [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :world (-read-byte conn))]
+ payload))
-(defn- read-packet-playerpositionlook [conn]
- (assoc {}
- :x (-read-double conn)
- :stance (-read-double conn)
- :y (-read-double conn)
- :z (-read-double conn)
- :yaw (-read-float conn)
- :pitch (-read-float conn)
- :onground (-read-bool conn)))
+(defn- read-packet-playerpositionlook [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-double conn)
+ :stance (-read-double conn)
+ :y (-read-double conn)
+ :z (-read-double conn)
+ :yaw (-read-float conn)
+ :pitch (-read-float conn)
+ :onground (-read-bool conn))]
+ (dosync (alter (:player bot) merge {:location payload}))
+ payload))
-(defn- read-packet-playerdigging [conn]
- (assoc {}
- :status (-read-byte conn)
- :x (-read-int conn)
- :y (-read-byte conn)
- :z (-read-int conn)
- :face (-read-byte conn)))
+(defn- read-packet-playerdigging [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :status (-read-byte conn)
+ :x (-read-int conn)
+ :y (-read-byte conn)
+ :z (-read-int conn)
+ :face (-read-byte conn))]
+ payload))
-(defn- read-packet-playerblockplacement [conn]
- (assoc {}
- :x (-read-int conn)
- :y (-read-byte conn)
- :z (-read-int conn)
- :direction (-read-byte conn)
- :id (-read-short conn)
- :amount (-read-byte conn)
- :damage (-read-short conn)))
+(defn- read-packet-playerblockplacement [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-int conn)
+ :y (-read-byte conn)
+ :z (-read-int conn)
+ :direction (-read-byte conn)
+ :id (-read-short conn)
+ :amount (-read-byte conn)
+ :damage (-read-short conn))]
+ payload))
-(defn- read-packet-holdingchange [conn]
- (assoc {}
- :slot (-read-short conn)))
+(defn- read-packet-holdingchange [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :slot (-read-short conn))]
+ payload))
-(defn- read-packet-usebed [conn]
- (assoc {}
- :eid (-read-int conn)
- :inbed (-read-byte conn)
- :x (-read-int conn)
- :y (-read-byte conn)
- :z (-read-int conn)))
+(defn- read-packet-usebed [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :inbed (-read-byte conn)
+ :x (-read-int conn)
+ :y (-read-byte conn)
+ :z (-read-int conn))]
+ payload))
-(defn- read-packet-animate [conn]
- (assoc {}
- :eid (-read-int conn)
- :animate (-read-byte conn)))
+(defn- read-packet-animate [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :animate (-read-byte conn))]
+ payload))
-(defn- read-packet-entityaction [conn]
- (assoc {}
- :eid (-read-int conn)
- :action (-read-byte conn)))
+(defn- read-packet-entityaction [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :action (-read-byte conn))]
+ payload))
-(defn- read-packet-namedentityspawn [conn]
- (assoc {}
- :eid (-read-int conn)
- :playername (-read-string-ucs2 conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)
- :rotation (-read-byte conn)
- :pitch (-read-byte conn)
- :currentitem (-read-short conn)))
+(defn- read-packet-namedentityspawn [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :playername (-read-string-ucs2 conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn)
+ :rotation (-read-byte conn)
+ :pitch (-read-byte conn)
+ :currentitem (-read-short conn))]
+ payload))
-(defn- read-packet-pickupspawn [conn]
- (assoc {}
- :eid (-read-int conn)
- :item (-read-short conn)
- :count (-read-byte conn)
- :damagedata (-read-short conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)
- :rotation (-read-byte conn)
- :pitch (-read-byte conn)
- :roll (-read-byte conn)))
+(defn- read-packet-pickupspawn [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :item (-read-short conn)
+ :count (-read-byte conn)
+ :damagedata (-read-short conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn)
+ :rotation (-read-byte conn)
+ :pitch (-read-byte conn)
+ :roll (-read-byte conn))]
+ payload))
-(defn- read-packet-collectitem [conn]
- (assoc {}
- :collectedeid (-read-int conn)
- :collectoreid (-read-int conn)))
+(defn- read-packet-collectitem [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :collectedeid (-read-int conn)
+ :collectoreid (-read-int conn))]
+ payload))
-(defn- read-packet-addobjectvehicle [conn]
- (let [basepacket (assoc {}
- :eid (-read-int conn)
- :type (-read-byte conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)
- :moar (-read-int conn))]
- (if (< 0 (:moar basepacket))
- basepacket
- (assoc basepacket
- :unknownx (-read-int conn)
- :unknowny (-read-int conn)
- :unknownz (-read-int conn)))))
+(defn- read-packet-addobjectvehicle [bot]
+ (let [conn (:connection bot)
+ payload (let [basepacket (assoc {}
+ :eid (-read-int conn)
+ :type (-read-byte conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn)
+ :moar (-read-int conn))]
+ (if (< 0 (:moar basepacket))
+ basepacket
+ (assoc basepacket
+ :unknownx (-read-int conn)
+ :unknowny (-read-int conn)
+ :unknownz (-read-int conn))))]
+ payload))
-(defn- read-packet-mobspawn [conn]
- (assoc {}
- :eid (-read-int conn)
- :type (-read-byte conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)
- :yaw (-read-byte conn)
- :pitch (-read-byte conn)
- :datastream (-read-metadata conn)))
+(defn- read-packet-mobspawn [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :type (-read-byte conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn)
+ :yaw (-read-byte conn)
+ :pitch (-read-byte conn)
+ :datastream (-read-metadata conn))]
+ payload))
-(defn- read-packet-entitypainting [conn]
- (assoc {}
- :eid (-read-int conn)
- :type (-read-string-ucs2 conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)
- :direction (-read-int conn)))
+(defn- read-packet-entitypainting [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :type (-read-string-ucs2 conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn)
+ :direction (-read-int conn))]
+ payload))
-(defn- read-packet-stanceupdate [conn]
- (assoc {}
- :unknown1 (-read-float conn)
- :unknown2 (-read-float conn)
- :unknown3 (-read-bool conn)
- :unknown4 (-read-bool conn)
- :unknown5 (-read-float conn)
- :unknown6 (-read-float conn)))
+(defn- read-packet-stanceupdate [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :unknown1 (-read-float conn)
+ :unknown2 (-read-float conn)
+ :unknown3 (-read-bool conn)
+ :unknown4 (-read-bool conn)
+ :unknown5 (-read-float conn)
+ :unknown6 (-read-float conn))]
+ payload))
-(defn- read-packet-entityvelocity [conn]
- (assoc {}
- :eid (-read-int conn)
- :velocityx (-read-short conn)
- :velocityy (-read-short conn)
- :velocityz (-read-short conn)))
+(defn- read-packet-entityvelocity [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :velocityx (-read-short conn)
+ :velocityy (-read-short conn)
+ :velocityz (-read-short conn))]
+ payload))
-(defn- read-packet-entitydestroy [conn]
- (assoc {}
- :eid (-read-int conn)))
+(defn- read-packet-entitydestroy [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn))]
+ payload))
-(defn- read-packet-entity [conn]
- (assoc {}
- :eid (-read-int conn)))
+(defn- read-packet-entity [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn))]
+ payload))
-(defn- read-packet-entityrelativemove [conn]
- (assoc {}
- :eid (-read-int conn)
- :dx (-read-byte conn)
- :dy (-read-byte conn)
- :dz (-read-byte conn)))
+(defn- read-packet-entityrelativemove [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :dx (-read-byte conn)
+ :dy (-read-byte conn)
+ :dz (-read-byte conn))]
+ payload))
-(defn- read-packet-entitylook [conn]
- (assoc {}
- :eid (-read-int conn)
- :yaw (-read-byte conn)
- :pitch (-read-byte conn)))
+(defn- read-packet-entitylook [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :yaw (-read-byte conn)
+ :pitch (-read-byte conn))]
+ payload))
-(defn- read-packet-entitylookandrelativemove [conn]
- (assoc {}
- :eid (-read-int conn)
- :dx (-read-byte conn)
- :dy (-read-byte conn)
- :dz (-read-byte conn)
- :yaw (-read-byte conn)
- :pitch (-read-byte conn)))
+(defn- read-packet-entitylookandrelativemove [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :dx (-read-byte conn)
+ :dy (-read-byte conn)
+ :dz (-read-byte conn)
+ :yaw (-read-byte conn)
+ :pitch (-read-byte conn))]
+ payload))
-(defn- read-packet-entityteleport [conn]
- (assoc {}
- :eid (-read-int conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)
- :yaw (-read-byte conn)
- :pitch (-read-byte conn)))
+(defn- read-packet-entityteleport [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn)
+ :yaw (-read-byte conn)
+ :pitch (-read-byte conn))]
+ payload))
-(defn- read-packet-entitystatus [conn]
- (assoc {}
- :eid (-read-int conn)
- :entitystatus (-read-byte conn)))
+(defn- read-packet-entitystatus [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :entitystatus (-read-byte conn))]
+ payload))
-(defn- read-packet-attachentity [conn]
- (assoc {}
- :eid (-read-int conn)
- :vehicleid (-read-int conn)))
+(defn- read-packet-attachentity [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :vehicleid (-read-int conn))]
+ payload))
-(defn- read-packet-entitymetadata [conn]
- (assoc {}
- :eid (-read-int conn)
- :metadata (-read-metadata conn)))
+(defn- read-packet-entitymetadata [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :metadata (-read-metadata conn))]
+ payload))
-(defn- read-packet-prechunk [conn]
- (assoc {}
- :x (-read-int conn)
- :z (-read-int conn)
- :mode (-read-bool conn)))
+(defn- read-packet-prechunk [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-int conn)
+ :z (-read-int conn)
+ :mode (-read-bool conn))]
+ payload))
-(defn- read-packet-mapchunk [conn]
- (let [predata (assoc {}
- :x (-read-int conn)
- :y (-read-short conn)
- :z (-read-int conn)
- :sizex (-read-byte conn)
- :sizey (-read-byte conn)
- :sizez (-read-byte conn)
- :compressedsize (-read-int conn))]
- (assoc predata
- :compresseddata
- (-read-bytearray conn
- (:compressedsize predata)))))
+(defn- read-packet-mapchunk [bot]
+ (let [conn (:connection bot)
+ payload (let [predata (assoc {}
+ :x (-read-int conn)
+ :y (-read-short conn)
+ :z (-read-int conn)
+ :sizex (-read-byte conn)
+ :sizey (-read-byte conn)
+ :sizez (-read-byte conn)
+ :compressedsize (-read-int conn))]
+ (assoc predata
+ :compresseddata
+ (-read-bytearray conn
+ (:compressedsize predata))))]
+ payload))
-(defn- read-packet-multiblockchange [conn]
- (assoc {}
- :chunkx (-read-int conn)
- :chunkz (-read-int conn)
- :arraysize (-read-short conn)
- :coordinatearray (-read-shortarray conn)
- :typearray (-read-bytearray conn)
- :metadataarray (-read-bytearray conn)))
+(defn- read-packet-multiblockchange [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :chunkx (-read-int conn)
+ :chunkz (-read-int conn)
+ :arraysize (-read-short conn)
+ :coordinatearray (-read-shortarray conn arraysize)
+ :typearray (-read-bytearray conn arraysize)
+ :metadataarray (-read-bytearray conn arraysize))]
+ payload))
-(defn- read-packet-blockchange [conn]
- (assoc {}
- :x (-read-int conn)
- :y (-read-byte conn)
- :z (-read-int conn)
- :blocktype (-read-byte conn)
- :blockmetadata (-read-byte conn)))
+(defn- read-packet-blockchange [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-int conn)
+ :y (-read-byte conn)
+ :z (-read-int conn)
+ :blocktype (-read-byte conn)
+ :blockmetadata (-read-byte conn))]
+ payload))
-(defn- read-packet-playnoteblock [conn]
- (assoc {}
- :x (-read-int conn)
- :y (-read-short conn)
- :z (-read-int conn)
- :instrumenttype (-read-byte conn)
- :pitch (-read-byte conn)))
+(defn- read-packet-playnoteblock [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-int conn)
+ :y (-read-short conn)
+ :z (-read-int conn)
+ :instrumenttype (-read-byte conn)
+ :pitch (-read-byte conn))]
+ payload))
-(defn- read-packet-explosion [conn]
- (let [prerecords (assoc {}
- :x (-read-int conn)
- :y (-read-short conn)
- :z (-read-int conn)
- :unknownradius (-read-byte conn)
- :recordcount (-read-byte conn))]
- (assoc prerecords
- :records (-read-bytearray conn
- (* 3 (:recordcount prerecords))))))
+(defn- read-packet-explosion [bot]
+ (let [conn (:connection bot)
+ payload (let [prerecords (assoc {}
+ :x (-read-int conn)
+ :y (-read-short conn)
+ :z (-read-int conn)
+ :unknownradius (-read-byte conn)
+ :recordcount (-read-byte conn))]
+ (assoc prerecords
+ :records (-read-bytearray conn
+ (* 3 (:recordcount prerecords)))))]
+ payload))
-(defn- read-packet-soundeffect [conn]
- (assoc {}
- :effectid (-read-int conn)
- :x (-read-int conn)
- :y (-read-byte conn)
- :z (-read-int conn)
- :sounddata (-read-int conn)))
+(defn- read-packet-soundeffect [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :effectid (-read-int conn)
+ :x (-read-int conn)
+ :y (-read-byte conn)
+ :z (-read-int conn)
+ :sounddata (-read-int conn))]
+ payload))
-(defn- read-packet-newinvalidstate [conn]
- (assoc {}
- :reason (-read-byte conn)))
+(defn- read-packet-newinvalidstate [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :reason (-read-byte conn))]
+ payload))
-(defn- read-packet-thunderbolt [conn]
- (assoc {}
- :eid (-read-int conn)
- :unknown (-read-bool conn)
- :x (-read-int conn)
- :y (-read-int conn)
- :z (-read-int conn)))
+(defn- read-packet-thunderbolt [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :eid (-read-int conn)
+ :unknown (-read-bool conn)
+ :x (-read-int conn)
+ :y (-read-int conn)
+ :z (-read-int conn))]
+ payload))
-(defn- read-packet-openwindow [conn]
- (assoc {}
- :windowid (-read-byte conn)
- :inventorytype (-read-byte conn)
- :windowtitle (-read-string-utf8 conn)
- :numberofslots (-read-byte conn)))
+(defn- read-packet-openwindow [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :windowid (-read-byte conn)
+ :inventorytype (-read-byte conn)
+ :windowtitle (-read-string-utf8 conn)
+ :numberofslots (-read-byte conn))]
+ payload))
-(defn- read-packet-closewindow [conn]
- (assoc {}
- :windowid (-read-byte conn)))
+(defn- read-packet-closewindow [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :windowid (-read-byte conn))]
+ payload))
-(defn- read-packet-setslot [conn]
- (assoc {}
- :windowid (-read-byte conn)
- :slot (-read-short conn)
- :itemid (-read-short conn)
- :itemcount (-read-byte conn)
- :itemuses (-read-short conn)))
+(defn- read-packet-setslot [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :windowid (-read-byte conn)
+ :slot (-read-short conn)
+ :itemid (-read-short conn)
+ :itemcount (-read-byte conn)
+ :itemuses (-read-short conn))]
+ payload))
-(defn- read-packet-windowitems [conn]
- (letfn [(-read-payload-item []
- (let [payload (assoc {} :itemid (-read-short conn))]
- (if (= (:itemid payload) -1)
- payload
- (assoc payload
- :count (-read-byte conn)
- :uses (-read-short conn)))))]
- (let [prepayload (assoc {}
- :windowid (-read-byte conn)
- :count (-read-short conn))
- payload (repeatedly (:count prepayload) -read-payload-item)]
- (assoc prepayload :payload payload))))
+(defn- read-packet-windowitems [bot]
+ (let [conn (:connection bot)
+ payload (letfn [(-read-payload-item []
+ (let [payload (assoc {} :itemid (-read-short conn))]
+ (if (= (:itemid payload) -1)
+ payload
+ (assoc payload
+ :count (-read-byte conn)
+ :uses (-read-short conn)))))]
+ (let [prepay (assoc {}
+ :windowid (-read-byte conn)
+ :count (-read-short conn))
+ pay (repeatedly (:count prepay) -read-payload-item)]
+ (assoc prepay :payload pay)))]
+ payload))
-(defn- read-packet-updateprogressbar [conn]
- (assoc {}
- :windowid (-read-byte conn)
- :progressbar (-read-short conn)
- :value (-read-short conn)))
+(defn- read-packet-updateprogressbar [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :windowid (-read-byte conn)
+ :progressbar (-read-short conn)
+ :value (-read-short conn))]
+ payload))
-(defn- read-packet-transaction [conn]
- (assoc {}
- :windowid (-read-byte conn)
- :actionnumber (-read-short conn)
- :accepted (-read-short conn)))
+(defn- read-packet-transaction [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :windowid (-read-byte conn)
+ :actionnumber (-read-short conn)
+ :accepted (-read-short conn))]
+ payload))
-(defn- read-packet-updatesign [conn]
- (assoc {}
- :x (-read-int conn)
- :y (-read-short conn)
- :z (-read-int conn)
- :text1 (-read-string-ucs2 conn)
- :text2 (-read-string-ucs2 conn)
- :text3 (-read-string-ucs2 conn)
- :text4 (-read-string-ucs2 conn)))
+(defn- read-packet-updatesign [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :x (-read-int conn)
+ :y (-read-short conn)
+ :z (-read-int conn)
+ :text1 (-read-string-ucs2 conn)
+ :text2 (-read-string-ucs2 conn)
+ :text3 (-read-string-ucs2 conn)
+ :text4 (-read-string-ucs2 conn))]
+ payload))
-(defn- read-packet-mapdata [conn]
- (let [pretext (assoc {}
- :unknown1 (-read-int conn)
- :unknown2 (-read-short conn)
- :textlength (-read-int conn))]
- (assoc pretext :text (-read-bytearray (:textlength pretext)))))
+(defn- read-packet-mapdata [bot]
+ (let [conn (:connection bot)
+ payload (let [pretext (assoc {}
+ :unknown1 (-read-int conn)
+ :unknown2 (-read-short conn)
+ :textlength (-read-int conn))]
+ (assoc pretext :text (-read-bytearray (:textlength pretext))))]
+ payload))
-(defn- read-packet-incrementstatistic [conn]
- (assoc {}
- :statisticid (-read-int conn)
- :amount (-read-byte conn)))
+(defn- read-packet-incrementstatistic [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :statisticid (-read-int conn)
+ :amount (-read-byte conn))]
+ payload))
-(defn- read-packet-disconnectkick [conn]
- (assoc {}
- :reason (-read-string-ucs2 conn)))
+(defn- read-packet-disconnectkick [bot]
+ (let [conn (:connection bot)
+ payload (assoc {}
+ :reason (-read-string-ucs2 conn))]
+ payload))
; Reading Wrappers -----------------------------------------------------------------
@@ -454,63 +559,65 @@
packet-id (int (-read-byte conn))
packet-type (packet-types packet-id)]
(if (= nil packet-type)
- (println (str "UNKNOWN PACKET TYPE: " (Integer/toHexString packet-id)))
(do
- (println "\n--PACKET--> " packet-type)
- (println
+ (println (str "UNKNOWN PACKET TYPE: " (Integer/toHexString packet-id)))
+ (/ 1 0))
+ (do
+ (identity (str "\n--PACKET--> " packet-type))
+ (identity
(case packet-type
- :keepalive (read-packet-keepalive conn)
- :handshake (read-packet-handshake conn)
- :login (read-packet-login conn)
- :chat (read-packet-chat conn)
- :timeupdate (read-packet-timeupdate conn)
- :equipment (read-packet-equipment conn)
- :spawnposition (read-packet-spawnposition conn)
- :useentity (read-packet-useentity conn)
- :updatehealth (read-packet-updatehealth conn)
- :respawn (read-packet-respawn conn)
- :playerpositionlook (read-packet-playerpositionlook conn)
- :playerdigging (read-packet-playerdigging conn)
- :playerblockplacement (read-packet-playerblockplacement conn)
- :holdingchange (read-packet-holdingchange conn)
- :usebed (read-packet-usebed conn)
- :animate (read-packet-animate conn)
- :entityaction (read-packet-entityaction conn)
- :namedentityspawn (read-packet-namedentityspawn conn)
- :pickupspawn (read-packet-pickupspawn conn)
- :collectitem (read-packet-collectitem conn)
- :addobjectvehicle (read-packet-addobjectvehicle conn)
- :mobspawn (read-packet-mobspawn conn)
- :entitypainting (read-packet-entitypainting conn)
- :stanceupdate (read-packet-stanceupdate conn)
- :entityvelocity (read-packet-entityvelocity conn)
- :entitydestroy (read-packet-entitydestroy conn)
- :entity (read-packet-entity conn)
- :entityrelativemove (read-packet-entityrelativemove conn)
- :entitylook (read-packet-entitylook conn)
- :entitylookandrelativemove (read-packet-entitylookandrelativemove conn)
- :entityteleport (read-packet-entityteleport conn)
- :entitystatus (read-packet-entitystatus conn)
- :attachentity (read-packet-attachentity conn)
- :entitymetadata (read-packet-entitymetadata conn)
- :prechunk (read-packet-prechunk conn)
- :mapchunk (read-packet-mapchunk conn)
- :multiblockchange (read-packet-multiblockchange conn)
- :blockchange (read-packet-blockchange conn)
- :playnoteblock (read-packet-playnoteblock conn)
- :explosion (read-packet-explosion conn)
- :soundeffect (read-packet-soundeffect conn)
- :newinvalidstate (read-packet-newinvalidstate conn)
- :thunderbolt (read-packet-thunderbolt conn)
- :openwindow (read-packet-openwindow conn)
- :closewindow (read-packet-closewindow conn)
- :setslot (read-packet-setslot conn)
- :windowitems (read-packet-windowitems conn)
- :updateprogressbar (read-packet-updateprogressbar conn)
- :transaction (read-packet-transaction conn)
- :updatesign (read-packet-updatesign conn)
- :mapdata (read-packet-mapdata conn)
- :incrementstatistic (read-packet-incrementstatistic conn)
- :disconnectkick (read-packet-disconnectkick conn)))))
- (println "\n\n\n")))
+ :keepalive (read-packet-keepalive bot)
+ :handshake (read-packet-handshake bot)
+ :login (read-packet-login bot)
+ :chat (read-packet-chat bot)
+ :timeupdate (read-packet-timeupdate bot)
+ :equipment (read-packet-equipment bot)
+ :spawnposition (read-packet-spawnposition bot)
+ :useentity (read-packet-useentity bot)
+ :updatehealth (read-packet-updatehealth bot)
+ :respawn (read-packet-respawn bot)
+ :playerpositionlook (read-packet-playerpositionlook bot)
+ :playerdigging (read-packet-playerdigging bot)
+ :playerblockplacement (read-packet-playerblockplacement bot)
+ :holdingchange (read-packet-holdingchange bot)
+ :usebed (read-packet-usebed bot)
+ :animate (read-packet-animate bot)
+ :entityaction (read-packet-entityaction bot)
+ :namedentityspawn (read-packet-namedentityspawn bot)
+ :pickupspawn (read-packet-pickupspawn bot)
+ :collectitem (read-packet-collectitem bot)
+ :addobjectvehicle (read-packet-addobjectvehicle bot)
+ :mobspawn (read-packet-mobspawn bot)
+ :entitypainting (read-packet-entitypainting bot)
+ :stanceupdate (read-packet-stanceupdate bot)
+ :entityvelocity (read-packet-entityvelocity bot)
+ :entitydestroy (read-packet-entitydestroy bot)
+ :entity (read-packet-entity bot)
+ :entityrelativemove (read-packet-entityrelativemove bot)
+ :entitylook (read-packet-entitylook bot)
+ :entitylookandrelativemove (read-packet-entitylookandrelativemove bot)
+ :entityteleport (read-packet-entityteleport bot)
+ :entitystatus (read-packet-entitystatus bot)
+ :attachentity (read-packet-attachentity bot)
+ :entitymetadata (read-packet-entitymetadata bot)
+ :prechunk (read-packet-prechunk bot)
+ :mapchunk (read-packet-mapchunk bot)
+ :multiblockchange (read-packet-multiblockchange bot)
+ :blockchange (read-packet-blockchange bot)
+ :playnoteblock (read-packet-playnoteblock bot)
+ :explosion (read-packet-explosion bot)
+ :soundeffect (read-packet-soundeffect bot)
+ :newinvalidstate (read-packet-newinvalidstate bot)
+ :thunderbolt (read-packet-thunderbolt bot)
+ :openwindow (read-packet-openwindow bot)
+ :closewindow (read-packet-closewindow bot)
+ :setslot (read-packet-setslot bot)
+ :windowitems (read-packet-windowitems bot)
+ :updateprogressbar (read-packet-updateprogressbar bot)
+ :transaction (read-packet-transaction bot)
+ :updatesign (read-packet-updatesign bot)
+ :mapdata (read-packet-mapdata bot)
+ :incrementstatistic (read-packet-incrementstatistic bot)
+ :disconnectkick (read-packet-disconnectkick bot)))))
+ (identity "\n\n\n")))
--- a/src/clojurecraft/out.clj Fri Jun 24 21:05:15 2011 -0400
+++ b/src/clojurecraft/out.clj Sun Jun 26 18:47:29 2011 -0400
@@ -3,17 +3,14 @@
; Writing Data ---------------------------------------------------------------------
(defn- -write-byte [conn i]
- (println (str "-> PACKET ID: " (Integer/toHexString i)))
(doto (:out @conn)
(.writeByte (int i))))
(defn- -write-bytearray [conn ba]
- (println (str "-> BYTEARRAY: " ba))
(doto (:out @conn)
(.write ba 0 (count ba))))
(defn- -write-short [conn i]
- (println (str "-> SHORT: " i))
(doto (:out @conn)
(.writeShort (int i))))
@@ -21,38 +18,31 @@
(map #(-write-short %) sa))
(defn- -write-int [conn i]
- (println (str "-> INT: " i))
(doto (:out @conn)
(.writeInt (int i))))
(defn- -write-long [conn i]
- (println (str "-> LONG: " i))
(doto (:out @conn)
(.writeLong (int i))))
(defn- -write-double [conn i]
- (println (str "-> DOUBLE: " i))
(doto (:out @conn)
(.writeDouble (int i))))
(defn- -write-float [conn i]
- (println (str "-> FLOAT: " i))
(doto (:out @conn)
(.writeFloat (int i))))
(defn- -write-string-utf8 [conn s]
- (println (str "-> STRING: " s))
(doto (:out @conn)
(.writeUTF s)))
(defn- -write-string-ucs2 [conn s]
(-write-short conn (count s))
- (println (str "-> STRING: " s))
(doto (:out @conn)
(.writeChars s)))
(defn- -write-bool [conn b]
- (println (str "-> BOOL: " b))
(doto (:out @conn)
(.writeBoolean b)))
@@ -63,7 +53,7 @@
; Writing Packets ------------------------------------------------------------------
(defn- write-packet-keepalive [conn _]
- (-write-byte conn (:handshake packet-ids)))
+ (-write-byte conn (:keepalive packet-ids)))
(defn- write-packet-handshake [conn {username :username}]
(-write-byte conn (:handshake packet-ids))
@@ -317,9 +307,11 @@
(doto (:out @conn) (.flush)))
(defn write-packet [bot packet-type payload]
+ (println (str "<--WRITING-- " packet-type))
+ (println payload)
(let [conn (:connection bot)]
(case packet-type
- :keepalive (write-packet-handshake conn payload)
+ :keepalive (write-packet-keepalive conn payload)
:handshake (write-packet-handshake conn payload)
:login (write-packet-login conn payload)
:chat (write-packet-chat conn payload)
@@ -352,5 +344,6 @@
:updatesign (write-packet-updatesign conn payload)
:incrementstatistic (write-packet-incrementstatistic conn payload)
:disconnectkick (write-packet-disconnectkick conn payload))
- (flushc conn)))
+ (flushc conn))
+ (println "written\n\n"))