DizzyEggg
|
f35c0abe80
|
merge with battle tent update
|
2018-07-01 12:16:52 +02:00 |
|
DizzyEggg
|
15fe5a031b
|
Merge branch 'master' into decompile_battle_tent
|
2018-06-30 14:43:41 +02:00 |
|
Marcus Huderle
|
ed8b006e67
|
Rename map-layout-related things
|
2018-06-20 19:54:21 -05:00 |
|
DizzyEggg
|
ab36efdaf4
|
document bounce effect
|
2018-06-20 23:07:51 +02:00 |
|
DizzyEggg
|
0fe3e612eb
|
battle tent start and create frontier struct in saveblock
|
2018-06-17 12:30:09 +02:00 |
|
DizzyEggg
|
3bcd30969a
|
cut field effect is decompiled and documented
|
2018-06-16 14:04:29 +02:00 |
|
Marcus Huderle
|
aa9a45c16f
|
Rebrand 'map object' and 'field object' to 'event object'
|
2018-06-11 19:11:48 -05:00 |
|
Diegoisawesome
|
0b09575fd4
|
Merge pull request #249 from golemgalvanize/decompile_pokedex
Decompile pokedex
|
2018-06-01 00:02:46 -07:00 |
|
DizzyEggg
|
9e7965fab0
|
document record mixing
|
2018-05-26 00:25:36 +02:00 |
|
DizzyEggg
|
b051cbaaab
|
more record mixing decomp
|
2018-05-25 21:00:41 +02:00 |
|
DizzyEggg
|
03b593d3c3
|
try my luck with record mixing
|
2018-05-22 21:54:57 +02:00 |
|
DizzyEggg
|
1a8d5132d6
|
fix record mixing for real
|
2018-05-20 10:51:09 +02:00 |
|
DizzyEggg
|
e44f35c7b7
|
fix record mixing merge conflicts
|
2018-05-19 12:32:44 +02:00 |
|
Diegoisawesome
|
23b050a99e
|
Update naked attribute and ASM_DIRECT to NAKED macro
|
2018-05-11 17:24:32 -05:00 |
|
golem galvanize
|
13efa1ef62
|
fixing conflicts
|
2018-05-10 03:34:36 -04:00 |
|
golem galvanize
|
d31600e70e
|
finish decompiling pokedex
|
2018-05-10 03:30:42 -04:00 |
|
PikalaxALT
|
fd1d75ce37
|
Merge branch 'master' into mauville_old_man
|
2018-05-07 18:18:00 -04:00 |
|
PikalaxALT
|
61cc1d5574
|
Rename symbols using Ruby as a reference
|
2018-05-07 18:11:20 -04:00 |
|
PikalaxALT
|
58200616d5
|
Merge branch 'master' into trader
|
2018-05-04 17:45:50 -04:00 |
|
PikalaxALT
|
c6115a2fec
|
through sub_8120C0C
|
2018-05-03 17:03:52 -04:00 |
|
Marcus Huderle
|
cdb5e9e314
|
Merge pull request #242 from DizzyEggg/decompile_battle_records
Decompile battle records
|
2018-05-03 08:42:44 -07:00 |
|
PikalaxALT
|
21c3e7e8e5
|
through SetMauvilleOldMan
|
2018-05-02 11:31:58 -04:00 |
|
PikalaxALT
|
4acbcf5759
|
Port trader from Ruby
|
2018-05-01 15:19:24 -04:00 |
|
DizzyEggg
|
95cf853762
|
battle records more decomp and subtle name changes
|
2018-05-01 14:01:54 +02:00 |
|
DizzyEggg
|
25c669e36b
|
decompile item
|
2018-04-29 13:36:26 +02:00 |
|
golem galvanize
|
069a7e71fc
|
Merge branch 'master' of https://github.com/pret/pokeemerald into decompile_pokedex
|
2018-03-30 16:49:08 -04:00 |
|
Diegoisawesome
|
ebd88b3606
|
Merge branch 'master' of https://github.com/pret/pokeemerald into intro
|
2018-02-17 04:03:59 -06:00 |
|
Diegoisawesome
|
0a206ee52c
|
Finish decompiling intro
|
2018-02-15 22:30:39 -06:00 |
|
golem galvanize
|
6cbea9af6d
|
Merge branch 'master' of https://github.com/pret/pokeemerald into decompile_pokedex
|
2018-02-15 18:20:53 -05:00 |
|
golem galvanize
|
4a71a61e58
|
start decompiling
|
2018-02-15 18:20:19 -05:00 |
|
DizzyEggg
|
94b47c0686
|
decompile overworld
|
2018-02-14 00:58:22 +01:00 |
|
DizzyEggg
|
f22be4d010
|
more overworld work
|
2018-02-12 18:26:26 +01:00 |
|
DizzyEggg
|
382442c4c8
|
start decompiling overworld.s
|
2018-02-12 15:01:43 +01:00 |
|
PikalaxALT
|
590c4b500b
|
Merge branch 'master' into record_mixing
|
2018-02-11 20:12:40 -05:00 |
|
PikalaxALT
|
ea347199a2
|
Merge branch 'master' into link
|
2018-02-11 19:22:06 -05:00 |
|
Diegoisawesome
|
772fd47564
|
Merge branch 'master' of https://github.com/pret/pokeemerald into menu
|
2018-02-07 18:06:59 -06:00 |
|
DizzyEggg
|
96ab6f8353
|
match secret base func and fix struct
|
2018-02-07 13:49:33 +01:00 |
|
PikalaxALT
|
d52f52fa73
|
Merge branch 'master' into link
|
2018-02-03 09:42:19 -05:00 |
|
ProjectRevoTPP
|
78bd2b0849
|
move save rodata to source and use saveblock chunk macros
|
2018-01-31 15:26:57 -05:00 |
|
Diegoisawesome
|
3793152bc3
|
More work on menu
|
2018-01-29 17:26:36 -06:00 |
|
PikalaxALT
|
d4e8c20f84
|
Merge branch 'master' into link
|
2018-01-21 23:20:13 -05:00 |
|
PikalaxALT
|
d35cf06854
|
nonmatching sub_801120C
|
2018-01-21 18:25:23 -05:00 |
|
scnorton
|
89bbecd34b
|
Include <string.h> in global.h
|
2018-01-21 14:40:19 -05:00 |
|
scnorton
|
c6ff1a6ce3
|
Merge branch 'master' into link
|
2018-01-18 12:53:31 -05:00 |
|
ProjectRevoTPP
|
10ddfac7ab
|
consistency
|
2018-01-06 22:00:08 -05:00 |
|
ProjectRevoTPP
|
7be61cfb1a
|
add assert support to pokeemerald.
|
2018-01-06 21:12:42 -05:00 |
|
camthesaxman
|
601ec28721
|
remove explicit memcpy and add HEAP_SIZE constant
|
2018-01-06 00:35:48 -06:00 |
|
DizzyEggg
|
cb229f56e8
|
fix pokeblock conflicts
|
2017-12-18 16:58:14 +01:00 |
|
Diegoisawesome
|
6a674e1e83
|
Merge remote-tracking branch 'Egg/decompile_mail_data'
|
2017-12-17 22:51:40 -06:00 |
|
DizzyEggg
|
46fa2557d7
|
merge mail with master, fix conflicts
|
2017-12-17 20:22:56 +01:00 |
|
PikalaxALT
|
190a2cba61
|
Merge branch 'master' into link
|
2017-12-16 11:27:10 -05:00 |
|
DizzyEggg
|
f4ab21ee67
|
Merge branch 'master' into decompile_use_pokeblock
|
2017-12-16 11:42:59 +01:00 |
|
DizzyEggg
|
44abbae60b
|
nerge with master, fix conflicts
|
2017-12-16 01:08:55 +01:00 |
|
DizzyEggg
|
4351676749
|
decompile more of pokeblock.s
|
2017-12-16 00:08:23 +01:00 |
|
Diegoisawesome
|
e3c366df64
|
Merge remote-tracking branch 'pret/master'
|
2017-12-15 00:08:48 -06:00 |
|
camthesaxman
|
caa13f8777
|
convert some constants to C headers
|
2017-12-05 11:55:48 -06:00 |
|
PikalaxALT
|
0b58905eea
|
sub_800E3A8
|
2017-12-04 19:10:37 -05:00 |
|
DizzyEggg
|
4faa442d5a
|
decompile and label mail
|
2017-12-03 19:19:11 +01:00 |
|
DizzyEggg
|
e8ecb01ab2
|
more work on battle setup
|
2017-11-29 19:54:15 +01:00 |
|
Diegoisawesome
|
8e9428c482
|
Add languages to enum
|
2017-11-29 00:53:18 -06:00 |
|
PikalaxALT
|
cbd2718b5e
|
Merge branch 'master' into link
|
2017-11-27 20:05:51 -05:00 |
|
PikalaxALT
|
a875d665b8
|
Merge branch 'master' into easy_chat
|
2017-11-25 10:56:55 -05:00 |
|
PikalaxALT
|
d6d315d817
|
Merge branch 'master' into link
|
2017-11-19 00:07:56 -05:00 |
|
DizzyEggg
|
3de416662b
|
wild encounter, fix merge conflicts
|
2017-11-18 21:45:52 +01:00 |
|
Diegoisawesome
|
5dc8beb034
|
Merge pull request #112 from DizzyEggg/decompile_recorded_battle
Decompile recorded battle
|
2017-11-18 13:29:27 -06:00 |
|
DizzyEggg
|
6b075ae0ff
|
wild encounter file is decompiled
|
2017-11-17 22:28:55 +01:00 |
|
DizzyEggg
|
a2a17bba92
|
more work on wild encounter
|
2017-11-17 17:50:07 +01:00 |
|
DizzyEggg
|
b37d8c0821
|
start decompiling wild encounter
|
2017-11-16 20:38:10 +01:00 |
|
DizzyEggg
|
a972de7bca
|
start working on daycare
|
2017-11-14 20:23:25 +01:00 |
|
DizzyEggg
|
209b6eb467
|
more of recorded battle done
|
2017-11-13 18:07:23 +01:00 |
|
DizzyEggg
|
c4674735d2
|
start working on recorded battle
|
2017-11-12 22:59:36 +01:00 |
|
PikalaxALT
|
d76901ff64
|
through sub_800A0AC
|
2017-11-10 08:37:50 -05:00 |
|
PikalaxALT
|
1c3e7f169f
|
sub_80E6E24
|
2017-11-03 22:26:12 -04:00 |
|
PikalaxALT
|
f8486b31c5
|
sub_80E6CA0
|
2017-11-03 21:56:18 -04:00 |
|
PikalaxALT
|
ca2bc94c2b
|
through sub_80E6BF8
|
2017-11-03 20:59:29 -04:00 |
|
PikalaxALT
|
01d6114da2
|
easy_chat_input_maybe
|
2017-11-02 19:26:14 -04:00 |
|
PikalaxALT
|
ed7ded0748
|
Merge branch 'master' into easy_chat
|
2017-11-02 18:34:41 -04:00 |
|
PikalaxALT
|
17fd3bccf7
|
Merge branch 'master' into secret_base
|
2017-11-01 23:39:54 -04:00 |
|
PikalaxALT
|
975e28c01e
|
Merge branch 'master' into easy_chat
|
2017-10-28 20:03:24 -04:00 |
|
PikalaxALT
|
84a9441267
|
MWF: sub_80E9914
|
2017-10-25 19:54:24 -04:00 |
|
PikalaxALT
|
eb2c2f0a3f
|
through sub_80E8BC8
|
2017-10-23 19:21:08 -04:00 |
|
DizzyEggg
|
356eb34e32
|
undo revert
|
2017-10-23 14:40:22 +02:00 |
|
DizzyEggg
|
5b70307962
|
revert merge coz its bugged
|
2017-10-23 13:36:55 +02:00 |
|
DizzyEggg
|
7d1373e3fa
|
Merge branch 'master' into decompile_battle_controllers
|
2017-10-23 13:33:32 +02:00 |
|
PikalaxALT
|
1ef4dbe691
|
Fix global declarations of libc fns
|
2017-10-22 20:43:03 -04:00 |
|
DizzyEggg
|
813b1bfd4a
|
label and do more work at player controller
|
2017-10-22 01:04:02 +02:00 |
|
DizzyEggg
|
cda5c5f925
|
start working on walda phrase
|
2017-10-20 18:52:01 +02:00 |
|
PikalaxALT
|
52db3ad5aa
|
Decompile TV (#80)
* ClearTVShowData
* special_0x44
* DoTVShow (nonmatching because align)
* DoTVShowBravoTrainerPokemonProfile
* Update field names
* DoTVShowBravoTrainerBattleTower
* Renaming of struct fields
* sub_80EBFF4 and UpdateTVScreensOnMap
* SetTVMetatilesOnMap
* Power buttons for the TV screens on the map
* special_0x45
* sub_80EC18C
* special_0x4a
* ResetGabbyAndTy
* GabbyAndTyBeforeInterview
* GabbyAndTyAfterInterview
* Through IsTVShowInSearchOfTrainersAiring
* GabbyAndTyGetLastQuote
* GabbyAndTyGetLastBattleTrivia
* GabbyAndTySetScriptVarsToFieldObjectLocalIds
* InterviewAfter; use TVShow as a precursor for making the individual show structs anonymous
* Make TV structs anonymous within the union
* Move the TV union to its own subheader
* Move TV show enums to the global.tv.h subheader
* Funcion renaming
* Apply static attributes where able
* PutPokemonTodayCaughtOnAir
* sub_80EC8A4
* PutPokemonTodayFailedOnTheAir
* sub_80EC9E8, sub_80ECA10
* sub_80ECA38
* sub_80ECB00
* Put3CheersForPokeblocksOnTheAir
* PutFanClubSpecialOnTheAir
* ContestLiveUpdates_BeforeInterview
* Other before-interview Contest Live Updates functions
* ContestLiveUpdates_BeforeInterview_5
* InterviewAfter_BravoTrainerPokemonProfile
* BravoTrainerPokemonProfile_BeforeInterview1
* BravoTrainerPokemonProfile_BeforeInterview2
* Disassemble TV data
* Decompile TV data
* InterviewAfter_BravoTrainerBattleTowerProfile
* SaveRecordedItemPurchasesForTVShow
* PutNameRaterShowOnTheAir
* StartMassOutbreak
* PutLilycoveContestLadyShowOnTheAir
* InterviewAfter_FanClubLetter
* Rip TV strings
* InterviewAfter_RecentHappenings
* InterviewAfter_PkmnFanClubOpinions
* sub_80ED718
* EndMassOutbreak
* sub_80ED888
* sub_80ED8B4
* UpdateMassOutbreakTimeLeft
* sub_80ED950
* PutFishingAdviceShowOnTheAir
* through sub_80EDA80
* ewram and common syms are now fetched from the object files
* BSS symbols are taken from the tv.o file
* through sub_80EDC60
* sub_80EDCE8
* sub_80EDD78
* through sub_80EDE84
* nomatching sub_80EDE98
* sub_80EDFB4
* sub_80EE104
* sub_80EE104
* sub_80EE184
* sub_80EE2CC
* sub_80EE35C
* sub_80EE44C
* sub_80EE4DC
* sub_80EE5A4
* sub_80EE69C
* sub_80EE72C
* sub_80EE7C0
* sub_80EE818
* sub_80EE8C8
* sub_80EEA70
* sub_80EEB98
* sub_80EEBF4
* through sub_80EED60
* Functions relating to Pokemon News
* sub_80EEF6C
* GetPriceReduction
* IsPriceDiscounted
* sub_80EF120
* through sub_80EF370
* sub_80EF40C
* HasMixableShowAlreadyBeenSpawnedWithPlayerID
* TV_SortPurchasesByQuantity
* FindActiveBroadcastByShowType_SetScriptResult
* InterviewBefore
* through sub_80EF88C
* through sub_80EF93C
* through sub_80EFA24
* through TV_BernoulliTrial
* sub_80EFB58
* sub_80EFBA4
* sub_80EFBDC
* through sub_80EFD98
* ChangePokemonNickname
* ChangeBoxPokemonNickname
* sub_80EFF9C
* through player_id_to_dword
* CheckForBigMovieOrEmergencyNewsOnTV
* GetMomOrDadStringForTVMessage
* sub_80F01E8
* sub_80F0358
* sub_80F049C
* TV record mixing functions
* sub_80F06D0
* sub_80F0708 nonmatching
* through sub_80F0B24
* sub_80F0B64
* through sub_80F0C04
* sub_80F0C7C
* sub_80F0D60
* sub_80F0E58
* sub_80F0E84
* through sub_80F0F24
* sub_80F0F64
* sub_80F1208
* sub_80F1254
* sub_80F1290
* sub_80F12A4
* sub_80F14F8
* DoTVShowTodaysSmartShopper
* DoTVShowTheNameRaterShow
* DoTVShowPokemonTodaySuccessfulCapture
* DoTVShowPokemonTodayFailedCapture
* DoTVShowPokemonFanClubLetter
* DoTVShowRecentHappenings
* DoTVShowPokemonFanClubOpinions
* DoTVShowPokemonNewsMassOutbreak
* DoTVShowPokemonContestLiveUpdates
* DoTVShowPokemonBattleUpdate
* DoTVShow3CheersForPokeblocks
* DoTVShowInSearchOfTrainers
* Label GabbyAndTyData fields; remove ddump comments from data/text/tv.inc
* DoTVShowPokemonAngler
* DoTVShowTheWorldOfMasters; update RAM symbols and field names
* Decorate static functions
* DoTVShowTodaysRivalTrainer; region map enums
* TVDewfordTrendWatcherNetworkTextGroup
* DoTVShowHoennTreasureInvestigators
* DoTVShowFindThatGamer
* DoTVShowBreakingNewsTV
* DoTVShowSecretBaseVisit
* DoTVShowPokemonLotterWinnerFlashReport
* DoTVShowThePokemonBattleSeminar
* DoTVShowTrainerFanClubSpecial, DoTVShowTrainerFanClub
* DoTVShowSpotTheCuties
* DoTVShowPokemonNewsBattleFrontier
* DoTVShowWhatsNo1InHoennToday
* Helpers for DoTVShowSecretBaseSecrets
* DoTVShowSecretBaseSecrets
* DoTVShowSafariFanClub
* Finish decompilation of tv.s
* Some renaming
* Rename text group pointers
* revoke statis; pokenews enums
* Labels are number one
* Label all TV struct fields
* Make data/text/tv.inc more readable
* Split data/text/tv.inc
* Rename pokenews text pointers
* Frontier Symbol constants; indicate static rodata objects with 's' prefix
* Fix leading spaces/tabs
F*** CLion sometimes
* Fix inconsequential warning
|
2017-10-13 10:09:36 -05:00 |
|
DizzyEggg
|
7552caaadc
|
placeholders for battle strings are done
|
2017-10-07 19:59:41 +02:00 |
|
DizzyEggg
|
729f4e10ed
|
start decompiling battle2
|
2017-10-01 01:12:42 +02:00 |
|
PikalaxALT
|
0e75d957d6
|
Update offset comments in save block 1
|
2017-09-25 19:57:44 -04:00 |
|
DizzyEggg
|
9ee9a20152
|
fix merge conflicts
|
2017-09-21 10:50:15 +02:00 |
|
PikalaxALT
|
7c8cbc6b88
|
SetLilycoveContestLady
|
2017-09-20 16:49:22 -04:00 |
|
PikalaxALT
|
d22a9acc63
|
through sub_818E490
|
2017-09-20 16:12:18 -04:00 |
|
scnorton
|
8a31e58689
|
sub_818E298
|
2017-09-20 11:30:09 -04:00 |
|
scnorton
|
0b81c2920a
|
sub_818E1F4
|
2017-09-20 10:45:00 -04:00 |
|
DizzyEggg
|
3919b7130b
|
Fix merge conflicts
|
2017-09-20 13:12:43 +02:00 |
|
PikalaxALT
|
28d0fa33fe
|
SetLilicoveQuizLady
|
2017-09-19 22:35:40 -04:00 |
|
PikalaxALT
|
73ee165ef6
|
sub_818DF00
|
2017-09-19 22:25:31 -04:00 |
|
PikalaxALT
|
316f9f4d83
|
through sub_818DD14
|
2017-09-19 21:28:01 -04:00 |
|
PikalaxALT
|
f43de6e582
|
Merge branch 'master' into lilycove_lady
|
2017-09-19 21:18:34 -04:00 |
|
scnorton
|
3b3423d1a7
|
sub_818DC60
|
2017-09-19 17:07:36 -04:00 |
|
scnorton
|
4e8a2c6934
|
SetLilycoveFavourLady
|
2017-09-19 16:55:53 -04:00 |
|
scnorton
|
b26eb6713b
|
sub_818DB20
|
2017-09-19 16:32:33 -04:00 |
|
scnorton
|
e7e1938094
|
Start decompilation of lilycove_lady
|
2017-09-19 16:17:23 -04:00 |
|
DizzyEggg
|
c253bf5e75
|
add important headers, const ptrs and egg hatch start
|
2017-09-18 18:36:05 +02:00 |
|
PikalaxALT
|
559833ccf6
|
Merge branch 'master' into field_map_obj
|
2017-09-16 15:41:54 -04:00 |
|
Cameron Hall
|
19d2d73c70
|
Merge pull request #28 from DizzyEggg/decomp_pokemon
decompile pokemon1/2/3
|
2017-09-16 14:14:50 -05:00 |
|
PikalaxALT
|
64ffa8f963
|
Merge branch 'master' into field_map_obj
|
2017-09-13 19:29:19 -04:00 |
|
DizzyEggg
|
b1e90c1d50
|
review berry cleanings
|
2017-09-13 19:30:05 +02:00 |
|
PikalaxALT
|
e26501f130
|
Support functions for GoRandomDirections
|
2017-09-13 10:59:25 -04:00 |
|
DizzyEggg
|
a08cd8e5a7
|
define number of map objects
|
2017-09-13 12:17:48 +02:00 |
|
DizzyEggg
|
5f4c5e280c
|
berry.s decompiled
|
2017-09-13 11:16:26 +02:00 |
|
DizzyEggg
|
8731a8caa5
|
one more function in pokemon1
|
2017-09-12 15:36:04 +02:00 |
|
DizzyEggg
|
44dbf4dea0
|
port pokemon size record
|
2017-09-08 22:23:14 +02:00 |
|
scnorton
|
db2b371e70
|
gpu_pal_allocator_reset__manage_upper_four
|
2017-09-08 15:11:29 -04:00 |
|
DizzyEggg
|
ba1c066d57
|
new game fully decompiled
|
2017-09-08 16:46:37 +02:00 |
|
DizzyEggg
|
4a1b2967ca
|
make lots of define files
|
2017-09-07 19:45:32 +02:00 |
|
scnorton
|
9498dfa71c
|
InitFieldObjectStateFromTemplate (nonmatching, same as ruby)
|
2017-09-06 14:25:17 -04:00 |
|
PikalaxALT
|
83dbdc0318
|
npc_clear_ids_and_state
|
2017-09-06 08:46:47 -04:00 |
|
DizzyEggg
|
92892d140a
|
begin load_save.c
|
2017-09-04 18:26:39 +02:00 |
|
DizzyEggg
|
5afd2d5bfb
|
begin new save.c, label lots of things
|
2017-09-03 22:50:17 +02:00 |
|
DizzyEggg
|
50530b4666
|
begin decompiling item.s
|
2017-09-03 00:47:51 +02:00 |
|
DizzyEggg
|
048700fe57
|
decompile rtc
|
2017-09-02 23:28:44 +02:00 |
|
DizzyEggg
|
b5fea95a46
|
finish event data
|
2017-09-02 22:31:37 +02:00 |
|
DizzyEggg
|
a4cc67008e
|
begin event data
|
2017-09-02 21:43:53 +02:00 |
|
DizzyEggg
|
449d546556
|
split some battle files
|
2017-09-01 23:40:13 +02:00 |
|
Diegoisawesome
|
b95747dc69
|
Begin disassembling window.s
|
2017-03-29 19:02:15 -05:00 |
|
YamaArashi
|
53935efc64
|
mostly finish string_util.c
|
2017-01-14 15:17:51 -08:00 |
|
YamaArashi
|
1268134668
|
decompile string_util
|
2017-01-14 14:20:49 -08:00 |
|
Diegoisawesome
|
4df1937738
|
Ported task.c and others from pokeruby
|
2016-10-31 09:43:17 -05:00 |
|
YamaArashi
|
bc10815b94
|
reorganize headers and add CpuFill macros
|
2016-01-08 12:49:23 -08:00 |
|
YamaArashi
|
b4781cdf03
|
gpu_regs.c
|
2016-01-08 01:08:16 -08:00 |
|
YamaArashi
|
4e95a13295
|
update asm
|
2016-01-07 23:27:40 -08:00 |
|
YamaArashi
|
d35478a398
|
move C files
|
2016-01-06 18:57:32 -08:00 |
|