More actions
No edit summary |
No edit summary |
||
Line 8: | Line 8: | ||
|version=1.1 | |version=1.1 | ||
|license=Mixed | |license=Mixed | ||
|download=https://dlhb.gamebrew.org/ | |download=https://dlhb.gamebrew.org/3dshomebrews/sharkgate2ntr.7z | ||
|website=https://gbatemp.net/threads/release-gateshark2ntr.436504 | |website=https://gbatemp.net/threads/release-gateshark2ntr.436504 | ||
}} | }} | ||
{{Obsolete}} | |||
Gateshark2NTR is a program that will allow you to convert a Gateshark's cheats text file in a plugin usable with NTR. | |||
With it you can simply load your text files with cheats. | '''Note:''' This is no longer supported, consider using [[CTRPluginFramework 3DS]] with Action Replay support instead of using a converter. With it you can simply load your text files with cheats. | ||
==User guide== | |||
Requirements: | |||
# [https://sourceforge.net/projects/devkitpro/ DevKitPRO]. Install this and be sure to add "c:\devkitPro\msys\bin" to the PATH Environment Variable | |||
* You also need to have the [https://www.microsoft.com/en-US/download/details.aspx?id=48145 VCRedist 2015] installed. | |||
There are 3 ways to pass the file: | |||
* Drag & Drop the file on the soft's icon. | |||
* Launch the soft and a window will appear to select the file. | |||
* Pass the file as an argument through a shell. | |||
This soft support all the codes used by gateway and even more. | This soft support all the codes used by gateway and even more. | ||
623D6B28 10000000 | ===Complete STD AR/Gateway codes=== | ||
{| role="presentation" class="wikitable mw-collapsible mw-collapsed" style="width:800px;" | |||
!colspan="2"|0 Type | |||
7 Type | |- | ||
Format | |style="width: 10%;"|Format | ||
Description | |0XXXXXXX YYYYYYYY | ||
Simple | |- | ||
Example | |Description||32bit write of YYYYYYYY to 0XXXXXXX. | ||
|- | |||
723D6B28 00005400 | |Simple||Makes the value at address 0XXXXXXX equal the value YYYYYYYY. | ||
|- | |||
|Example||023D6B28 3B9ACA00 | |||
8 Type | |- | ||
Format | !colspan="2"|1 Type | ||
Description | |- | ||
Simple | |Format||1XXXXXXX 0000YYYY | ||
Example | |- | ||
|Description||16bit write of YYYY to 0XXXXXXX. | |||
823D6B28 00005400 | |- | ||
|Simple||Makes the value at address 0XXXXXXX equal the value YYYY. | |||
|- | |||
9 Type | |Example||023D6B28 00002710 | ||
Format | |- | ||
Description | !colspan="2"|2 Type | ||
Simple | |- | ||
Example | |Format||2XXXXXXX 000000YY | ||
|- | |||
923D6B28 00005400 | |Description||8bit write of YY to 0XXXXXXX. | ||
|- | |||
|Simple||Makes the value at address 0XXXXXXX equal the value YY. | |||
A Type | |- | ||
Format | |Example||023D6B28 00000032 | ||
Description | |- | ||
Simple | !colspan="2"|3 Type | ||
Example | |- | ||
|Format||3XXXXXXXX YYYYYYYY | |||
A23D6B28 00005400 | |- | ||
|Description||32bit if less than. | |||
|- | |||
B Type | |Simple||If the value at address 0XXXXXXX is less than the value YYYYYYYY. | ||
Format | |- | ||
Description | |Example||323D6B28 10000000 | ||
Simple | |- | ||
Example | !colspan="2"|4 Type | ||
|- | |||
B23D6B28 00000000 | |Format||4XXXXXXXX YYYYYYYY | ||
00002000 0001869F | |- | ||
|Description||32bit if greater than. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is greater than the value YYYYYYYY. | |||
|- | |||
|Example||423D6B28 10000000 | |||
|- | |||
!colspan="2"|5 Type | |||
|- | |||
|Format||5XXXXXXXX YYYYYYYY | |||
|- | |||
|Description||32bit if equal to. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is equal to the value YYYYYYYY. | |||
|- | |||
|Example||523D6B28 10000000 | |||
|- | |||
!colspan="2"|6 Type | |||
|- | |||
|Format||3XXXXXXXX YYYYYYYY | |||
|- | |||
|Description||32bit if not equal to. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is not equal to the value YYYYYYYY. | |||
|- | |||
|Example||623D6B28 10000000 | |||
|- | |||
!colspan="2"|7 Type | |||
|- | |||
|Format||7XXXXXXXX 0000YYYY | |||
|- | |||
|Description||16bit if less than. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is less than the value YYYY. | |||
|- | |||
|Example||723D6B28 00005400 | |||
|- | |||
!colspan="2"|8 Type | |||
|- | |||
|Format||8XXXXXXXX 0000YYYY | |||
|- | |||
|Description||16bit if greater than. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is greater than the value YYYY. | |||
|- | |||
|Example||823D6B28 00005400 | |||
|- | |||
!colspan="2"|9 Type | |||
|- | |||
|Format||9XXXXXXXX 0000YYYY | |||
|- | |||
|Description||16bit if equal to. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is equal to the value YYYY. | |||
|- | |||
|Example||923D6B28 00005400 | |||
|- | |||
!colspan="2"|A Type | |||
|- | |||
|Format||AXXXXXXXX 0000YYYY | |||
|- | |||
|Description||16bit if not equal to. | |||
|- | |||
|Simple||If the value at address 0XXXXXXX is not equal to the value YYYY. | |||
|- | |||
|Example||A23D6B28 00005400 | |||
|- | |||
!colspan="2"|B Type | |||
|- | |||
|Format||BXXXXXXX 00000000 | |||
|- | |||
|Description||Loads offset register. | |||
|- | |||
|Simple||Used for pointers, the address at 0XXXXXXX is the offset for all of the following lines. | |||
|- | |||
|Example|| | |||
B23D6B28 00000000 <br> | |||
00002000 0001869F <br> | |||
D2000000 00000000 | D2000000 00000000 | ||
|- | |||
!colspan="2"|C Type | |||
C Type | |- | ||
Format | |Format||C0000000 ZZZZZZZZ | ||
Description | |- | ||
Simple | |Description||Repeat following lines at specified offset. | ||
Note | |- | ||
Example | |Simple||Used to write a value to an address, and then continues to write that value Z number of times to all addresses at an offset determined by the (D6, D7, D8, or DC) type following it. | ||
|- | |||
C0000000 00000005 | |Note||Used with the D6, D7, D8, and DC types. C types can not be nested. | ||
023D6B28 0009896C | |- | ||
DC000000 00000010 | |Example|| | ||
C0000000 00000005 <br> | |||
023D6B28 0009896C <br> | |||
DC000000 00000010 <br> | |||
D2000000 00000000 | D2000000 00000000 | ||
|- | |||
!colspan="2"|D0 Type | |||
D0 Type | |- | ||
Format | |Format||D0000000 00000000 | ||
Description | |- | ||
Simple | |Description||Ends most recent conditional. | ||
Example | |- | ||
|Simple||Type 3 through A are all "conditionals," the conditional most recently executed before this line will be terminated by it. | |||
94000130 FFFB0000 | |- | ||
74000100 FF00000C | |Example|| | ||
023D6B28 0009896C | 94000130 FFFB0000 <br> | ||
D0000000 00000000 | 74000100 FF00000C <br> | ||
023D6B28 0009896C <br> | |||
D0000000 00000000 <br><br> | |||
The 7 type line would be terminated. | The 7 type line would be terminated.<br> | ||
|- | |||
!colspan="2"|D1 Type | |||
D1 Type | |- | ||
Format | |Format||D1000000 00000000 | ||
Description | |- | ||
Simple | |Description||Ends repeat block. | ||
Example | |- | ||
|Simple||Will end all conditionals within a C type code, along with the C type itself. | |||
94000130 FFFB0000 | |- | ||
C0000000 00000010 | |Example|| | ||
8453DA0C 00000200 | 94000130 FFFB0000 <br> | ||
023D6B28 0009896C | C0000000 00000010 <br> | ||
D6000000 00000005 | 8453DA0C 00000200 <br> | ||
D1000000 00000000 | 023D6B28 0009896C <br> | ||
D6000000 00000005 <br> | |||
D1000000 00000000 <br><br> | |||
The C line, 8 line, 0 line, and D6 line would be terminated. | The C line, 8 line, 0 line, and D6 line would be terminated. | ||
|- | |||
!colspan="2"|D2 Type | |||
D2 Type | |- | ||
Format | |Format||D2000000 00000000 | ||
Description | |- | ||
Simple | |Description||Ends all conditionals/repeats before it and sets offset and stored to zero. | ||
Example | |- | ||
|Simple||Ends all lines. | |||
94000130 FEEF0000 | |- | ||
C0000000 00000010 | |Example|| | ||
8453DA0C 00000200 | 94000130 FEEF0000 <br> | ||
023D6B28 0009896C | C0000000 00000010 <br> | ||
D6000000 00000005 | 8453DA0C 00000200 <br> | ||
D2000000 00000000 | 023D6B28 0009896C <br> | ||
D6000000 00000005 <br> | |||
D2000000 00000000 <br><br> | |||
All lines would terminate. | All lines would terminate. | ||
|- | |||
!colspan="2"|D3 Type | |||
D3 Type | |- | ||
Format | |Format||D3000000 XXXXXXXX | ||
Description | |- | ||
Simple | |Description||Sets offset. | ||
Note | |- | ||
Example | |Simple||Loads the address X so that lines after can modify the value at address X. | ||
|- | |||
D3000000 023D6B28 | |Note||Used with the D4, D5, D6, D7, D8, and DC types. | ||
|- | |||
|Example||D3000000 023D6B28 | |||
D4 Type | |- | ||
Format | !colspan="2"|D4 Type | ||
Description | |- | ||
Simple | |Format||D4000000 YYYYYYYY | ||
Note | |- | ||
Example | |Description||adds to the stored address' value. | ||
|- | |||
D4000000 00000025 | |Simple||adds to the value at the address defined by lines D3, D9, DA, and DB. | ||
|- | |||
|Note||used with the D3, D9, DA, DB, DC types. | |||
D5 Type | |- | ||
Format | |Example||D4000000 00000025 | ||
Description | |- | ||
Simple | !colspan="2"|D5 Type | ||
Note | |- | ||
Example | |Format||D5000000 YYYYYYYY | ||
|- | |||
D5000000 34540099 | |Description||Sets the stored address' value. | ||
|- | |||
|Simple||Makes the value at the address defined by lines D3, D9, DA, and DB to YYYYYYYY. | |||
D6 Type | |- | ||
Format | |Note||Used with the D3, D9, DA, DB, and DC types. | ||
Description | |- | ||
Simple | |Example||D5000000 34540099 | ||
Note | |- | ||
Example | !colspan="2"|D6 Type | ||
|- | |||
D3000000 023D6B28 | |Format||D6000000 XXXXXXXX | ||
|- | |||
|Description||32bit store and increment by 4. | |||
D7 Type | |- | ||
Format | |Simple||Stores the value at address XXXXXXXX and to addresses in increments of 4. | ||
Description | |- | ||
Simple | |Note||Used with the C, D3, and D9 types. | ||
Note | |- | ||
Example | |Example||D3000000 023D6B28 | ||
|- | |||
D7000000 023D6B28 | !colspan="2"|D7 Type | ||
|- | |||
|Format||D7000000 XXXXXXXX | |||
D8 Type | |- | ||
Format | |Description||16bit store and increment by 2. | ||
Description | |- | ||
Simple | |Simple||Stores 2 bytes of the value at address XXXXXXXX and to addresses in increments of 2. | ||
Note | |- | ||
Example | |Note||Used with the C, D3, and DA types. | ||
|- | |||
D8000000 023D6B28 | |Example||D7000000 023D6B28 | ||
|- | |||
!colspan="2"|D8 Type | |||
D9 Type | |- | ||
Format | |Format||D8000000 XXXXXXXX | ||
Description | |- | ||
Simple | |Description||8bit store and increment by 1. | ||
Note | |- | ||
Example | |Simple||Stores 1 byte of the value at address XXXXXXXX and to addresses in increments of 1. | ||
|- | |||
D9000000 023D6B28 | |Note||Used with the C, D3, and DB types. | ||
|- | |||
|Example||D8000000 023D6B28 | |||
DA Type | |- | ||
Format | !colspan="2"|D9 Type | ||
Description | |- | ||
Simple | |Format||D9000000 XXXXXXXX | ||
Note | |- | ||
Example | |Description||32bit load. | ||
|- | |||
DA000000 023D6B28 | |Simple||Loads the value from address X. | ||
|- | |||
|Note||Used with the D5 and D6 types. | |||
DB Type | |- | ||
Format | |Example||D9000000 023D6B28 | ||
Description | |- | ||
Simple | !colspan="2"|DA Type | ||
Note | |- | ||
Example | |Format||DA000000 XXXXXXXX | ||
|- | |||
DB000000 023D6B28 | |Description||16bit load. | ||
|- | |||
|Simple||Loads 2 bytes from address X. | |||
DC Type | |- | ||
Format | |Note||Used with the D5 and D7 types. | ||
Description | |- | ||
Simple | |Example||DA000000 023D6B28 | ||
Note | |- | ||
Example | !colspan="2"|DB Type | ||
|- | |||
DC000000 00000100 | |Format||DB000000 XXXXXXXX | ||
|- | |||
|Description||8bit load. | |||
E Type | |- | ||
Format | |Simple||Loads 1 byte from address X. | ||
EXXXXXXX UUUUUUUU | |- | ||
|Note||Used with the D5 and D8 types. | |||
|- | |||
|Example||DB000000 023D6B28 | |||
|- | |||
!colspan="2"|DC Type | |||
|- | |||
|Format||DC000000 VVVVVVVV | |||
|- | |||
|Description||32bit store and increment by V. | |||
|- | |||
|Simple||Stores the value at address(es) before it and to addresses in increments of V. | |||
|- | |||
|Note||Used with the C, D3, D5, D9, D8, DB types. | |||
|- | |||
|Example||DC000000 00000100 | |||
|- | |||
!colspan="2"|E Type | |||
|- | |||
|Format|| | |||
EXXXXXXX UUUUUUUU <br> | |||
YYYYYYYY YYYYYYYY | YYYYYYYY YYYYYYYY | ||
Description | |- | ||
Simple | |Description||Writes Y to X for U bytes. | ||
Example | |- | ||
|Simple||Writes the values at Y (Y can be any length) to addresses starting at X, for U. number of bytes. | |||
E23D6B28 00000010 | |- | ||
1244F2F2 02354653 | |Example|| | ||
23FEDA20 542FEBC0 | E23D6B28 00000010 <br> | ||
D2000000 00000000 | 1244F2F2 02354653 <br> | ||
23FEDA20 542FEBC0 <br> | |||
D2000000 00000000 <br><br> | |||
Special Codes: Built outsite the ARCode format, The Gateway Team have given us a little bonus. | Special Codes: Built outsite the ARCode format, The Gateway Team have given us a little bonus. | ||
|- | |||
!colspan="2"|DD Type | |||
DD Type | |- | ||
Format | |Format||DD000000 XXXXXXXX | ||
Description | |- | ||
|Description||triggers the following code on single or combined keypress. Keypress code stops when terminated with D0 Type code. These can be stacked, i.e. A(01)+Left(20) would be 00000021 | |||
Keys | |- | ||
0x00000001=A | |Keys|| | ||
0x00000002=B | 0x00000001=A <br> | ||
0x00000004=Select | 0x00000002=B <br> | ||
0x00000008=Start | 0x00000004=Select <br> | ||
0x00000010=Right | 0x00000008=Start <br> | ||
0x00000020=Left | 0x00000010=Right <br> | ||
0x00000040=Up | 0x00000020=Left <br> | ||
0x00000080=Down | 0x00000040=Up <br> | ||
0x00000100=R | 0x00000080=Down <br> | ||
0x00000200=L | 0x00000100=R <br> | ||
0x00000400=X | 0x00000200=L <br> | ||
0x00000400=X <br> | |||
0x00000800=Y | 0x00000800=Y | ||
|- | |||
Example | |Example|| | ||
DD000000 00000021 <br> | |||
DD000000 00000021 | 1AE40233 000000FF <br> | ||
1AE40233 000000FF | D0000000 00000000 <br><br> | ||
D0000000 00000000 | |||
Not Implemented: These codes are part of the ARCode format but have not been confirmed built by the Gateway Team. | Not Implemented: These codes are part of the ARCode format but have not been confirmed built by the Gateway Team. | ||
|- | |||
!colspan="2"|F Type | |||
F Type | |- | ||
Format | |Format||FXXXXXXX UUUUUUUU | ||
Description | |- | ||
Simple | |Description||Writes from the offset to address at X for U bytes. | ||
Example | |- | ||
|Simple||Writes from the offset (D3 type) to the address at X for U bytes. | |||
D3000000 023D6B28 | |- | ||
F23D6B2C 00000004 | |Example|| | ||
D3000000 023D6B28 <br> | |||
F23D6B2C 00000004 <br> | |||
D2000000 00000000 | D2000000 00000000 | ||
|- | |||
|} | |||
===Custom Codes=== | |||
==Custom Codes== | {| role="presentation" class="wikitable mw-collapsible mw-collapsed" style="width:800px;" | ||
!colspan="2"|S Type | |||
S Type | |- | ||
Format | |style="width: 10%;"|Format | ||
Description | |S0000000 UUUUUUUU | ||
|- | |||
KR Type | |Description||Put the cheats thread in sleep for U milliseconds. | ||
Format | |- | ||
Description | !colspan="2"|KR Type | ||
|- | |||
DIS Type | |Format||KR000000 UUUUUUUU | ||
Format | |- | ||
Description | |Description||Wait for the U keys to be released. Use the same values as the DD code | ||
|- | |||
!colspan="2"|DIS Type | |||
|- | |||
|Format||DIS00000 00000000 | |||
|- | |||
|Description||This will disable the cheat. With this the cheat will only be executed once. | |||
As the execution is really fast, you might be unable to see the ON on the menu before it goes to OFF. Still the code have been executed. | As the execution is really fast, you might be unable to see the ON on the menu before it goes to OFF. Still the code have been executed. | ||
|- | |||
!colspan="2"|LOG Type | |||
|- | |||
|Format||LOG0X00Y ZZZZZZZZ | |||
|- | |||
|Description||This code will create an entry in the logger. See below for further details. | |||
|- | |||
|} | |||
===Config=== | |||
The soft can use a config file in order to set some preference: | |||
#builder_name: Nanquitas; | |||
#name_auto: 1; | |||
#folder_auto: 1; | |||
#log: 0; | |||
#debug: 1; | |||
==Config== | |||
#builder_name: Nanquitas; | |||
#name_auto: 1; | |||
#folder_auto: 1; | |||
#log: 0; | |||
#debug: 1; | |||
List of options and their meaning: | List of options and their meaning: | ||
* builder_name - Will permit you to enter the name that will be used by the converter automatically for the splash menu. | |||
* name_auto - Set to 1 by default. If disabled the soft will ask you to enter a name for the resulting file. | |||
* folder_auto - Set to 1 by default, if the name of the input file is recognized as a titleID, the program will automatically create the folder tree like: plugin > ID folder > plugin.plg. | |||
* log - Set to 0 by default. Create a traceback file with various info. Mainly used to debug the program. | |||
* debug - Set to 0 by default. If activated, the plugin will have the Debug Menu enabled. This menu can be shown with L + Start and shows various infos. This menu also have a logger. | |||
===Creating a spoiler=== | |||
You can organize the menu with some spoiler. | |||
[++Spoiler text++]//<-- Will open a spoiler | |||
[--]//<-- Will close a spoiler | |||
You can open a spoiler inside another spoiler but only for "two level": | You can open a spoiler inside another spoiler but only for "two level": | ||
[cheats] | |||
[+Spoiler+] | |||
->cheats | |||
->[+Spoiler inside Spoiler+] | |||
--->[cheats] | |||
->[+a second spoiler inside the first one+] | |||
--->[cheats] | |||
You can't do: | You can't do: | ||
[cheats] | |||
[+Spoiler+] | |||
->cheats | |||
->[+Spoiler inside Spoiler+] | |||
--->[cheats] | |||
--->[+a spoiler inside the second one which is himself in the first one+] | |||
----->[cheats] | |||
Doing the second option will only create another spoiler below the second. | |||
{| role="presentation" class="wikitable mw-collapsible mw-collapsed" style="width:800px;" | |||
!Example | |||
|- | |||
|style="width:800px;"| | |||
[++Monsters codes++] <br> | |||
<br> | |||
[Monster3 Infinite Health] <br> | |||
DD000000 00000010 <br> | |||
980D2436 F7FF0800 <br> | |||
B80D2434 00000000 <br> | |||
50000000 006DEA60 <br> | |||
00000088 0001869F <br> | |||
KR000000 00000010 <br> | |||
S0000000 00010000 <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[Monster2 Infinite Health] <br> | |||
980D242E F7FF0800 <br> | |||
B80D242C 00000000 <br> | |||
50000000 006DEA60 <br> | |||
00000088 0001869F <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[Monster1 Infinite Health] <br> | |||
980D2426 F7FF0800 <br> | |||
B80D2424 00000000 <br> | |||
50000000 006DEA60 <br> | |||
00000088 0001869F <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[--] <br> | |||
[++Player codes++] <br> | |||
[++AP++] <br> | |||
[Infinite AP] <br> | |||
980D2406 F7FF0800 <br> | |||
B80D2404 00000000 <br> | |||
50000000 006DDEEC <br> | |||
0000008C 0000270F <br> | |||
D2000000 00000000 <br> | |||
[++HEALTH++] <br> | |||
[Infinite Health] <br> | |||
980D2406 F7FF0800 <br> | |||
B80D2404 00000000 <br> | |||
50000000 006DDEEC <br> | |||
00000088 0000270F <br> | |||
D2000000 00000000 <br> | |||
[--] <br> | |||
[--] <br> | |||
[++ Inventory codes ++] <br> | |||
[9,999,999 CP] <br> | |||
6072E168 00000000 <br> | |||
B072E168 00000000 <br> | |||
DC000000 FFFFFFC4 <br> | |||
00000000 0098967F <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[9,999,999 gil] <br> | |||
6072E168 00000000 <br> | |||
B072E168 00000000 <br> | |||
DC000000 FFFFFFBC <br> | |||
00000000 0098967F <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[99 of all consumables] <br> | |||
6072E168 00000000 <br> | |||
B072E168 00000000 <br> | |||
DC000000 FFFF1CD8 <br> | |||
C0000000 0000001D <br> | |||
20000000 00000063 <br> | |||
DC000000 00000001 <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[99 of all Atmaliths and Magicites] <br> | |||
6072E168 00000000 <br> | |||
B072E168 00000000 <br> | |||
DC000000 FFFFECC0 <br> | |||
C0000000 00000037 <br> | |||
20000000 00000063 <br> | |||
DC000000 00000001 <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[Materials] <br> | |||
6072E168 00000000 <br> | |||
B072E168 00000000 <br> | |||
DC000000 FFFFEC7A <br> | |||
C0000000 0000000C <br> | |||
20000000 00000063 <br> | |||
DC000000 00000001 <br> | |||
D2000000 00000000 <br> | |||
[--] <br> | |||
<br> | |||
[No skill's cooldown] <br> | |||
004491E8 A0E10000 <br> | |||
<br> | |||
[Unlock DLC Quests] <br> | |||
6072E168 00000000 <br> | |||
B072E168 00000000 <br> | |||
DC000000 FFFF2828 <br> | |||
00000000 000001E0 <br> | |||
D2000000 00000000 <br> | |||
|- | |||
|} | |||
===Creating a note=== | |||
You can also create a note for a cheat, which can be shown by pressing Y in the menu. | |||
You can declare a note with: {This is a note} | |||
[Monster3 Infinite Health] | {| role="presentation" class="wikitable mw-collapsible mw-collapsed" style="width:800px;" | ||
DD000000 00000010 | |- | ||
980D2436 F7FF0800 | !Example | ||
B80D2434 00000000 | |- | ||
50000000 006DEA60 | |style="width:800px;"|[++Monsters codes++] <br> | ||
00000088 0001869F | <br> | ||
KR000000 00000010 | [Monster3 Infinite Health] <br> | ||
S0000000 00010000 | DD000000 00000010 <br> | ||
D2000000 00000000 | 980D2436 F7FF0800 <br> | ||
B80D2434 00000000 <br> | |||
50000000 006DEA60 <br> | |||
00000088 0001869F <br> | |||
KR000000 00000010 <br> | |||
S0000000 00010000 <br> | |||
D2000000 00000000 <br> | |||
{Monster #3 Infinite Health:\n\nWith this your third monster will be invicible !!!} <br> | |||
<br> | |||
[Monster2 Infinite Health] <br> | |||
980D242E F7FF0800 <br> | |||
B80D242C 00000000 <br> | |||
50000000 006DEA60 <br> | |||
00000088 0001869F <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[Monster1 Infinite Health] <br> | |||
980D2426 F7FF0800 <br> | |||
B80D2424 00000000 <br> | |||
50000000 006DEA60 <br> | |||
00000088 0001869F <br> | |||
D2000000 00000000 <br> | |||
<br> | |||
[--] <br> | |||
[++Player codes++] <br> | |||
[++AP++] <br> | |||
[Infinite AP] <br> | |||
980D2406 F7FF0800 <br> | |||
B80D2404 00000000 <br> | |||
50000000 006DDEEC <br> | |||
0000008C 0000270F <br> | |||
D2000000 00000000 <br> | |||
{I like to have a lot of AP !!!\nWith that I can beat the crap out of those beasts as long as I want !!!} <br> | |||
[++HEALTH++] <br> | |||
[Infinite Health] <br> | |||
980D2406 F7FF0800 <br> | |||
B80D2404 00000000 <br> | |||
50000000 006DDEEC <br> | |||
00000088 0000270F <br> | |||
D2000000 00000000 <br> | |||
{Mouahahahah !!!!\n\nFear me you ants !\n\nNothing can beat me, I'm god on earth!!!} <br> | |||
[--] <br> | |||
[--] <br> | |||
|- | |||
|} | |||
Note that the \n means going to the next line. By using it twice, you can jump a line. | |||
It's the only format character this function supports. | |||
===Troubleshoot=== | |||
If when you start the program you have this error: The program can't start because VCRUNTIME140.dll is missing from your computer. | |||
Try reinstalling the program to fix this problem. | |||
Then install the VCRedist 2015 I linked higher. | |||
[ | ===Changelog=== | ||
'''V1.1 2016/08/07''' | |||
* Add Mask support for 16 bits conditionals codes (thanks to [https://gbatemp.net/members/365052/ @itsRyan] for noticing it). | |||
* Add value truncation for the (wrong) writes codes, avoid warnings on compilation. | |||
'''V1.0.1 2016/08/03''' | |||
* Bug correction. | |||
==Credits== | |||
* [https://gbatemp.net/members/356222/ @cell9] for the CFW NTR. | |||
== | |||
* [https://gbatemp.net/members/356222/ @cell9] for the CFW NTR | |||
* [https://gbatemp.net/members/366229/ @chronoss] for being the main beta tester. He did a really great job, and many of improvement are here because of him | * [https://gbatemp.net/members/366229/ @chronoss] for being the main beta tester. He did a really great job, and many of improvement are here because of him | ||
* | * A lot of people all over the web, particularly people helping in the 3DS Scene. | ||
==External links== | |||
* GBAtemp - https://gbatemp.net/threads/release-gateshark2ntr.436504 | |||
[[Category:3DS homebrew applications]] | |||
[[Category:PC utilities for 3DS homebrew]] |
Revision as of 02:02, 25 February 2022
Gateshark2NTR | |
---|---|
File:Gateshark2NTR.jpg | |
General | |
Author | Nanquitas |
Type | PC Utilities |
Version | 1.1 |
License | Mixed |
Last Updated | 2016/08/07 |
Links | |
Download | |
Website | |
This application has been obsoleted by one or more applications that serve the same purpose, but are more stable or maintained. |
Gateshark2NTR is a program that will allow you to convert a Gateshark's cheats text file in a plugin usable with NTR.
Note: This is no longer supported, consider using CTRPluginFramework 3DS with Action Replay support instead of using a converter. With it you can simply load your text files with cheats.
User guide
Requirements:
- DevKitPRO. Install this and be sure to add "c:\devkitPro\msys\bin" to the PATH Environment Variable
- You also need to have the VCRedist 2015 installed.
There are 3 ways to pass the file:
- Drag & Drop the file on the soft's icon.
- Launch the soft and a window will appear to select the file.
- Pass the file as an argument through a shell.
This soft support all the codes used by gateway and even more.
Complete STD AR/Gateway codes
0 Type | |
---|---|
Format | 0XXXXXXX YYYYYYYY |
Description | 32bit write of YYYYYYYY to 0XXXXXXX. |
Simple | Makes the value at address 0XXXXXXX equal the value YYYYYYYY. |
Example | 023D6B28 3B9ACA00 |
1 Type | |
Format | 1XXXXXXX 0000YYYY |
Description | 16bit write of YYYY to 0XXXXXXX. |
Simple | Makes the value at address 0XXXXXXX equal the value YYYY. |
Example | 023D6B28 00002710 |
2 Type | |
Format | 2XXXXXXX 000000YY |
Description | 8bit write of YY to 0XXXXXXX. |
Simple | Makes the value at address 0XXXXXXX equal the value YY. |
Example | 023D6B28 00000032 |
3 Type | |
Format | 3XXXXXXXX YYYYYYYY |
Description | 32bit if less than. |
Simple | If the value at address 0XXXXXXX is less than the value YYYYYYYY. |
Example | 323D6B28 10000000 |
4 Type | |
Format | 4XXXXXXXX YYYYYYYY |
Description | 32bit if greater than. |
Simple | If the value at address 0XXXXXXX is greater than the value YYYYYYYY. |
Example | 423D6B28 10000000 |
5 Type | |
Format | 5XXXXXXXX YYYYYYYY |
Description | 32bit if equal to. |
Simple | If the value at address 0XXXXXXX is equal to the value YYYYYYYY. |
Example | 523D6B28 10000000 |
6 Type | |
Format | 3XXXXXXXX YYYYYYYY |
Description | 32bit if not equal to. |
Simple | If the value at address 0XXXXXXX is not equal to the value YYYYYYYY. |
Example | 623D6B28 10000000 |
7 Type | |
Format | 7XXXXXXXX 0000YYYY |
Description | 16bit if less than. |
Simple | If the value at address 0XXXXXXX is less than the value YYYY. |
Example | 723D6B28 00005400 |
8 Type | |
Format | 8XXXXXXXX 0000YYYY |
Description | 16bit if greater than. |
Simple | If the value at address 0XXXXXXX is greater than the value YYYY. |
Example | 823D6B28 00005400 |
9 Type | |
Format | 9XXXXXXXX 0000YYYY |
Description | 16bit if equal to. |
Simple | If the value at address 0XXXXXXX is equal to the value YYYY. |
Example | 923D6B28 00005400 |
A Type | |
Format | AXXXXXXXX 0000YYYY |
Description | 16bit if not equal to. |
Simple | If the value at address 0XXXXXXX is not equal to the value YYYY. |
Example | A23D6B28 00005400 |
B Type | |
Format | BXXXXXXX 00000000 |
Description | Loads offset register. |
Simple | Used for pointers, the address at 0XXXXXXX is the offset for all of the following lines. |
Example |
B23D6B28 00000000 |
C Type | |
Format | C0000000 ZZZZZZZZ |
Description | Repeat following lines at specified offset. |
Simple | Used to write a value to an address, and then continues to write that value Z number of times to all addresses at an offset determined by the (D6, D7, D8, or DC) type following it. |
Note | Used with the D6, D7, D8, and DC types. C types can not be nested. |
Example |
C0000000 00000005 |
D0 Type | |
Format | D0000000 00000000 |
Description | Ends most recent conditional. |
Simple | Type 3 through A are all "conditionals," the conditional most recently executed before this line will be terminated by it. |
Example |
94000130 FFFB0000 |
D1 Type | |
Format | D1000000 00000000 |
Description | Ends repeat block. |
Simple | Will end all conditionals within a C type code, along with the C type itself. |
Example |
94000130 FFFB0000 |
D2 Type | |
Format | D2000000 00000000 |
Description | Ends all conditionals/repeats before it and sets offset and stored to zero. |
Simple | Ends all lines. |
Example |
94000130 FEEF0000 |
D3 Type | |
Format | D3000000 XXXXXXXX |
Description | Sets offset. |
Simple | Loads the address X so that lines after can modify the value at address X. |
Note | Used with the D4, D5, D6, D7, D8, and DC types. |
Example | D3000000 023D6B28 |
D4 Type | |
Format | D4000000 YYYYYYYY |
Description | adds to the stored address' value. |
Simple | adds to the value at the address defined by lines D3, D9, DA, and DB. |
Note | used with the D3, D9, DA, DB, DC types. |
Example | D4000000 00000025 |
D5 Type | |
Format | D5000000 YYYYYYYY |
Description | Sets the stored address' value. |
Simple | Makes the value at the address defined by lines D3, D9, DA, and DB to YYYYYYYY. |
Note | Used with the D3, D9, DA, DB, and DC types. |
Example | D5000000 34540099 |
D6 Type | |
Format | D6000000 XXXXXXXX |
Description | 32bit store and increment by 4. |
Simple | Stores the value at address XXXXXXXX and to addresses in increments of 4. |
Note | Used with the C, D3, and D9 types. |
Example | D3000000 023D6B28 |
D7 Type | |
Format | D7000000 XXXXXXXX |
Description | 16bit store and increment by 2. |
Simple | Stores 2 bytes of the value at address XXXXXXXX and to addresses in increments of 2. |
Note | Used with the C, D3, and DA types. |
Example | D7000000 023D6B28 |
D8 Type | |
Format | D8000000 XXXXXXXX |
Description | 8bit store and increment by 1. |
Simple | Stores 1 byte of the value at address XXXXXXXX and to addresses in increments of 1. |
Note | Used with the C, D3, and DB types. |
Example | D8000000 023D6B28 |
D9 Type | |
Format | D9000000 XXXXXXXX |
Description | 32bit load. |
Simple | Loads the value from address X. |
Note | Used with the D5 and D6 types. |
Example | D9000000 023D6B28 |
DA Type | |
Format | DA000000 XXXXXXXX |
Description | 16bit load. |
Simple | Loads 2 bytes from address X. |
Note | Used with the D5 and D7 types. |
Example | DA000000 023D6B28 |
DB Type | |
Format | DB000000 XXXXXXXX |
Description | 8bit load. |
Simple | Loads 1 byte from address X. |
Note | Used with the D5 and D8 types. |
Example | DB000000 023D6B28 |
DC Type | |
Format | DC000000 VVVVVVVV |
Description | 32bit store and increment by V. |
Simple | Stores the value at address(es) before it and to addresses in increments of V. |
Note | Used with the C, D3, D5, D9, D8, DB types. |
Example | DC000000 00000100 |
E Type | |
Format |
EXXXXXXX UUUUUUUU |
Description | Writes Y to X for U bytes. |
Simple | Writes the values at Y (Y can be any length) to addresses starting at X, for U. number of bytes. |
Example |
E23D6B28 00000010 |
DD Type | |
Format | DD000000 XXXXXXXX |
Description | triggers the following code on single or combined keypress. Keypress code stops when terminated with D0 Type code. These can be stacked, i.e. A(01)+Left(20) would be 00000021 |
Keys |
0x00000001=A |
Example |
DD000000 00000021 |
F Type | |
Format | FXXXXXXX UUUUUUUU |
Description | Writes from the offset to address at X for U bytes. |
Simple | Writes from the offset (D3 type) to the address at X for U bytes. |
Example |
D3000000 023D6B28 |
Custom Codes
S Type | |
---|---|
Format | S0000000 UUUUUUUU |
Description | Put the cheats thread in sleep for U milliseconds. |
KR Type | |
Format | KR000000 UUUUUUUU |
Description | Wait for the U keys to be released. Use the same values as the DD code |
DIS Type | |
Format | DIS00000 00000000 |
Description | This will disable the cheat. With this the cheat will only be executed once.
As the execution is really fast, you might be unable to see the ON on the menu before it goes to OFF. Still the code have been executed. |
LOG Type | |
Format | LOG0X00Y ZZZZZZZZ |
Description | This code will create an entry in the logger. See below for further details. |
Config
The soft can use a config file in order to set some preference:
#builder_name: Nanquitas; #name_auto: 1; #folder_auto: 1; #log: 0; #debug: 1;
List of options and their meaning:
- builder_name - Will permit you to enter the name that will be used by the converter automatically for the splash menu.
- name_auto - Set to 1 by default. If disabled the soft will ask you to enter a name for the resulting file.
- folder_auto - Set to 1 by default, if the name of the input file is recognized as a titleID, the program will automatically create the folder tree like: plugin > ID folder > plugin.plg.
- log - Set to 0 by default. Create a traceback file with various info. Mainly used to debug the program.
- debug - Set to 0 by default. If activated, the plugin will have the Debug Menu enabled. This menu can be shown with L + Start and shows various infos. This menu also have a logger.
Creating a spoiler
You can organize the menu with some spoiler.
[++Spoiler text++]//<-- Will open a spoiler [--]//<-- Will close a spoiler
You can open a spoiler inside another spoiler but only for "two level":
[cheats] [+Spoiler+] ->cheats ->[+Spoiler inside Spoiler+] --->[cheats] ->[+a second spoiler inside the first one+] --->[cheats]
You can't do:
[cheats] [+Spoiler+] ->cheats ->[+Spoiler inside Spoiler+] --->[cheats] --->[+a spoiler inside the second one which is himself in the first one+] ----->[cheats]
Doing the second option will only create another spoiler below the second.
Example |
---|
[++Monsters codes++] |
Creating a note
You can also create a note for a cheat, which can be shown by pressing Y in the menu.
You can declare a note with: {This is a note}
Example |
---|
[++Monsters codes++]
|
Note that the \n means going to the next line. By using it twice, you can jump a line.
It's the only format character this function supports.
Troubleshoot
If when you start the program you have this error: The program can't start because VCRUNTIME140.dll is missing from your computer.
Try reinstalling the program to fix this problem.
Then install the VCRedist 2015 I linked higher.
Changelog
V1.1 2016/08/07
- Add Mask support for 16 bits conditionals codes (thanks to @itsRyan for noticing it).
- Add value truncation for the (wrong) writes codes, avoid warnings on compilation.
V1.0.1 2016/08/03
- Bug correction.