SubTerminalEX
Improve performance for command, enable other mods to add their own custom command and add some utility command for you
Last updated | 2 months ago |
Total downloads | 225 |
Total rating | 3 |
Categories | Mods Libraries |
Dependency string | Ozzzzy-SubTerminalEX-1.1.2 |
Dependants | 0 other packages depend on this package |
This mod requires the following mods to function
BepInEx-BepInExPack
BepInEx pack for Mono Unity games. Preconfigured and ready to use.
Preferred version: 5.4.2100README
SubTerminalEX v1.1.2
Note
- NOTE: This is client-only mod, it does not add cheat or hacks, it does not allow user to use hidden system only terminal command by itself.
- If you do happen to encounter crash, please report it to me so i can identify if it was because of my faulty code or vanilla issue
- If you got any issue with this mod, feel free to mention me in this discord server (username: Ozzzzymaniac)
Features
- "Cleanup" game command interpreter which improve performance (source?: trust me bro)
- Allow terminal to take a string argument
"this is multiple words argument"
as an single argument instead of being splitted to multiple argument - Add "a lot" of utility and quality of life commands
- Remove terminal bootup text (for people want "speed" startup, can be disabled in config
- Allow other mods to add their own desired custom commands and more...
New terminal command
Please note that all argument for all command below are all case in-sensitive and are all converted to upper-case
clear
or it alias cls
- Clear all text on the terminal
alias (set/map) [old] [new]
or alias [old] [new]
- Map [old] command to [new] so you can type [new] and it will work as if you are typing [old]
- E.g
alias set view_cam vcam
now you can type vcam and it work as if you are using view_cam
- E.g
alias (rem/remove/rm) [new]
- Remove mapped [new] command
- E.g
alias rem vcam
vcam will no longer work
- E.g
alias (clear/reset)
- Reset and remove all mapped commands
- E.g
alias clear
vcam and anything mapped before this point will now no longer work
- E.g
alias load [filename]
- Load a pre-defined alias text file at GAME_ROOT directory, due to "lazy" limitation loading a new alias text file result in all current alias'ed command being removed (technically a
alias clear
before loading the new file) - Please note that [filename] are case in-sensitive because it will get capitialized!
- E.g
alias load promax
now any of pre-defined alias will work just like you manually typing alias set
- E.g
alias (gen/generate) [filename]
- Generate alias text file for use of
alias load
, the generated file will include all of currently alias'ed command - Please note that [filename] are case in-sensitive because it will get capitialized!
- E.g
alias gen promax
will create a "PROMAX.txt" file at GAME_ROOT directory for use withalias load
- E.g
Alias Format
The alias text file is a simple text file that are follow the [block][separator?]
format
-
[block]
: a text section contain[old command]<space>[new command]
, within this block everything after[new command]<space>
are ignored -
[separator?]
: is either a newline\n
or a comma,
E.g:
view_cams vcam <= ( [block] = view_cams vcam; [separator?] = \n )
shop s this is a comment and will be ignored
list_bulkhead ldoor -- this is also a comment and also ignored (including --)
list_cam lcam, open_bulkhead open -- this comma is valid
close_bulkhead close,minimap mmap -- also valid
For mods developer (last revised: 11/30/2024)
- Note that any change to the first number in the mod version WILL cause incompatibility which mean any of these api WILL be or can be completely unusable
- All argument passed to your new command can be more than you request, only argument passed to vanilla are exactly the size they request! (can be customized)
- Prefer to xml documentation named
SubTerminalEX.xml
for more information and latest documentation (documentation here can be outdated at anytime)
Add/Remove/Hook/Override command
public static IEnumerator OnExecuteA(List<string> _){} // command has no argument so you can safely ignore the argument passed in
public static IEnumerator OnExecuteB(List<string> args) {} // command has argument, and are listed by the order they typed in
public static IEnumerator newMinimap(List<string> args) {} // when minimap is executed this method will run instead of the original method
public static void OnExecuteHook(List<string> args) {} // this method will run after route_to is executed, all argument passed in are exactly like the original command
// way 1 - for command have no argument
TerminalCommandManager.AddNoArgumentCommand("play", OnExecuteA);
// way 2 - for command that have argument
TerminalCommandManager.AddCommand("reset", OnExecuteB);
// override command (from other mods or vanilla)
TerminalCommandManager.OverrideCommand("minimap", newMinimap);
// extra: you can create your own alias too for mods that want to add alias for their own command
// note that alias created this way cant be deleted by user "alias remove" (can be changed)
TerminalCommandManager.AliasCommand("base_command", "new_alias");
// extra 2: you can now hook the desired command instead of override and then use hacks to run the original command!
TerminalCommandManager.HookCommand("route_to", OnExecuteHook, STEHookPriority.Default, STEHookTarget.Default);
TerminalCommandManager.HookCommand("route_to", OnExecuteHook, 69, STEHookTarget.Default);
// There is no checking done in the "background", so you can remove thing like this and make the game completely unplayable...
TerminalCommandManager.RemoveCommand("leave_checkpoint")
License
MIT License
Copyright (c) 2024 Nguyen Anh Tri
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.