How to give your KDE application IR support under KDE.
======================================================

by Gav Wood, 2003.

Introduction
------------

All DCOP-using applications under KDE have basic lirc support, since TDELirc has
the ability to interface any button to any DCOP call. However, to give your
application the real professional touch when using it with TDELirc, I recommend
you create a profile for it.

A profile tells TDELirc (and the user!) what the various DCOP calls do.
Essentially this is a kind of documentation for the DCOP calls. You don't have
to include all DCOP calls - just the ones that you feel would benefit end-users
the most (usually "interface adjusting" calls rather the "information gathering"
calls).


Method
------

1. DCOP

The first thing to do is to give your application DCOP functionality. This is
*very* easy and essentially amounts to adding a declaration to each object you
want to give DCOP accessibility and adding an entry to your Makefile. I wont go
into it here as the KDE documentation already provides a suitable resource for
such information.

Ensure you provide a full accessibility to your application's interface by DCOP,
and especially in the case of IR-interfacing, try not to have functions with too
many parameters, or with exotic types (stick to ints and QStrings where
necessary).

2. Create a profile

Having coded the necessary DCOP functionality into your application, the only
other thing to do is describe how it works to the user. This is done by means of
a .profile.xml document, examples of which may be found in the tdelirc/profiles
directory. A quick guide is given here:

a) First create top level "profile" tags with the DCOP application id and KDE
service name (found in the .desktop file) as attributes of them:

	<?xml version="1.0" ?>
	<!DOCTYPE profile SYSTEM "profile.dtd">
	<profile id="myapp" servicename="My Application">
	</profile>

b) Inside populate with name and author information. If your application is not a
KUniqueApplication, you **must** declare this with an "instances" tag, giving the
attribute "unique" a value of "0" (it defaults to "1", a KUniqueApplication). You
may optionally describe the default behavior TDELirc should take should there be
more than one instance of the application, with the attribute "ifmulti" which may
take one of "dontsend" (do nothing if >1 instance), "sendtoone" (send call to one
arbitrarily chosen instance) and "sendtoall" (send to all instances). The default
is "dontsend", however, "sendtoone" may be the most useful in many circumstances.

	<?xml version="1.0" ?>
	<!DOCTYPE profile SYSTEM "profile.dtd">
	<profile id="myapp" servicename="My Application">
		<name>My Application</name>
		<author>Me</author>
		<instances unique="0" ifmulti="sendtoone"/>
	</profile>

c) Populate the profile with action tags, for each DCOP action you want to be
available to the user. Each action tag should have DCOP object name and function
prototype.
   Several optional attrubutes to specify are the key-class (an identifier to
act as an abstract binding between remote controls and applications). There are
several defined; see the DTD files for a current list. The other options, repeat
and autostart are boolean specificers to tell whether the action should repeat
or automatically start the program by default.

	<?xml version="1.0" ?>
	<!DOCTYPE profile SYSTEM "profile.dtd">
	<profile id="myapp" servicename="My Application">
		<name>My Application</name>
		<author>Me</author>
		<instances unique="0" ifmulti="sendtoone"/>
		<action objid="MyApp" prototype="void showint(short int)"
				class="number" repeat="0" autostart="0">
		</action>
	</profile>

d) Give the action a name and comment:

	<?xml version="1.0" ?>
	<!DOCTYPE profile SYSTEM "profile.dtd">
	<profile id="myapp" servicename="My Application">
		<name>My Application</name>
		<author>Me</author>
		<instances unique="0" ifmulti="sendtoone"/>
		<action objid="MyApp" prototype="void showints(short int)"
				class="number" repeat="0" autostart="0">
			<name>Show Integers</name>
			<comment>Shows a configurable integer</comment>
		</action>
	</profile>

e) Describe each argument with a comment and type attribute. Valid types are
found in the profile.dtd file. If you cant find the exact type, just use one
that is silently castable. You should declare a default value between the
default tags:

	<?xml version="1.0" ?>
	<!DOCTYPE profile SYSTEM "profile.dtd">
	<profile id="myapp" servicename="My Application">
		<name>My Application</name>
		<author>Me</author>
		<instances unique="0" ifmulti="sendtoone"/>
		<action objid="MyApp" prototype="void showints(short int)"
				class="number" repeat="0" autostart="0">
			<name>Show Integers</name>
			<comment>Shows a configurable integer</comment>
			<argument type="int">
				<default>5</default>
				<comment>The integer to be shown</comment>
			</argument>
		</action>
	</profile>

When you have created your profile.xml file, put in your project's main source
tree.

3. Profile installation

There is a data directory in KDE reserved for profiles such as these; it's path
is "$(kde_datadir)/profiles". These extra lines must therefore be added to your
Makefile.am in the directory of your profile.xml:

	profiledata_DATA = [YOURAPPHERE].profile.xml
	profiledatadir = $(kde_datadir)/profiles
	EXTRA_DIST = $(profiledata_DATA)

(replace [YOURAPPHERE] with your application name---the prefix to your
profile.xml file.)


4. Finished

That's it you're done! Your KDE application is now fully IR enabled.