Skip to content

Tutorial: Your First Hack

Cooper Harasyn edited this page Oct 6, 2024 · 21 revisions

Your First Hack

The standard program most programmers write when learning a new language is Hello World, which prints "Hello World!" onscreen in some way. Sounds exciting, right?

It isn't. It's boring.

So let's do a twist on that that's a bit more involved, but is hopefully a lot more rewarding.

Planning the Hack

A hack without a plan is like a train without a steering wheel: it works just fine. However, you might want some levers and other controls on that train, because unless derailing trains is your weekend hobby, you're not likely to enjoy the trip in the long-run, once you realize you don't know where you're going. So let's think a bit before making this hack.

Note: There a few good words of advice like this on this old JHack tutorial. Though JHack is outdated, many of them (especially Rule 3) still ring true.

EarthBound is an RPG, so it would make sense if you made an NPC say "Hello World" instead of just printing it onscreen. So we'll need to make a character say this at some point in the game. That's actually pretty easy, though...you just need to substitute some dialog at one point. And it's boring besides. Maybe the character could be in a place where he's not supposed to be? Say (spoiler alert!) Robot Ness in Ness' house at the beginning of the game? Let's work with that.

Alright, so we need:

  • To decompile the ROM
  • To make an NPC with the Robot Ness sprite, and some dialogue attached to it
  • To write that dialogue in a CCScript file
  • To add the sprite to Ness's bedroom using the map editor, EbProjEdit
  • To recompile the changes into a new ROM

Doesn't sound that hard, right? So let's hop to it!

Creating your Project

Now that you have CoilSnake, you'll need an EarthBound ROM. I can't tell you how to get one, but they're pretty easy to find. Just ask your pal Google and don't click on any questionable ads/links in the process.

  1. Open up CoilSnake and select the Decompile tab
  2. Click on the "Browse..." button next to the ROM: field
  3. Select your EarthBound ROM
  4. Now click on the "Browse" button next to the "Output Directory:" field
  5. Choose where you want to save your project (YES, this is where all the files for your project will be stored, choose a good place!)
  6. Now press the big "Decompile" button at the bottom

A video walkthrough of these steps can be found here.

What is a CoilSnake project?

Unlike some hacking tools which directly modify a ROM when you edit, CoilSnake works using a project which is stored as files on your computer. Each CoilSnake project will have its files in its own folder, and will contain the following:

  • Project.snake, which CoilSnake uses for internal purposes (you should not need to edit this)
  • .yml files which contain miscellaneous data from the game and can be edited with a text editor
  • .ccs files in the ccscript subfolder, which are an Earthbound-specific format allowing you to insert text in the game's scripting language, and can be edited with a text editor
  • .png files which contain graphics from the game and can be edited with an image editor (many are "indexed" and need to be edited with an editor that supports saving as "indexed")

By decompiling the game's resources into these files, they can be edited individually using standard, commonly-available PC programs. Additionally, since only CoilSnake accesses the game's ROM, there is no concern about having the ROM corrupted by a hacking tool and losing progress (which was common with older hacking tools).

Editing files

Most of the files in your CoilSnake project will be some sort of text file (.yml, .ccs). You'll need a text editor to edit these. While you can use Notepad, Notepad is awful, and it's worth installing a programmer-focused text editor like Notepad++. Don't use a document editor like Word; it's not designed for this and you'll have a really bad time.

Replacing a NPC

All NPCs are configured in npc_config_table.yml, and are identified by their ID number. You can't add brand-new entries to this table, though, so we'll need to modify an existing one. In the map editor (more on this later), creating "new NPCs" just makes new references to these table entries.

The reason this works even if all current NPCs are used is because you can have multiple copies of the same NPC in-game, as long as they aren't close enough to each other to be loaded at once.

Open npc_config_table.yml in your text editor, and locate the entry for NPC #744. It should appear as follows:

744:
  Direction: down
  Event Flag: 0x274
  Movement: 708
  Show Sprite: when event flag set
  Sprite: 195
  Text Pointer 1: $c7db3f
  Text Pointer 2: $0
  Type: object

Change these attributes like so:

744:
  Direction: down
  Event Flag: 0x0
  Movement: 605
  Show Sprite: always
  Sprite: 5
  Text Pointer 1: robot.hello_world
  Text Pointer 2: $0
  Type: person

