diff --git a/INSTALL.md b/INSTALL.md index 50b180c9a..e74db0e9e 100644 --- a/INSTALL.md +++ b/INSTALL.md @@ -1,6 +1,6 @@ # Getting Started -Compiling **pokecrystal.gbc** requires a certain **Pokemon Crystal** rom: +Assembling **pokecrystal.gbc** requires a certain **Pokemon Crystal** rom: ``` Pokemon - Crystal Version (UE) (V1.0) [C][!].gbc @@ -10,11 +10,16 @@ md5: 9f2922b235a5eeb78d65594e82ef5dde Save it as **baserom.gbc** in the repository. -Feel free to ask us on **[nucleus.kafuka.org #skeetendo](https://kiwiirc.com/client/irc.nolimitzone.com/?#skeetendo)** if something goes wrong! +Feel free to ask us on +**[nucleus.kafuka.org #skeetendo](https://kiwiirc.com/client/irc.nolimitzone.com/?#skeetendo)** +if something goes wrong. + + # Windows -If you are on Windows and can't install Linux, **Cygwin** is a great alternative. +If you're on Windows and can't install Linux, **Cygwin** is a great alternative. + ## Installing Cygwin @@ -25,15 +30,21 @@ Cygwin provides a virtual Linux environment on Windows systems. Just get **setup During the install: * Keep the defaults. - * Most mirrors are molasses. Use **http://mirrors.kernel.org**. - -* From the package selection, select **wget**. +* From the package selection, pick: + * **wget** + * **make** + * **git** + * **python** + * **python-setuptools** + * **unzip** ## Using Cygwin -Launch the **Cygwin terminal**. Maybe you know your way around the Linux terminal, **bash**. If not, a crash course: +Launch the **Cygwin terminal**. +Maybe you know your way around the Linux terminal ( **bash** ). +If not, a crash course: ```bash # list files in current directory ls @@ -48,119 +59,113 @@ cd /away/we/go ## Getting up and running -We need a couple more things to be able to compile. +We need three things to assemble the source into a rom. +1. **rgbds** +2. a **pokecrystal** repository +3. a **base rom** -If you're feeling lazy, just paste these commands into your terminal. - - -**apt-cyg** lets you install new packages without running Cygwin setup. +- +We use **rgbds** to spit out a Game Boy rom from source. ```bash -wget http://apt-cyg.googlecode.com/svn/trunk/apt-cyg -chmod +x apt-cyg -mv apt-cyg /usr/local/bin/ +cd /usr/local/bin +wget http://iimarck.us/etc/rgbds-20130811.zip +unzip -j rgbds-20130811.zip +rm rgbds-20130811.zip ``` -Now we can use apt-cyg to install everything else. - -```bash -apt-cyg install make git python python-setuptools unzip -easy_install pip -``` - -**rgbds** will let you compile Game Boy roms. - -```bash -wget http://diyhpl.us/~bryan/irc/pokered/rgbds/rgbds-0.0.1.zip -unzip rgbds-0.0.1.zip -mv rgbds-0.0.1/* /usr/local/bin -rm -r rgbds-0.0.1* -``` - -Set up the **pokecrystal** repository: - +The **pokecrystal** repository contains the source files used to create the rom. ```bash cd ~ git clone https://github.com/kanzure/pokecrystal cd pokecrystal # install python requirements +easy_install pip pip install -r requirements.txt ``` -## Don't forget baserom.gbc!! +Not everything is included in the source yet. +Missing patches are copied from a **base rom** (not included). -Make sure you downloaded a base rom. Name it **baserom.gbc**. +``` +Pokemon - Crystal Version (UE) (V1.0) [C][!].gbc +md5: 9f2922b235a5eeb78d65594e82ef5dde +``` + +Name it **baserom.gbc**. + +- Now you should be able to build **pokecrystal.gbc** for the first time. - -This compiles a new rom from the source code, with any patches filled in from the base rom. +This assembles a new rom from the source code. ```bash make ``` This ought to take **between 3 and 15 seconds**, depending on your computer. -If you see `cmp baserom.gbc pokecrystal.gbc` as the last line, the build was successful! +If the last line is `cmp baserom.gbc pokecrystal.gbc`, the build was successful! -Your first compile processes every source file at once. After that, **only modified source files have to be reprocessed**, so compiling again should be a few seconds faster. +Your first build processes every source file at once. +After that, **only modified source files have to be processed again**, +so compiling again should be a few seconds faster. -Other **make targets** that may come in handy: - -`make clean` deletes any preprocessed source files (.tx), rgbds object files and pokecrystal.gbc, in case something goes wrong. - -`make pngs` decompresses any **lz** files in gfx/ and then exports any graphics files to **png**. - -`make lzs` does the reverse. This is already part of the build process, so **modified pngs will automatically be converted to 2bpp and lz-compressed** without any additional work. # Linux ```bash sudo apt-get install make gcc bison git python python-setuptools - -# unittest2 is required if using python2.6 -sudo easy_install unittest2 sudo easy_install pip -# download rgbds source code +# install rgbds git clone git://github.com/bentley/rgbds.git - -# compile rgbds cd rgbds make sudo make install -# check if rgbasm is installed now -which rgbasm +cd .. # download pokecrystal git clone git://github.com/kanzure/pokecrystal.git cd pokecrystal - -# install python requirements pip install -r requirements.txt - -# use hexdump to diff binary files -git config diff.hex.textconv hexdump ``` -To compile the rom from asm source: +Put your base rom in the pokecrystal repository. Name it **baserom.gbc**. + +To compile the rom from source: ```bash make ``` -That will take between 3 and 15 seconds, depending on your computer. If you see `cmp baserom.gbc pokecrystal.gbc` as the last line, the build was successful! Rejoice! +That will take between 3 and 15 seconds, depending on your computer. +If you see `cmp baserom.gbc pokecrystal.gbc` as the last line, the build was successful! Rejoice! + # Now what? -**main.asm** is a good starting point. The structure of the source is laid out here. +**[pokecrystal.asm](https://github.com/kanzure/pokecrystal/blob/master/pokecrystal.asm)** is a good starting point. +The structure of the source is laid out here. -* **Can't find something?** Anyone can add to the source. There's lots to be uncovered. -* **Do your own thing!** The asm source is hack-friendly, and the supplementary scripts in extras/ can be used for other projects. +* Other **make targets** that may come in handy: + + * `make clean` deletes any preprocessed source files (.tx), rgbds object files and pokecrystal.gbc. + * `make pngs` decompresses any **lz** files in gfx/ and then exports any graphics files to **png**. + * `make lzs` does the reverse. This is already part of the build process, so **modified pngs will automatically be converted to 2bpp and lz-compressed** without any additional work. + + +* **Can't find something?** +Anyone can add to the source. There's lots to be uncovered. + +* **Do your own thing!** +The asm source is hack-friendly, and the supplementary scripts in extras/ can be used for other projects. + +We'll be happy to answer any **questions** on +**[nucleus.kafuka.org #skeetendo](https://kiwiirc.com/client/irc.nolimitzone.com/?#skeetendo)**. -* We'll be happy to answer any **questions** on **[nucleus.kafuka.org #skeetendo](https://kiwiirc.com/client/irc.nolimitzone.com/?#skeetendo)**. diff --git a/Makefile b/Makefile index 6a75eeef0..06de33b56 100644 --- a/Makefile +++ b/Makefile @@ -21,7 +21,7 @@ pokecrystal.o: $(TEXTFILES:.asm=.tx) wram.asm constants.asm $(shell find constan @rm -f $@ pokecrystal.gbc: pokecrystal.o - rgblink -o $@ $< + rgblink -n pokecrystal.sym -m pokecrystal.map -o $@ $< rgbfix -Cjv -i BYTE -k 01 -l 0x33 -m 0x10 -p 0 -r 3 -t PM_CRYSTAL $@ pngs: