ZapScript: Difference between revisions

From Zaparoo Wiki

No edit summary
 
(5 intermediate revisions by the same user not shown)
Line 1: Line 1:
Tokens are set up to work with TapTo by writing a small piece of text to them, telling TapTo what it should do when it's read. The most common action is to launch a game, but it can perform other actions like launching a random game or even making an HTTP request.
Tokens are set up to work with Zaparoo by writing a small piece of text to them, telling Zaparoo what it should do when it's read. The most common action is to launch a game, but it can perform other actions like launching a random game or even making an HTTP request.


This text can be as simple as a path to a game file, or perform multiple custom commands in a row.
This text can be as simple as a path to a game file, or perform multiple custom commands in a row.
Line 5: Line 5:
== Setting Up Tokens ==
== Setting Up Tokens ==


=== TapTo Life ===
=== Zaparoo App ===
TapTo Life is a mobile app available on [https://wizzo.dev/tapto-life iOS and Android] which can be used to generate commands using your phone. It can search for games stored on your device, and write a tag using your phone's NFC reader with the correct format. Tag writing functionality is available for free.
The Zaparoo App is a mobile app available on [https://wizzo.dev/tapto-life iOS and Android] which can be used to generate commands using your phone. It can search for games stored on your device, and write a tag using your phone's NFC reader with the correct format. Tag writing functionality is available for free.


=== TapTUI ===
=== TapTUI ===
The <code>taptui.sh</code> script for MiSTer is included for download in the [https://github.com/wizzomafizzo/tapto/releases/latest/ TapTo releases].
This is a frontend to the Zaparoo service which lets you write and interact with tokens in many advanced ways. It can browse and search games on the MiSTer to be written, and has an awesome command palette to build up more complex commands.
 
This is a frontend to the TapTo service which lets you write and interact with tokens in many advanced ways. It can browse and search games on the MiSTer to be written, and has an awesome command palette to build up more complex commands.
 
It's included with TapTo on MiSTer if you're using the Downloader or Update All scripts, or you can download it manually to the <code>Scripts</code> folder on your MiSTer's SD card, and run it from the <code>Scripts</code> menu.
 
=== Remote ===
The Remote app has basic support for writing games to tokens through the TapTo service.
If you have TapTo running, a button to write a game to a token will be displayed when selecting games in search results and the games browser.
 
=== NFC Tools ===
The NFC Tools app is highly recommended for this. It's free and supports both iOS and Android.
You'll want to write a <code>Text record</code> with it for all the supported NFC service features.
 
==== Desktop ====
NFC Tools also has a free version for Windows, Mac and Linux that works well. [[ACR122U|ACR122U readers]] will work natively with most desktop operating systems.


== Launching Games ==
== Launching Games ==
For the most basic usage, a file path can be written to a token and TapTo will attempt to find the file on the device and launch it.
For the most basic usage, a file path can be written to a token and Zaparoo will attempt to find the file on the device and launch it.
The required system and configuration for the game will be automatically selected based on the file path. On MiSTer, you can also launch arcade .mra files, shortcut .mgl files and core .rbf files with just their path.
The required system and configuration for the game will be automatically selected based on the file path. On MiSTer, you can also launch arcade .mra files, shortcut .mgl files and core .rbf files with just their path.


TapTo uses the following rules, in order, to find the game file. Keep these rules in mind if you want a token to work well between different devices.
Zaparoo uses the following rules, in order, to find the game file. Keep these rules in mind if you want a token to work well between different devices.
{{Reminder|If you're not sure what to do, it's recommended to use the System Lookup method for the best portability between devices.}}
{{Reminder|If you're not sure what to do, it's recommended to use the System Lookup method for the best portability between devices.}}


Line 37: Line 22:


For example, to launch a game, write something like this to the token:
For example, to launch a game, write something like this to the token:
<code>/media/fat/games/Genesis/1 US - Q-Z/Some Game (USA, Europe).md</code>
 
<code>/media/fat/games/Genesis/1 US - Q-Z/Some Game (USA, Europe).md</code>
 
This is the least portable method, as it will only work on the device with the exact same file path.
This is the least portable method, as it will only work on the device with the exact same file path.


=== Relative Path ===
=== Relative Path ===
It's also possible to use a file path relative to the games folder. This will search for the file in all standard MiSTer game folder paths including CIFS and USB.
It's also possible to use a file path relative to the games folder. This will search for the file in all standard MiSTer game folder paths including CIFS and USB.
For example:
For example:
<code>Genesis/1 US - Q-Z/Some Game (USA, Europe).md</code>
 
<code>Genesis/1 US - Q-Z/Some Game (USA, Europe).md</code>
 
This saves storage space on the token and will work if one device has games stored on a USB drive and another on the SD card. There's no downside to using it compared to an absolute path.
This saves storage space on the token and will work if one device has games stored on a USB drive and another on the SD card. There's no downside to using it compared to an absolute path.


Some other examples:
Some other examples:
<code>_Arcade/Some Arcade Game.mra</code>


<code>_@Favorites/My Favorite Game.mgl</code>
<code>_Arcade/Some Arcade Game.mra</code>
 
<code>_@Favorites/My Favorite Game.mgl</code>
 
.zip files are also supported natively, same as they are in MiSTer itself. Just treat the .zip file as a folder name:
.zip files are also supported natively, same as they are in MiSTer itself. Just treat the .zip file as a folder name:
<code>Genesis/@Genesis - 2022-05-18.zip/1 US - Q-Z/Some Game (USA, Europe).md</code>
 
<code>Genesis/@Genesis - 2022-05-18.zip/1 US - Q-Z/Some Game (USA, Europe).md</code>


=== System Lookup ===
=== System Lookup ===
Line 59: Line 52:


For example:
For example:
<code>N64/1 US - A-M/Another Game (USA).z64</code>
 
While this looks like a relative path, it will work on any device with the same system folder structure, even if the Nintendo 64 folder does not have the same name. TapTo will look up the system ID and find the game file based on that.
<code>N64/1 US - A-M/Another Game (USA).z64</code>
 
While this looks like a relative path, it will work on any device with the same system folder structure, even if the Nintendo 64 folder does not have the same name. Zaparoo will look up the system ID and find the game file based on that.


System ID aliases (listed in the [[Systems]] page as well) can also be used here.
System ID aliases (listed in the [[Systems]] page as well) can also be used here.


For example, this will work:
For example, this will work:
<code>TurboGrafx16/Another Game (USA).pce</code>
 
<code>TurboGrafx16/Another Game (USA).pce</code>
 
Or this:
Or this:
<code>tgfx16/Another Game (USA).pce</code>
 
<code>tgfx16/Another Game (USA).pce</code>
 
Or even this:
Or even this:
<code>PCEngine/Another Game (USA).pce</code>
 
{{Info|While this method is basically the same as a relative path right now, as TapTo develops, we will be adding more features to this System Lookup method so it's not necessary to use explicit paths. It will also be important going forward as more devices are supported with different file structures.}}
<code>PCEngine/Another Game (USA).pce</code>
{{Info|While this method is basically the same as a relative path right now, as Zaparoo develops, we will be adding more features to this System Lookup method so it's not necessary to use explicit paths. It will also be important going forward as more devices are supported with different file structures.}}


=== Special Cases ===
=== Special Cases ===
Line 76: Line 76:


==== ao486 ====
==== ao486 ====
If a .vhd file is launched via TapTo, and this .vhd file is sitting in its own folder with an .iso or .chd file, that .iso or .chd file will also be automatically mounted alongside the .vhd file.
If a .vhd file is launched via Zaparoo, and this .vhd file is sitting in its own folder with an .iso or .chd file, that .iso or .chd file will also be automatically mounted alongside the .vhd file.


==== AmigaVision (Amiga) ====
==== AmigaVision (Amiga) ====
Line 82: Line 82:


For example, to launch Beneath a Stell Sky in AmigaVision:
For example, to launch Beneath a Stell Sky in AmigaVision:
<code>Amiga/listings/games.txt/Beneath a Steel Sky (OCS)[en]</code>
 
The <code>games.txt</code> and <code>demos.txt</code> files contain a listing of all supported games and demos, generated by AmigaVision, and can be treated as a virtual folder for launching via TapTo. Other games can be launched using the same format of <code>Amiga/listings/games.txt/<Game Name></code>.
<code>Amiga/listings/games.txt/Beneath a Steel Sky (OCS)[en]</code>
 
The <code>games.txt</code> and <code>demos.txt</code> files contain a listing of all supported games and demos, generated by AmigaVision, and can be treated as a virtual folder for launching via Zaparoo. Other games can be launched using the same format of <code>Amiga/listings/games.txt/<Game Name></code>.


Opening the <code>games.txt</code> and <code>demos.txt</code> files in a text editor will show the full list of supported games and demos.
Opening the <code>games.txt</code> and <code>demos.txt</code> files in a text editor will show the full list of supported games and demos.


==== NeoGeo ====
==== NeoGeo ====
NeoGeo also supports launching .zip files and folders directly with TapTo, as is supported with the MiSTer core itself.
NeoGeo also supports launching .zip files and folders directly with Zaparoo, as is supported with the MiSTer core itself.
 
For example, a .zip file:
 
<code>NeoGeo/mslug.zip</code>
 
Or a folder:
 
<code>NeoGeo/mslug2</code>


== Combining Commands ==
== Combining Commands ==
Line 94: Line 104:


For example, to switch to MiSTer.ini number 3 and launch the SNES core:
For example, to switch to MiSTer.ini number 3 and launch the SNES core:
<code>**mister.ini:3||_Console/SNES</code>
 
<code>**mister.ini:3||_Console/SNES</code>
 
Or launch a game and notify an HTTP service:
Or launch a game and notify an HTTP service:
<code>_Console/SNES||**http.get:<nowiki>https://example.com</nowiki></code>
 
<code>_Console/SNES||**http.get:<nowiki>https://example.com</nowiki></code>
 
As many of these can be combined as you like.
As many of these can be combined as you like.


Line 108: Line 122:


For example:
For example:
<code>**launch:/media/fat/games/Genesis/1 US - Q-Z/Some Game (USA, Europe).md</code>
 
<code>**launch:/media/fat/games/Genesis/1 US - Q-Z/Some Game (USA, Europe).md</code>


==== Launch a System (launch.system) ====
==== Launch a System (launch.system) ====
Line 114: Line 129:


For example:
For example:
<code>**launch.system:Atari2600</code>


<code>**launch.system:WonderSwanColor</code>
<code>**launch.system:Atari2600</code>
 
<code>**launch.system:WonderSwanColor</code>
 
It also works for any other system if you prefer this method over the standard core .rbf file one.
It also works for any other system if you prefer this method over the standard core .rbf file one.


==== Launch a Random Game (launch.random) ====
==== Launch a Random Game (launch.random) ====
This command will launch a game at random for the given system. For example:
This command will launch a game at random for the given system. For example:
<code>**launch.random:snes</code>
 
<code>**launch.random:snes</code>
 
This will launch a random SNES game each time you read the token.
This will launch a random SNES game each time you read the token.


System IDs can also be combined with the <code>,</code> separator. For example:
System IDs can also be combined with the <code>,</code> separator. For example:
<code>**launch.random:snes,nes</code>
 
<code>**launch.random:snes,nes</code>
 
This will launch a random game from either the SNES or NES systems. You can also select all systems with <code>**launch.random:all</code>.
This will launch a random game from either the SNES or NES systems. You can also select all systems with <code>**launch.random:all</code>.


Line 134: Line 155:
This is useful for folder full of .mgl file on MiSTer.
This is useful for folder full of .mgl file on MiSTer.


A random game can also be chosen using the <code>launch.search</code> syntax. Instead of picking and launching the first result, TapTo will pick a random one:
A random game can also be chosen using the <code>launch.search</code> syntax. Instead of picking and launching the first result, Zaparoo will pick a random one:


<code>**launch.random:Genesis/*sonic*</code>
<code>**launch.random:Genesis/*sonic*</code>
Line 155: Line 176:
==== Make an HTTP GET Request to a URL (http.get) ====
==== Make an HTTP GET Request to a URL (http.get) ====
Perform an HTTP GET request to the specified URL. For example:
Perform an HTTP GET request to the specified URL. For example:
<code>**http.get:<nowiki>https://example.com</nowiki></code>
 
<code>**launch.random:snes,nes</code>
 
This is useful for triggering webhooks or other web services.
This is useful for triggering webhooks or other web services.


It can be combined with other commands using the <code>||</code> separator. For example:
It can be combined with other commands using the <code>||</code> separator. For example:
<code>**http.get:<nowiki>https://example.com||_Console/SNES</nowiki></code>
 
<code>**http.get:<nowiki>https://example.com||_Console/SNES</nowiki></code>
 
If your URL contains any of the following characters, you must URL encode them by replacing them with the following:
If your URL contains any of the following characters, you must URL encode them by replacing them with the following:


Line 168: Line 193:
==== Make an HTTP POST Request to a URL (http.post) ====
==== Make an HTTP POST Request to a URL (http.post) ====
Perform an HTTP POST request to the specified URL. For example:
Perform an HTTP POST request to the specified URL. For example:
<code>**http.post:<nowiki>https://example.com,application/json,{</nowiki>"key":"value"}</code>
 
<code>**http.post:<nowiki>https://example.com,application/json,{</nowiki>"key":"value"}</code>
 
Or with Remote, to launch the Update All script:
Or with Remote, to launch the Update All script:
<code>**http.post:<nowiki>http://localhost:8182/api/scripts/launch/update_all.sh,application/json</nowiki>,</code>
 
<code>**http.post:<nowiki>http://localhost:8182/api/scripts/launch/update_all.sh,application/json</nowiki>,</code>
 
The command is in the format <code>URL,Content-Type,Body</code>.
The command is in the format <code>URL,Content-Type,Body</code>.


Line 183: Line 212:
==== Press a Keyboard Key (input.keyboard) ====
==== Press a Keyboard Key (input.keyboard) ====
Press a key or multiple keys on a virtual keyboard attached to the host. One key:
Press a key or multiple keys on a virtual keyboard attached to the host. One key:
<code>**input.keyboard:@</code>
<code>**input.keyboard:@</code>


Line 191: Line 221:
Special keys can be entered by with a key name surrounded by curly braces (<code>{}</code>) as shown above. If you want to enter an literal curly brace, type a backslash before it like <code>\{</code> and <code>\}</code>. Backslashes can also be escaped (<code>\\</code>).
Special keys can be entered by with a key name surrounded by curly braces (<code>{}</code>) as shown above. If you want to enter an literal curly brace, type a backslash before it like <code>\{</code> and <code>\}</code>. Backslashes can also be escaped (<code>\\</code>).


Possible key names are: esc, backspace, tab, enter, lctrl, lshift, backslash, rshift, lalt, space, caps, num, scroll, f1-f12, home, up pgup, left, right, end, down, pgdn, ins, del, volup, voldn.
Possible special key names are: esc, backspace, tab, enter, lctrl, lshift, backslash, rshift, lalt, space, caps, num, scroll, f1-f12, home, up pgup, left, right, end, down, pgdn, ins, del, volup, voldn.
 
==== Press a Gamepad Button (input.gamepad) ====
Press a button or multiple buttons in sequence on a virtual gamepad attached to the host.
 
This works the same as the <code>input.keyboard</code> command but with the following name mappings:
 
* ^, {up}: Dpad up
* V, {down}: Dpad down
* <, {left}: Dpad left
* >, {right}: Dpad right
* A, a: East button
* B, b: South button
* X, x: North button
* Y, y: West button
* {start}: Start
* {select}: Select
* {menu}: Menu (Xbox/PlayStation/etc. button)
* L, l, {l1}: Left bumper
* R, r, {r1}: Right bumper
* {l2}: Left trigger
* {r2}: Right trigger
 
For example:
 
<code>**input.gamepad:^^VV<><>BA{start}{select}</code>
 
Be aware that this gamepad likely needs to be mapped manually first to work, and that it will show to the game as an additional controller not imitate an existing connected controller.


==== Insert a Coin/Credit (input.coinp1/input.coinp2) ====
==== Insert a Coin/Credit (input.coinp1/input.coinp2) ====
Insert a coin/credit for player 1 or 2. For example (to insert 1 coin for player 1):
Insert a coin/credit for player 1 or 2. For example (to insert 1 coin for player 1):
<code>**input.coinp1:1</code>
 
<code>**input.coinp1:1</code>
 
This command presses the <code>5</code> and <code>6</code> key on the keyboard respectively, which is generally accepted as the coin insert keys in MiSTer arcade cores. If it doesn't work, try manually mapping the coin insert keys in the OSD.
This command presses the <code>5</code> and <code>6</code> key on the keyboard respectively, which is generally accepted as the coin insert keys in MiSTer arcade cores. If it doesn't work, try manually mapping the coin insert keys in the OSD.


It also supports inserting multiple coins at once. For example (to insert 3 coins for player 2):
It also supports inserting multiple coins at once. For example (to insert 3 coins for player 2):
<code>**input.coinp2:3</code>
 
<code>**input.coinp2:3</code>


=== MiSTer ===
=== MiSTer ===
Line 209: Line 269:


For example:
For example:
<code>**mister.ini:1</code>
 
<code>**mister.ini:1</code>
 
This switch will not persist after a reboot, same as loading it through the OSD.
This switch will not persist after a reboot, same as loading it through the OSD.


==== Launch a Core RBF File (mister.core) ====
==== Launch a Core RBF File (mister.core) ====
This command will launch a MiSTer core .rbf file directly. For example:
This command will launch a MiSTer core .rbf file directly. For example:
<code>**mister.core:_Console/SNES</code>
 
<code>**mister.core:_Console/SNES</code>
 
Or:
Or:
<code>**mister.core:_Console/PSX_20220518</code>
 
<code>**mister.core:_Console/PSX_20220518</code>
 
It uses the exact same format as the <code>rbf</code> tag in a .mgl file, where the ending of a filename can be omitted. The path is relative to the SD card.
It uses the exact same format as the <code>rbf</code> tag in a .mgl file, where the ending of a filename can be omitted. The path is relative to the SD card.
==== Launch a Script (mister.script) ====
It's possible to launch a MiSTer script which already exists on the MiSTer:
<code>**mister.script:update_all.sh</code>
Zaparoo will '''close the currently running game''' back to the menu core if necessary, then launch the script on screen as if it were launched from the Scripts menu. The script must exist already in <code>/media/fat/Scripts</code> or it won't be run.
Arguments to the script are allowed, just type them after the filename as you would on a shell. Arguments are escaped for security.


=== Utility Functions ===
=== Utility Functions ===


==== Run a System/Linux Command (shell) ====
==== Run a System/Linux Command (shell) ====
{{Warn|This feature is intentionally disabled for security reasons when run straight from a token. You can still use it, by enabling the allow_commands option in tapto.ini.}}
{{Warn|This feature is intentionally disabled for security reasons when run straight from a token. You can still use it by enabling the allow_commands option in the Zaparoo config file.}}
This command will run a MiSTer Linux command directly. For example:
This command will run a MiSTer Linux command directly. For example:
<code>**shell:reboot</code>
 
<code>**shell:reboot</code>


==== Delay Command Execution (delay) ====
==== Delay Command Execution (delay) ====
This command will delay the execution of the next command by the specified number of milliseconds. For example:
This command will delay the execution of the next command by the specified number of milliseconds. For example:
<code>**delay:500</code>
 
<code>**delay:500</code>
 
Will delay the next command by 500ms (half a second). This is a ''blocking command'' and will delay the entire token read by the specified time.
Will delay the next command by 500ms (half a second). This is a ''blocking command'' and will delay the entire token read by the specified time.


It can be combined with other commands using the <code>||</code> separator. For example, to launch SNES, wait 10 seconds, then press F12:
It can be combined with other commands using the <code>||</code> separator. For example, to launch SNES, wait 10 seconds, then press F12:
<code>_Console/SNES||**delay:10000||**input.key:88</code>
 
<code>_Console/SNES||**delay:10000||**input.key:88</code>

Latest revision as of 14:11, 30 November 2024

Tokens are set up to work with Zaparoo by writing a small piece of text to them, telling Zaparoo what it should do when it's read. The most common action is to launch a game, but it can perform other actions like launching a random game or even making an HTTP request.

This text can be as simple as a path to a game file, or perform multiple custom commands in a row.

Setting Up Tokens

Zaparoo App

The Zaparoo App is a mobile app available on iOS and Android which can be used to generate commands using your phone. It can search for games stored on your device, and write a tag using your phone's NFC reader with the correct format. Tag writing functionality is available for free.

TapTUI

This is a frontend to the Zaparoo service which lets you write and interact with tokens in many advanced ways. It can browse and search games on the MiSTer to be written, and has an awesome command palette to build up more complex commands.

Launching Games

For the most basic usage, a file path can be written to a token and Zaparoo will attempt to find the file on the device and launch it. The required system and configuration for the game will be automatically selected based on the file path. On MiSTer, you can also launch arcade .mra files, shortcut .mgl files and core .rbf files with just their path.

Zaparoo uses the following rules, in order, to find the game file. Keep these rules in mind if you want a token to work well between different devices.

If you're not sure what to do, it's recommended to use the System Lookup method for the best portability between devices.

Absolute Path

Any path starting with a / will be treated as an absolute path.

For example, to launch a game, write something like this to the token:

/media/fat/games/Genesis/1 US - Q-Z/Some Game (USA, Europe).md

This is the least portable method, as it will only work on the device with the exact same file path.

Relative Path

It's also possible to use a file path relative to the games folder. This will search for the file in all standard MiSTer game folder paths including CIFS and USB.

For example:

Genesis/1 US - Q-Z/Some Game (USA, Europe).md

This saves storage space on the token and will work if one device has games stored on a USB drive and another on the SD card. There's no downside to using it compared to an absolute path.

Some other examples:

_Arcade/Some Arcade Game.mra

_@Favorites/My Favorite Game.mgl

.zip files are also supported natively, same as they are in MiSTer itself. Just treat the .zip file as a folder name:

Genesis/@Genesis - 2022-05-18.zip/1 US - Q-Z/Some Game (USA, Europe).md

System Lookup

This is similar to a relative path, but the first "folder" will be treated as a reference to a system instead of a folder. Like this: <System ID>/<Game Path>.

Check the Systems documentation for a list of supported system IDs.

For example:

N64/1 US - A-M/Another Game (USA).z64

While this looks like a relative path, it will work on any device with the same system folder structure, even if the Nintendo 64 folder does not have the same name. Zaparoo will look up the system ID and find the game file based on that.

System ID aliases (listed in the Systems page as well) can also be used here.

For example, this will work:

TurboGrafx16/Another Game (USA).pce

Or this:

tgfx16/Another Game (USA).pce

Or even this:

PCEngine/Another Game (USA).pce

While this method is basically the same as a relative path right now, as Zaparoo develops, we will be adding more features to this System Lookup method so it's not necessary to use explicit paths. It will also be important going forward as more devices are supported with different file structures.

Special Cases

Some systems have special cases and extra support implemented for their launching capabilities.

ao486

If a .vhd file is launched via Zaparoo, and this .vhd file is sitting in its own folder with an .iso or .chd file, that .iso or .chd file will also be automatically mounted alongside the .vhd file.

AmigaVision (Amiga)

Launching games in the AmigaVision image on the Amiga core is supported via the games.txt files and demos.txt files located in the Amiga/listings folder on your SD card.

For example, to launch Beneath a Stell Sky in AmigaVision:

Amiga/listings/games.txt/Beneath a Steel Sky (OCS)[en]

The games.txt and demos.txt files contain a listing of all supported games and demos, generated by AmigaVision, and can be treated as a virtual folder for launching via Zaparoo. Other games can be launched using the same format of Amiga/listings/games.txt/<Game Name>.

Opening the games.txt and demos.txt files in a text editor will show the full list of supported games and demos.

NeoGeo

NeoGeo also supports launching .zip files and folders directly with Zaparoo, as is supported with the MiSTer core itself.

For example, a .zip file:

NeoGeo/mslug.zip

Or a folder:

NeoGeo/mslug2

Combining Commands

All commands and game/core launches can be combined on a single token if space permits using the || separator.

For example, to switch to MiSTer.ini number 3 and launch the SNES core:

**mister.ini:3||_Console/SNES

Or launch a game and notify an HTTP service:

_Console/SNES||**http.get:https://example.com

As many of these can be combined as you like.

Custom Commands

There are a set of special commands that can be written to tokens to perform dynamic actions. These are marked in a token by putting ** at the start of the stored text.

Launching Media

Generic Launch (launch)

This command works exactly the same as the basic game launch behavior. It's just a more explicit way of doing it.

For example:

**launch:/media/fat/games/Genesis/1 US - Q-Z/Some Game (USA, Europe).md

Launch a System (launch.system)

This command will launch a system, based on MiSTer Extensions own internal list of system IDs. This can be useful for "meta systems" such as Atari 2600 and WonderSwan Color which don't have their own core .rbf file.

For example:

**launch.system:Atari2600

**launch.system:WonderSwanColor

It also works for any other system if you prefer this method over the standard core .rbf file one.

Launch a Random Game (launch.random)

This command will launch a game at random for the given system. For example:

**launch.random:snes

This will launch a random SNES game each time you read the token.

System IDs can also be combined with the , separator. For example:

**launch.random:snes,nes

This will launch a random game from either the SNES or NES systems. You can also select all systems with **launch.random:all.

An absolute path to a folder will pick a random file from that folder and attempt to launch it:

**launch.random:/media/fat/_#Favorites

This is useful for folder full of .mgl file on MiSTer.

A random game can also be chosen using the launch.search syntax. Instead of picking and launching the first result, Zaparoo will pick a random one:

**launch.random:Genesis/*sonic*

Search for and Launch Game (launch.search)

This command will search for a game with the given query by filename and launch the first result. The syntax of the command is similar to the generic launch command, but with the addition of "globbing" to create a fuzzy search query. For example:

**launch.search:SNES/*mario*

Will search for all SNES games with the word "mario" in the filename and launch the first result. Narrow it down:

**launch.search:SNES/super mario*(*usa*

To launch the US version of Super Mario something.

Search queries are case insensitive.

HTTP Requests

Make an HTTP GET Request to a URL (http.get)

Perform an HTTP GET request to the specified URL. For example:

**launch.random:snes,nes

This is useful for triggering webhooks or other web services.

It can be combined with other commands using the || separator. For example:

**http.get:https://example.com||_Console/SNES

If your URL contains any of the following characters, you must URL encode them by replacing them with the following:

  • , with %2C
  • || with %7C%7C
  • ** with %2A%2A

Make an HTTP POST Request to a URL (http.post)

Perform an HTTP POST request to the specified URL. For example:

**http.post:https://example.com,application/json,{"key":"value"}

Or with Remote, to launch the Update All script:

**http.post:http://localhost:8182/api/scripts/launch/update_all.sh,application/json,

The command is in the format URL,Content-Type,Body.

If your URL contains any of the following characters, you must URL encode them by replacing them with the following:

  • , with %2C
  • || with %7C%7C
  • ** with %2A%2A

Virtual Input Devices

Press a Keyboard Key (input.keyboard)

Press a key or multiple keys on a virtual keyboard attached to the host. One key:

**input.keyboard:@

Multiple keys in sequence:

**input.keyboard:qWeRty{enter}{up}aaa

Special keys can be entered by with a key name surrounded by curly braces ({}) as shown above. If you want to enter an literal curly brace, type a backslash before it like \{ and \}. Backslashes can also be escaped (\\).

Possible special key names are: esc, backspace, tab, enter, lctrl, lshift, backslash, rshift, lalt, space, caps, num, scroll, f1-f12, home, up pgup, left, right, end, down, pgdn, ins, del, volup, voldn.

Press a Gamepad Button (input.gamepad)

Press a button or multiple buttons in sequence on a virtual gamepad attached to the host.

This works the same as the input.keyboard command but with the following name mappings:

  • ^, {up}: Dpad up
  • V, {down}: Dpad down
  • <, {left}: Dpad left
  • >, {right}: Dpad right
  • A, a: East button
  • B, b: South button
  • X, x: North button
  • Y, y: West button
  • {start}: Start
  • {select}: Select
  • {menu}: Menu (Xbox/PlayStation/etc. button)
  • L, l, {l1}: Left bumper
  • R, r, {r1}: Right bumper
  • {l2}: Left trigger
  • {r2}: Right trigger

For example:

**input.gamepad:^^VV<><>BA{start}{select}

Be aware that this gamepad likely needs to be mapped manually first to work, and that it will show to the game as an additional controller not imitate an existing connected controller.

Insert a Coin/Credit (input.coinp1/input.coinp2)

Insert a coin/credit for player 1 or 2. For example (to insert 1 coin for player 1):

**input.coinp1:1

This command presses the 5 and 6 key on the keyboard respectively, which is generally accepted as the coin insert keys in MiSTer arcade cores. If it doesn't work, try manually mapping the coin insert keys in the OSD.

It also supports inserting multiple coins at once. For example (to insert 3 coins for player 2):

**input.coinp2:3

MiSTer

These commands are only available on the MiSTer platform.

Change the Active MiSTer.ini File (mister.ini)

Loads the specified MiSTer.ini file and relaunches the menu core if open. Specify the .ini file with its index in the list shown in the MiSTer menu. Numbers 1 to 4.

For example:

**mister.ini:1

This switch will not persist after a reboot, same as loading it through the OSD.

Launch a Core RBF File (mister.core)

This command will launch a MiSTer core .rbf file directly. For example:

**mister.core:_Console/SNES

Or:

**mister.core:_Console/PSX_20220518

It uses the exact same format as the rbf tag in a .mgl file, where the ending of a filename can be omitted. The path is relative to the SD card.

Launch a Script (mister.script)

It's possible to launch a MiSTer script which already exists on the MiSTer:

**mister.script:update_all.sh

Zaparoo will close the currently running game back to the menu core if necessary, then launch the script on screen as if it were launched from the Scripts menu. The script must exist already in /media/fat/Scripts or it won't be run.

Arguments to the script are allowed, just type them after the filename as you would on a shell. Arguments are escaped for security.

Utility Functions

Run a System/Linux Command (shell)

This feature is intentionally disabled for security reasons when run straight from a token. You can still use it by enabling the allow_commands option in the Zaparoo config file.

This command will run a MiSTer Linux command directly. For example:

**shell:reboot

Delay Command Execution (delay)

This command will delay the execution of the next command by the specified number of milliseconds. For example:

**delay:500

Will delay the next command by 500ms (half a second). This is a blocking command and will delay the entire token read by the specified time.

It can be combined with other commands using the || separator. For example, to launch SNES, wait 10 seconds, then press F12:

_Console/SNES||**delay:10000||**input.key:88