A few explanations are in order:

  • The event flag is set to 0x0 because we won't need to toggle this sprite's visibility with an event flag (though we could if we wanted to).
  • Therefore, Show Sprite is set to "always" instead of "when event flag set" or "when event flag unset"
  • The movement code is set to 605, which will make the robot stand still.
  • Sprite is set to 5 because the sprite we want (Robot Ness) is 005.png in the SpriteGroups folder.
  • Type is set to "person" instead of "object" because "person" NPCs can be Talked to, while "object" NPCs have to be Checked.
  • Finally, Text Pointer 1 specifies that the text block to run is the hello_world part of a new CCScript file we're going to create, robot.ccs.

After making the edits, ensure you save the file in your text editor - otherwise, CoilSnake and the EB Project Editor will not see your changes since they aren't saved into the project folder.

Now that we have our NPC ready, let's place it on the map!

Editing the Map

You'll need the EB Project Editor for this step, although for the purpose of this first hack, you won't need to be fully knowledgeable with it yet (it's covered in more detail later in this guide).

You can open up the EB Project Editor through CoilSnake's Tools menu. This tool requires a Java Runtime Environment, which is not bundled with CoilSnake and will need to be installed separately.

When you first open it, you should see a tiny, unassuming initial screen, something like the one pictured to the right. You can't really do anything with it yet, so click on the folder icon to open your project's Project.snake file. It might take a while to load everything, but you'll know when it's ready when all three buttons light up. We won't need to modify tilesets or door mechanisms, so open up the Map Editor.

Since we want to edit Ness' bedroom, scroll over the map until you find it – it's somewhere around the top-right corner.

Once you find it, bring up the Sprite Edit mode – do so by choosing it from the Mode menu at the top, or by hitting F2 if you're fond of keyboard shortcuts.

Then, right-click someplace within Ness' bedroom, and select "New NPC". Now right-click on it and choose "Switch NPC (0)". In the dialog box that pops up, type "744" - the ID number from npc_config_table.yml.

Ness' bedroom should now look something like this:

Scripting Some Dialogue

CCScript files must all be placed in the ccscript directory of your CoilSnake project. Go ahead and create an empty robot.ccs file with a text editor of your choice, and write this text into it: In your text editor, create a new file and enter this text:

hello_world:
    "@Hello World!" end

Then, save this in the ccscript directory with the name robot.ccs. If you are on Windows, you may need to change the file type to All files (*.*) instead of *.txt, as otherwise your text editor may save it as robot.ccs.txt.

This short script will make our NPC say "Hello World!" to Ness, then stop the conversation. Neat, isn't it?

Compiling and Running

Looks like we are good to go. Go into CoilSnake once more. Before getting started, you'll need to copy your EarthBound ROM:

  1. Make a copy of your Base ROM (so you don't lose the original!) and rename it
  2. Click on the Compile tab in CoilSnake
  3. Choose your Base ROM
  4. Choose the project folder
  5. Choose a name for the output ROM - something like Test.smc will do
  6. Click on the big "Compile" button
  7. CoilSnake will ask you if you want to expand your ROM. Say yes and it will make sure there's enough free space for everything to be crammed back in there.
  8. Now sit back and let the compilation process complete

Watch a video of these steps: http://youtu.be/cjVKUQSSkhQ

Now, open up the output ROM in your favorite emulator (or simply click the Run button), and try out your work!

And there you have it. Your first hack. Isn't he cute?

Of course, this is just the beginning, and there's a lot to learn yet...

Troubleshooting

If you are getting an error like Unknown pointer label[robot.hello_world], please check that:

  • You did not make a typo in the contents of robot.ccs.
  • The file is actually named robot.ccs and not, for example, robot.css.
  • The file has the proper extension, and is not named something like robot.ccs.txt. Windows Explorer hides extensions by default, so it may not be showing you the .txt at the end of the filename. You should check that Windows is set to not hide file extensions. There are many tutorials online that can tell you how to do this, such as this one.

Conclusion

You got to build your first hack for EarthBound and you got familiar with some of the tools you'll be using, as well as getting a glimpse at some of the techniques you'll be using time and again. From now on, you can read this manual in almost any order, since most chapters aren't dependent on others. You'll start learning all sorts of techniques one by one, until you're ready to make the Next Big Hack.

Is your heart beating incredibly fast?

Clone this wiki locally