1
0
Fork 0
mirror of https://github.com/zeldaret/oot.git synced 2025-01-22 00:26:59 +00:00
oot/docs/tutorial/pre-decomp.md
EllipticEllipsis effd4256c9
Tutorial docs (#715)
* Move tutorial into docs folder

* Merge remote-tracking branch 'upstream/master' into tutorial_docs

* Object decomp added

* contents and intro updates

* mention object decomp in beginning

* Addressed Fig's review

* Update EnSkb to jointTable and morphTable

* minor table tweak

* typo

* Alter to say ZAPD makes the object output folder

* Apply suggestions from code review

Co-authored-by: Anghelo Carvajal <anghelo.carvajal.14@sansano.usm.cl>

* More review changes

* Apply suggestions from code review

Co-authored-by: Roman971 <32455037+Roman971@users.noreply.github.com>

Co-authored-by: Anghelo Carvajal <anghelo.carvajal.14@sansano.usm.cl>
Co-authored-by: Roman971 <32455037+Roman971@users.noreply.github.com>
2021-03-24 01:15:35 +01:00

2.4 KiB

Pre-decompilation

It is very important to get everything set up properly before you start trying to decompile anything. As usual, if you need help at any stage of the process, ask in the Discord and we'll do our best to help.

Setting up the repository

This is covered on the main page of the repository.

Git and GitHub workflow

First, make a GitHub fork of the repository, then clone it into a git-enabled local folder.

Once you have decided on an actor, you should make a new git branch to work on: your master branch is meant to stay level with the main repository. Name it something sensible: my EnFirefly branch is called "en_firefly", for example, but you may prefer to use a more descriptive name: "Dark_Link" is rather more suggestive than "en_torch2", for example. You work on the branch, commit changes, and periodically push them to GitHub, if only for backup purposes.

Once you have finished an actor, you submit a pull request for other people to check your work complies with the project's conventions, and once it is deemed satisfactory, it will be merged in to the main repository.

But we are getting ahead of ourselves:

Choosing a first actor

Since actors cover so many different categories of stuff in the game, they come in a wide variety of shapes, sizes and difficulties. The following is a list of things to bear in mind:

  • Bosses are by far the largest, and all are already taken, so you can safely ignore them. Likewise ovl_Fishing, the largest actor in the game.
  • Enemies are often quite complicated due to the many different interactions they have with Link, and sometimes one another.
  • NPCs vary hugely. Some of the smaller ones are suitable to be first actors, but many are not.
  • Cutscene objects tend to have very complicated functions, and are best left until later.
  • The best starter actors tend to be dungeon or scene objects: statues, platforms, decorations, gates, etc., although we are naturally running a bit short on these now.

The general rule of thumb is to pick something with few, simple interactions with its environment. (For example, my first actor was BgIceTurara: icicles, which can do about 3 different things: break, fall, and grow.) This hopefully means that the functions are mostly small and simple. You are also probably better off if Draw and Init are small functions, although difficulty is sometimes not correlated to size.

If in doubt, ask someone to have a quick look through the code to see if it's suitable.