Scriptlets
As part of the Universal Hotfix released with Winterbreak, a method of running programs was introduced: Scriptlets
Scriptlets are handled by the SH_Integration.
Essentially, any .sh
file in the Kindle’s documents
folder (/mnt/us/documents
) will be indexed as though it were a book and get added to the library.
From here, it can be clicked on to run it.
Scriptlet Metadata
How these Scriptlets appear can be customised in the file itself by adding specific lines to the start of the file:
#!/bin/sh
# Name: Test Script
# Author: Hackerdude
echo "Hello, World!"
When this Scriptlet is added to a Kindle, it will appear in the library with the name of Test Script
and the author of Hackerdude
.
Icons
Scriptlets can be given an Icon via the # Icon:
flag, the value can either be an absolute path to the image file, or a base64 encoded image as shown:
#!/bin/sh
# Name: KoReader
# Author: Hackerdude
# Icon: 
echo "Hello, World!"
Note that some converters use the wrong filetype when generating the base64 string, ensure the filetype matches the actual data
Hooks
The # UseHooks
flag allows Scriptlets to have functions that are called when certain events happen to the Scriptlet, as opposed to the entire script being called once when it is ran:
#!/bin/sh
# Name: Test For Evnets
# Author: HackerDude
# UseHooks
on_install() {
echo "on_install called!" >> /mnt/us/test.log
}
on_remove() {
echo "on_remove called!" >> /mnt/us/test.log
}
on_run() {
echo "on_run called!" >> /mnt/us/test.log
}
DontUseFbink
By default, the script’s stdout and stderr are both piped to FBink to display on the Kindle, if you do not want this behaviour, then add the # DontUseFBInk
flag to your script as such:
#!/bin/sh
# Name: Silent Script
# Author: HackerDude
# DontUseFBInk
echo "A user won't see this"
Examples
For more Scriptlet examples or to share your own, please check the scriptlets
channel in the Kindle Modding Community Discord server.