I'm writing an application which will potentially be invoked by more than one launchd
job – that is, there might be two distinct LaunchAgent .plist
files which invoke the application with different program arguments or in different conditions. I'd like the application to be able to examine the job, or the job's .plist
, so it can adjust its behaviour based on what it finds there.
In particular, supposing a program foo
could be started up from both A.plist
and B.plist
, I'd like the program to be able to preserve different state depending on which job/plist invoked it. If all I can do is detect the (presumed distinct) Label
of the job, that will be enough (though more would be better).
The obvious ways to do this are using different flags in the ProgramArguments
array in the job, or to set different values in EnvironmentVariables
, but both of those feel fragile, both imply duplication of bits of configuration, and both require extra documentation (“copy the value of the Label
into EnvironmentVariables
field FOO
...; don't ask why”).
I can see the function SMJobCopyDictionary
. With that, it appears that I can get access to the job's dictionary – ie, this information is available in principle – but I need to know the job's label first. Function SMCopyAllJobDictionaries
allows me to iterate through all of the jobs, but it's not obvious how I'd find the one which invoked a particular instance of the application.
Googling launchd read job label
or launchd self dict
(or similar) don't come up with anything useful.
Take a look at the SampleD code on Apple's site. This code shows how daemon's can access calling launchd information.
Looking at the launch.h header, I suspect
LAUNCH_JOBKEY_LABEL
is what you are after.