diff options
| -rw-r--r-- | INSTALL.md | 135 | ||||
| -rw-r--r-- | Makefile | 2 | 
2 files changed, 71 insertions, 66 deletions
| 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. - - -If you're feeling lazy, just paste these commands into your terminal. - - -**apt-cyg** lets you install new packages without running Cygwin setup. - -```bash -wget http://apt-cyg.googlecode.com/svn/trunk/apt-cyg -chmod +x apt-cyg -mv apt-cyg /usr/local/bin/ -``` - -Now we can use apt-cyg to install everything else. +We need three things to assemble the source into a rom. -```bash -apt-cyg install make git python python-setuptools unzip -easy_install pip -``` +1. **rgbds** +2. a **pokecrystal** repository +3. a **base rom** -**rgbds** will let you compile Game Boy roms. +- +We use **rgbds** to spit out a Game Boy rom from source.  ```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* +cd /usr/local/bin +wget http://iimarck.us/etc/rgbds-20130811.zip +unzip -j rgbds-20130811.zip +rm rgbds-20130811.zip  ``` -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). + +``` +Pokemon - Crystal Version (UE) (V1.0) [C][!].gbc +md5: 9f2922b235a5eeb78d65594e82ef5dde +``` + +Name it **baserom.gbc**. -Make sure you downloaded a base rom. 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. + + +* 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. -* **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. -* **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)**. @@ -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: | 
