Linproman's taskfile-format

Continue reading, if you want to create a .task-file for Linproman to run scripts on process- or systemevents on Linux:

Loading happens...

Format

It's just like other configfiles on your distribution or good 'ol inifiles: [section] key=value [processcondition[UID]] key=value If a key is missing, default values will be used, so you only need to write non-default values to the file.

Checkcycle

The tasks will be linked (to processes with matching PID or Name) and checked on the regular program-update you defined in Options»General, so the ticks may or may not be seconds.
The program will check processconditions first, then system ones, then tasks ones (process- and system- and tasksconditions can be mixed in a task, but tasksconnections are intended to be used to connect tasks and not be mixed. Don't you dare to report a bug if you mixed all that stuff and got in a kind of a kerfuffle!

Main - [main]

KeyTypeDefaultExplanation
name=stringErrorName for your task
description=string(empty)Put a description here, if you need more informations to remember what it does
scriptpathname=stringErrorFull path + filename to the script which should be executed when the conditions met
id=int64-1If you want to connect this tasks with others give it a unique number to identify
enabled=int(bool)false1=task enabled; 2=task disabled (only value which can also be set in the GUI)
conditionconnection=int00=and(all conditions must be true);1=or(one condition must be true) – value will always be set to 0 for taskconditions (because it would not make sense to or-connect tasks)
disableafterfiring=int(bool)false1=automatically disables the task after firing; 0=it won't do that
fired=int(bool)falseWill be set to 1 after firing by the program and written back to the taskfile
showintraymenu=int(bool)falseShow this task in trayicon's task-menu (for fast en/disable)
setupdatespeed=int32(ms)0Set the application update interval in ms. (This cannot exceed minimum and maximum from defines.inc)
example:
[main] name=example description=I wonder if I will ever again read this... scriptpathname=/script/path.name enabled=1

Processconditions - [processcondition[UID]]

UID = something unique (string or number). 2 or more sections with the same name would lead to kerfuffle (like destroying your fully armed and operational battle station).
It is possible to identify processes by ByPID or ByName+ByPath or ByWindowName.

KeyTypeDefaultExplanation
ByPID=int(list of integers)(empty)Process will be identified by the PID; You can define multiple PID, separated by |
ByName=string(empty)Processes will be identified by their name you can see in the treeview (case sensitive!)
All processes with that name will be linked to that processcondition, but the condition itself will be matched against one of them (See HandleAll to alter this).
ByNameStrict=int(bool)falseIf false: ByName must match a part of a processes' name, if true ByName must match exactly (like down to each character).
ByPath=string(empty)If the name is not unique, you can add the path you can see in Processform (case sensitive!)
ByWindowName=string(empty)Same as name, but for process' windowname (because it is slow only the following processes get their windowname allocated: java) (case sensitive!)
ByWindowNameStrict=int(bool)falseSame behaivior as the parameter for name.
ByCommandLine=string(empty)Same as ByName/ByPath, but for process' commandline (for wine or some such) - The matching is done for the substring, so passing an "exe-name" would be enough (case sensitive!)
HandleAll=int(bool)falseUnder normal circurstances (=false) conditions are checked against any of the matching id or name parameters. For example: If any of the processes killjimmy is using cpu above X, XTicks going up and the condition may become true.
If this parameter is set to true, all processes must be using cpu above X, before Xticks going up and the condition will become true.
ignore_if_parent_same_named=int(bool)1If the process has a parent with the exact same name it won't be linked - Use this for processes which spawn a lot of childs you don't want to handle (e.g. firefox, upscayl)
XTicks=int321How many ticks (in a row) the value has to be met before the condition becomes true - Value cannot be less than 1
condition=string(empty)See in the conditions-section
value=string(parsed to uint64)0You can enter integers or floats (Decimal separator depends on your systemconfiguration) You can add k, m,g or t to create bigger, readable values. Like "1,5g" which will be converted to 1,5 GiB (1024!)
script_parameters=string(empty)Pass additional parameters to your script (PID will be passed automatically as 1st parameter)
resettrueticksafterwards=int(bool)0If set to 1, the Xticks will be reset, if the condition gets true (to stop a continues row)

example:
[processcondition0] ByName=gnome-calculator XTicks=10 condition=alive

Systemconditions - [systemcondition[UID]]

(See about the UID up at processonditionpart)
Systemconditions can have the following same keys: XTicks=, resettrueticksafterwards=, condition=, value= and script_parameters= as processconditions, see documentation there for details. Of course the checkvalue and conditions are not against a process, but the whole system.
But it can also have specified keys:

KeyTypeDefaultExplanation
condition_IDparam=int-1If theres a specified (for example) battery you want to check put the ID here. If parameters missing in some cases all batteries or just one will be checked.

example:
[systemcondition0] XTicks=10 condition=cpu> value=50

Conditions

Processconditions check the condition against the process (for example how much CPU-percent the process uses), while the same action in a systemcondition would check how many CPU-percent the whole system uses.
ActionExplanation
Processconditions only:
alivetrue if process exists|If combined with HandleAll=1 all processes known need to be alive (if a new one appears, condition keeps beeing true, if one died, condition becomes false for one tick)
jstrue if process just started (Xticks will be ignored because it makes no sense here) - This only fires, if Linproman witness the creation of a process (so processes created before the applicationstart won't be handled as just created)
diedtrue if the process was brutally murdered (must have been alive for this to become true)
Both:
truealways true
falsealways false
cpu>true if cpu-use is above X percent
cpu<true if cpu-use is below X percent
hddr>true if devicereaddelta is above X bytes per tick
hddr<true if devicereaddelta is below X bytes per tick
hddw>true if devicewrittendelta is above X bytes per tick
hddw<true if devicewrittendelta is below X bytes per tick
netr>true if networkreceiceddelta is above X bytes per tick
netr<true if networkreceiveddelta is below X bytes per tick
nets>true if networkwrittendelta is above X bytes per tick
nets<true if networkwrittendelta is below X bytes per tick
ram>true if ramuse above X bytes
ram%>true if ramuse above X percent
swap>true if swapuse above X bytes
swap%>true if swapuse above X percent
Systemconditions only:
cputtrue if CPU is below throttle-speed (Options»General)
batctrue if one of the bats is charging (or BATID)
batdtrue if one of the bats is discharging (or BATID)
batftrue if one all the bats are full (or BATID)
bat%>true if average level of all the bats are above X percent (or BATID)
bat%<true if average level of all the bats are below X percent (or BATID)
batmodetrue if your device is running on battery

Taskconnections - [taskconnections]

No numbers in the section, because only one should exists in a taskfile!
With the section taskconnection you can specify a list of task-ids which should be all true (or connection wouldn't make sense) before this task becomes true itself. It's for connecting tasks. Linproman wont stop you combining this with process- and systemconditions, but that wasn't even tested once in development.

KeyExplanation
idlist=The list of the connected tasks separated by "|"

example:
[taskconnections] idlist=1|2|3|4

Full examples

Move mediainfo-gui and g-earth (which spawning always on monitor 1 to monitor 2):
[main] name=Move wrong spawning windows description=because they're programmed by Pakled scriptpathname=/home/lilstinky/scripts/linproman/move_pid_2_mainmonitor.sh enabled=1 conditionconnection=1 [processcondition0] ByName=mediainfo-gui condition=js [processcondition1] ByName=googleearth-bin condition=js script_parameters=googleearth
Kill Thunar if it is using to much cpu: [main] name=Stuck thunar description=Thunar using all cpu: https://gitlab.xfce.org/xfce/thunar/-/issues/510 scriptpathname=/home/lilstinky/scripts/linproman/warn_n_kill.sh enabled=1 [processcondition0] ByName=thunar condition=cpu> XTicks=120 resettrueticksafterwards=1 value=10 script_parameters=thunar
Shut down or stand-by a system when CPU and network-traffic is below a value: [main] name=Stand-by lazy system description=Sleep now! scriptpathname=/home/lilstinky/scripts/linproman/standby.sh enabled=1 disableafterfiring=1 [systemcondition0] XTicks=300 condition=cpu< value=10 [systemcondition1] XTicks=300 condition=netr< value=10k [systemcondition2] XTicks=300 condition=nets< value=10k
End the "helper-apps" Evolution leaves in RAM on exit (*-source-registry, *-calendar-factory and *-addressbook-factory): [main] name=Cleanup after Evolution description=End the nasty helper-apps Evolution leaves in RAM after it has ended scriptpathname=/home/lilstinky/scripts/linproman/cleanup_evolutionstuff.sh enabled=1 fired=0 [processcondition0] ByName=evolution ByNameStrict=1 HandleAll=1 resettrueticksafterwards=1 condition=died XTicks=10