kAnyRemote
Prev
Next

Description of configuration file format (Server-style)

Since version 2.0 format of configurational file was changed. Description of format of configurational file for versions 1.X could be found here.

You may find some predefined configuration files in cfg-examples/Server-style directory:

You may find some predefined configuration files for Bemused emulation in cfg-examples/Bemused-emulation directory:

All examples have on-screen help binded to "* *" (press "*" two times).

I hope after investigation of these configuration files You'll become more familiar with its format. Description of that format could be found in file cfg-examples/conf-file-explanation.cfg

Description of configurational file format (Server-style):

AutoRepeat=false

Auto repeat feature (as on PC keyboard - about 10 events per second). Usefull for mouse emulation, for example. Default value is false.

Baudrate=19200

Baudrate to use; default value is 19200

Device=bluetooth:10

Device to connect; default value is /dev/rfcomm0.

If kAnyRemote works as server correct value for Device could be: Device=socket:"port" or Device=bluetooth:"channel"or just Device=bluetooth (to choose first available channel).

Log=true

Print or not to print logging info to the file /tmp/kanyremote.log, default value is false.

Debug=true

Print or not to print verbose logging info to the file /tmp/kanyremote.log, default value is true.Works only if Log=true.

Screen=true

Send or don't send any commands (SetStatus(), SetTitle(), etc.) to phone. Default value is false.

[Aliases] section

Format:

Key_Code=New_alias

and then use "One" in [Keys] section instead of "1" or "49"

[Keys] section

A short example:

Format:

Key_Codes=Command1;Command2;Command3;....

Where CommandX could be:

Exec() command

It is possible to define multi-key commands

It is not good idea to define:

simultaneously, since only one command will works (which one - depends on search order).

It is possible to group keymappings in so-called "mode" to set more than one command to the key:

It is possible to write rather complex commands inside Exec(), for example:

Set() command

This command used to control GUI of Java client. It is possible to change: caption of screen, title and status fields, arrange icons from predefined icon set and to show some text on the screen of cell phone.

Thare are several ways to use this command:

Set(icons, ...)

Format: SetI(icons,caption,1,name1,2,name2...,*,name11,#,name12)

where nameX specifies desired action. This command sets the caption of Java client window and reports to Java client to dynamically change shown icons.

if You do not want to change the caption of Java client window then it is possible to write:

Set(title, ...)

Format: Set(title, new_title)

This command set the title field of Java client

Set(status, ...)

Format: Set(status, new_status) This command set the status field of Java client

Set(text, ...)

Format: Set(help, title, _long_text_) This command shows help test on the screenof cell phone.

It is possible to add line break characters to the text. It could be done with "\n". The length of the text which can transferred to phone limited by Java realization in the phone. Anyway 1/2 Kbyte should be handled properly.

ExecAndSet()

Format: ExecAndSet(tag,command)

This command similar to the Set(), but uses the output of command specified as a string to set GUI element of Java client specified in tag field..

Timer()

Format: Timer(timerId, timeout, maxTimes, tag, command)

This command similar to the ExecAndSet(), but it will be executed peridicallly by timer.

For example, the following command run 'dcop amarok player nowPlaying' command 2 times with timeout equal to 5 sec and set result to the title field of Java client:

The following command run 'date' command every 10 sec and set result to the status field of Java client:

It is impossible to have two active timer commands with the same timerId. If results of the executed command is the same as previous one, then results will not be sent to Java client.

CancelTimerCmd()

Format: CancelTimetCmd(timerId)

This command deletes timer previously created by Timer() command by specified timerId.

The following commands used mainly in Bemused-emulation:

Send()

Format: Send(string, string_value)

or Send(byte, byte_value1, byte_value2,...)

Send to the Java client specified string or sequence of bytes. This command is used mainly in Bemused server emulation.

byte_valueX is string representation of 1 - 255 values. Send(byte, ...) command sends to the Java client specified bytes of data, one by one. Mainly this command is used to Bemused server emulation.

ExecAndSend()

Format: ExecAndSend(tag,command)

This command similar to the Send(tag, ...), but uses the output of command specified as a string to send. This command is used mainly in Bemused server emulation.

There are several "internal" commands:

TempDisconnect used to temporary (1 minute) disconnecting from phone:

Exit command used to exit from application:

Switch off "remote control" functionality without disconnecting:

Switch on "remote control" functionality:

Change mode:

There are several "events" could be triggered:

(Init) event will be fired when anyRemote is initialized:

(Connect) event will be fired when connection established:

(Disconnect) event will be fired when connection is lost:

If mode is changed by SetMode() then (ExitMode) event for current mode and (EnterMode) event for the new mode will be fired:

Auto-lock example:

Variable substitution:

Current time will be substituted instead of $(Time):

Current mode be substituted instead of $(Mode):

[Alarms] section

Format:

Alarm_file=command1;command2;...

When file Alarm_file will be created, then command1, command2 ... will be executed.



Prev
Next
Home