Provided by: rofi_1.7.1-0.1_amd64 bug

NAME

       rofi script mode - Rofi format for scriptable modi.

DESCRIPTION

       rofi  supports  modes  that  use  simple  scripts in the background to generate a list and
       process the result from user actions.  This provide a  simple  interface  to  make  simple
       extensions to rofi.

USAGE

       To specify a script mode, set a mode with the following syntax: "{name}:{executable}"

       For example:

              rofi -show fb -modi "fb:file_browser.sh"

       The name should be unique.

API

       Rofi  calls  the  executable without arguments on startup.  This should generate a list of
       options, separated by a newline (\n) (This can be changed by the  script).   If  the  user
       selects  an  option,  rofi  calls the executable with the text of that option as the first
       argument.  If the script returns no entries, rofi quits.

       A simple script would be:

              #!/usr/bin/env bash

              if [ x"$@" = x"quit" ]
              then
                  exit 0
              fi
              echo "reload"
              echo "quit"

       This shows two entries, reload and quit. When the quit entry is selected, rofi closes.

Environment

       Rofi sets the following environment variable when executing the script:

   ROFI_RETV
       An integer number with the current state:

              • 0: Initial call of script.

              • 1: Selected an entry.

              • 2: Selected a custom entry.

              • 10-28: Custom keybinding 1-19 ( need to be explicitly enabled by script ).

   ROFI_INFO
       Environment get set when selected entry get set with the property value of the 'info'  row
       option, if set.

Passing mode options

       Extra options, like setting the prompt, can be set by the script.  Extra options are lines
       that start with a NULL character (\0) followed by a key, separator (\x1f) and value.

       For example to set the prompt:

                  echo -en "\0prompt\x1fChange prompt\n"

       The following extra options exists:

              • prompt:      Update the prompt text.

              • message:     Update the message text.

              • markup-rows: If 'true' renders markup in the row.

              • urgent:      Mark rows as urgent. (for syntax see  the  urgent  option  in  dmenu
                mode)

              • active:       Mark  rows  as  active.  (for syntax see the active option in dmenu
                mode)

              • delim:       Set the delimiter for for next rows. Default is '\n' and this option
                should finish with this. Only call this on first call of script, it is remembered
                for consecutive calls.

              • no-custom:   If set to 'true'; only accept listed entries, ignore custom input.

              • use-hot-keys: If set to true, it  enabled  the  Custom  keybindings  for  script.
                Warning this breaks the normal rofi flow.

Parsing row options

       Extra options for individual rows can be set.  The extra option can be specified following
       the same syntax as mode option, but following the entry.

       For example:

                  echo -en "aap\0icon\x1ffolder\n"

       The following options are supported:

              • icon: Set the icon for that row.

              • meta: Specify invisible search terms.

              • nonselectable: If true the row cannot activated.

              • info: Info that, on selection, gets placed in the ROFI_INFO environment variable.
                This entry does not get searched.

       multiple entries can be passed using the \x1f separator.

                  echo -en "aap\0icon\x1ffolder\x1finfo\x1ftest\n"

Executing external program

       If  you  want  to  launch an external program from the script, you need to make sure it is
       launched in the background.  If not rofi will wait for its output (to display).

       In bash the best way to do this is using coproc.

               coproc ( myApp  > /dev/null  2>1 )

DASH shell

       If you use the dash shell for your script, take special care with how dash handles escaped
       values for the separators.  See issue #1201 on github.

SEE ALSO

       rofi(1), rofi-sensible-terminal(1), dmenu(1), rofi-theme(5), rofi-theme-selector(1)

AUTHOR

       Qball Cow qball@gmpclient.orgmailto:qball@gmpclient.org⟩

       Rasmus Steinke rasi@xssn.atmailto:rasi@xssn.at⟩

       Quentin Glidic sardemff7+rofi@sardemff7.net ⟨mailto:sardemff7+rofi@sardemff7.net⟩

       Original    code    based    on    work    by:    Sean    Pringle   sean.pringle@gmail.commailto:sean.pringle@gmail.com⟩

       For a full list of authors, check the AUTHORS file.

                                           rofi-script                             ROFI-SCRIPT(5)