]> git.saurik.com Git - apple/launchd.git/blame - launchd/src/liblaunch_public.h
launchd-258.18.tar.gz
[apple/launchd.git] / launchd / src / liblaunch_public.h
CommitLineData
e91b9f68
A
1/*
2 * Copyright (c) 2005 Apple Computer, Inc. All rights reserved.
3 *
ed34e3c3 4 * @APPLE_APACHE_LICENSE_HEADER_START@
e91b9f68 5 *
ed34e3c3
A
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
e91b9f68 9 *
ed34e3c3
A
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
e91b9f68
A
16 * limitations under the License.
17 *
ed34e3c3 18 * @APPLE_APACHE_LICENSE_HEADER_END@
e91b9f68
A
19 */
20#ifndef _LAUNCH_H_
21#define _LAUNCH_H_
22
ed34e3c3
A
23#include <mach/mach.h>
24#include <sys/cdefs.h>
e91b9f68
A
25#include <stddef.h>
26#include <stdbool.h>
27
5b0a4722
A
28#pragma GCC visibility push(default)
29
ed34e3c3
A
30__BEGIN_DECLS
31
32#ifdef __GNUC__
33#define __ld_normal __attribute__((__nothrow__))
34#define __ld_setter __attribute__((__nothrow__, __nonnull__))
35#define __ld_getter __attribute__((__nothrow__, __nonnull__, __pure__, __warn_unused_result__))
36#define __ld_iterator(x, y) __attribute__((__nonnull__(x, y)))
37#define __ld_allocator __attribute__((__nothrow__, __malloc__, __nonnull__, __warn_unused_result__))
38#else
39#define __ld_normal
40#define __ld_setter
41#define __ld_getter
42#define __ld_iterator(x, y)
43#define __ld_allocator
44#endif
45
e91b9f68
A
46
47#define LAUNCH_KEY_SUBMITJOB "SubmitJob"
48#define LAUNCH_KEY_REMOVEJOB "RemoveJob"
49#define LAUNCH_KEY_STARTJOB "StartJob"
50#define LAUNCH_KEY_STOPJOB "StopJob"
51#define LAUNCH_KEY_GETJOB "GetJob"
e91b9f68
A
52#define LAUNCH_KEY_GETJOBS "GetJobs"
53#define LAUNCH_KEY_CHECKIN "CheckIn"
54
55#define LAUNCH_JOBKEY_LABEL "Label"
56#define LAUNCH_JOBKEY_DISABLED "Disabled"
57#define LAUNCH_JOBKEY_USERNAME "UserName"
58#define LAUNCH_JOBKEY_GROUPNAME "GroupName"
59#define LAUNCH_JOBKEY_TIMEOUT "TimeOut"
5b0a4722 60#define LAUNCH_JOBKEY_EXITTIMEOUT "ExitTimeOut"
e91b9f68
A
61#define LAUNCH_JOBKEY_INITGROUPS "InitGroups"
62#define LAUNCH_JOBKEY_SOCKETS "Sockets"
ed34e3c3 63#define LAUNCH_JOBKEY_MACHSERVICES "MachServices"
5b0a4722 64#define LAUNCH_JOBKEY_MACHSERVICELOOKUPPOLICIES "MachServiceLookupPolicies"
e91b9f68 65#define LAUNCH_JOBKEY_INETDCOMPATIBILITY "inetdCompatibility"
ed34e3c3 66#define LAUNCH_JOBKEY_ENABLEGLOBBING "EnableGlobbing"
e91b9f68
A
67#define LAUNCH_JOBKEY_PROGRAMARGUMENTS "ProgramArguments"
68#define LAUNCH_JOBKEY_PROGRAM "Program"
69#define LAUNCH_JOBKEY_ONDEMAND "OnDemand"
ed34e3c3
A
70#define LAUNCH_JOBKEY_KEEPALIVE "KeepAlive"
71#define LAUNCH_JOBKEY_LIMITLOADTOHOSTS "LimitLoadToHosts"
72#define LAUNCH_JOBKEY_LIMITLOADFROMHOSTS "LimitLoadFromHosts"
73#define LAUNCH_JOBKEY_LIMITLOADTOSESSIONTYPE "LimitLoadToSessionType"
e91b9f68
A
74#define LAUNCH_JOBKEY_RUNATLOAD "RunAtLoad"
75#define LAUNCH_JOBKEY_ROOTDIRECTORY "RootDirectory"
76#define LAUNCH_JOBKEY_WORKINGDIRECTORY "WorkingDirectory"
e91b9f68
A
77#define LAUNCH_JOBKEY_ENVIRONMENTVARIABLES "EnvironmentVariables"
78#define LAUNCH_JOBKEY_USERENVIRONMENTVARIABLES "UserEnvironmentVariables"
e91b9f68
A
79#define LAUNCH_JOBKEY_UMASK "Umask"
80#define LAUNCH_JOBKEY_NICE "Nice"
5b0a4722
A
81#define LAUNCH_JOBKEY_HOPEFULLYEXITSFIRST "HopefullyExitsFirst"
82#define LAUNCH_JOBKEY_HOPEFULLYEXITSLAST "HopefullyExitsLast"
e91b9f68
A
83#define LAUNCH_JOBKEY_LOWPRIORITYIO "LowPriorityIO"
84#define LAUNCH_JOBKEY_SESSIONCREATE "SessionCreate"
5b0a4722 85#define LAUNCH_JOBKEY_STARTONMOUNT "StartOnMount"
e91b9f68
A
86#define LAUNCH_JOBKEY_SOFTRESOURCELIMITS "SoftResourceLimits"
87#define LAUNCH_JOBKEY_HARDRESOURCELIMITS "HardResourceLimits"
e91b9f68
A
88#define LAUNCH_JOBKEY_STANDARDOUTPATH "StandardOutPath"
89#define LAUNCH_JOBKEY_STANDARDERRORPATH "StandardErrorPath"
90#define LAUNCH_JOBKEY_DEBUG "Debug"
ed34e3c3 91#define LAUNCH_JOBKEY_WAITFORDEBUGGER "WaitForDebugger"
e91b9f68
A
92#define LAUNCH_JOBKEY_QUEUEDIRECTORIES "QueueDirectories"
93#define LAUNCH_JOBKEY_WATCHPATHS "WatchPaths"
94#define LAUNCH_JOBKEY_STARTINTERVAL "StartInterval"
95#define LAUNCH_JOBKEY_STARTCALENDARINTERVAL "StartCalendarInterval"
96#define LAUNCH_JOBKEY_BONJOURFDS "BonjourFDs"
ed34e3c3
A
97#define LAUNCH_JOBKEY_LASTEXITSTATUS "LastExitStatus"
98#define LAUNCH_JOBKEY_PID "PID"
5b0a4722
A
99#define LAUNCH_JOBKEY_THROTTLEINTERVAL "ThrottleInterval"
100#define LAUNCH_JOBKEY_LAUNCHONLYONCE "LaunchOnlyOnce"
101#define LAUNCH_JOBKEY_ABANDONPROCESSGROUP "AbandonProcessGroup"
f36da725
A
102#define LAUNCH_JOBKEY_POLICIES "Policies"
103
104#define LAUNCH_JOBPOLICY_DENYCREATINGOTHERJOBS "DenyCreatingOtherJobs"
e91b9f68
A
105
106#define LAUNCH_JOBINETDCOMPATIBILITY_WAIT "Wait"
107
ed34e3c3
A
108#define LAUNCH_JOBKEY_MACH_RESETATCLOSE "ResetAtClose"
109#define LAUNCH_JOBKEY_MACH_HIDEUNTILCHECKIN "HideUntilCheckIn"
110
111#define LAUNCH_JOBKEY_KEEPALIVE_SUCCESSFULEXIT "SuccessfulExit"
112#define LAUNCH_JOBKEY_KEEPALIVE_NETWORKSTATE "NetworkState"
113#define LAUNCH_JOBKEY_KEEPALIVE_PATHSTATE "PathState"
5b0a4722
A
114#define LAUNCH_JOBKEY_KEEPALIVE_OTHERJOBACTIVE "OtherJobActive"
115#define LAUNCH_JOBKEY_KEEPALIVE_OTHERJOBENABLED "OtherJobEnabled"
ed34e3c3 116
e91b9f68
A
117#define LAUNCH_JOBKEY_CAL_MINUTE "Minute"
118#define LAUNCH_JOBKEY_CAL_HOUR "Hour"
119#define LAUNCH_JOBKEY_CAL_DAY "Day"
120#define LAUNCH_JOBKEY_CAL_WEEKDAY "Weekday"
121#define LAUNCH_JOBKEY_CAL_MONTH "Month"
122
123#define LAUNCH_JOBKEY_RESOURCELIMIT_CORE "Core"
124#define LAUNCH_JOBKEY_RESOURCELIMIT_CPU "CPU"
125#define LAUNCH_JOBKEY_RESOURCELIMIT_DATA "Data"
126#define LAUNCH_JOBKEY_RESOURCELIMIT_FSIZE "FileSize"
127#define LAUNCH_JOBKEY_RESOURCELIMIT_MEMLOCK "MemoryLock"
128#define LAUNCH_JOBKEY_RESOURCELIMIT_NOFILE "NumberOfFiles"
129#define LAUNCH_JOBKEY_RESOURCELIMIT_NPROC "NumberOfProcesses"
130#define LAUNCH_JOBKEY_RESOURCELIMIT_RSS "ResidentSetSize"
131#define LAUNCH_JOBKEY_RESOURCELIMIT_STACK "Stack"
132
5b0a4722
A
133#define LAUNCH_JOBKEY_DISABLED_MACHINETYPE "MachineType"
134#define LAUNCH_JOBKEY_DISABLED_MODELNAME "ModelName"
135
e91b9f68
A
136#define LAUNCH_JOBSOCKETKEY_TYPE "SockType"
137#define LAUNCH_JOBSOCKETKEY_PASSIVE "SockPassive"
138#define LAUNCH_JOBSOCKETKEY_BONJOUR "Bonjour"
139#define LAUNCH_JOBSOCKETKEY_SECUREWITHKEY "SecureSocketWithKey"
140#define LAUNCH_JOBSOCKETKEY_PATHNAME "SockPathName"
aa59983a 141#define LAUNCH_JOBSOCKETKEY_PATHMODE "SockPathMode"
e91b9f68
A
142#define LAUNCH_JOBSOCKETKEY_NODENAME "SockNodeName"
143#define LAUNCH_JOBSOCKETKEY_SERVICENAME "SockServiceName"
144#define LAUNCH_JOBSOCKETKEY_FAMILY "SockFamily"
145#define LAUNCH_JOBSOCKETKEY_PROTOCOL "SockProtocol"
ab36757d 146#define LAUNCH_JOBSOCKETKEY_MULTICASTGROUP "MulticastGroup"
e91b9f68
A
147
148typedef struct _launch_data *launch_data_t;
149
150typedef enum {
151 LAUNCH_DATA_DICTIONARY = 1,
152 LAUNCH_DATA_ARRAY,
153 LAUNCH_DATA_FD,
154 LAUNCH_DATA_INTEGER,
155 LAUNCH_DATA_REAL,
156 LAUNCH_DATA_BOOL,
157 LAUNCH_DATA_STRING,
158 LAUNCH_DATA_OPAQUE,
159 LAUNCH_DATA_ERRNO,
ed34e3c3 160 LAUNCH_DATA_MACHPORT,
e91b9f68
A
161} launch_data_type_t;
162
ed34e3c3
A
163launch_data_t launch_data_alloc(launch_data_type_t) __ld_allocator;
164launch_data_t launch_data_copy(launch_data_t) __ld_allocator;
165launch_data_type_t launch_data_get_type(const launch_data_t) __ld_getter;
166void launch_data_free(launch_data_t) __ld_setter;
e91b9f68
A
167
168/* Generic Dictionaries */
169/* the value should not be changed while iterating */
ed34e3c3
A
170bool launch_data_dict_insert(launch_data_t, const launch_data_t, const char *) __ld_setter;
171launch_data_t launch_data_dict_lookup(const launch_data_t, const char *) __ld_getter;
172bool launch_data_dict_remove(launch_data_t, const char *) __ld_setter;
173void launch_data_dict_iterate(const launch_data_t, void (*)(const launch_data_t, const char *, void *), void *) __ld_iterator(1, 2);
174size_t launch_data_dict_get_count(const launch_data_t) __ld_getter;
e91b9f68
A
175
176/* Generic Arrays */
ed34e3c3
A
177bool launch_data_array_set_index(launch_data_t, const launch_data_t, size_t) __ld_setter;
178launch_data_t launch_data_array_get_index(const launch_data_t, size_t) __ld_getter;
179size_t launch_data_array_get_count(const launch_data_t) __ld_getter;
180
181launch_data_t launch_data_new_fd(int) __ld_allocator;
182launch_data_t launch_data_new_machport(mach_port_t) __ld_allocator;
183launch_data_t launch_data_new_integer(long long) __ld_allocator;
184launch_data_t launch_data_new_bool(bool) __ld_allocator;
185launch_data_t launch_data_new_real(double) __ld_allocator;
186launch_data_t launch_data_new_string(const char *) __ld_allocator;
187launch_data_t launch_data_new_opaque(const void *, size_t) __ld_allocator;
188
189bool launch_data_set_fd(launch_data_t, int) __ld_setter;
190bool launch_data_set_machport(launch_data_t, mach_port_t) __ld_setter;
191bool launch_data_set_integer(launch_data_t, long long) __ld_setter;
192bool launch_data_set_bool(launch_data_t, bool) __ld_setter;
193bool launch_data_set_real(launch_data_t, double) __ld_setter;
194bool launch_data_set_string(launch_data_t, const char *) __ld_setter;
195bool launch_data_set_opaque(launch_data_t, const void *, size_t) __ld_setter;
196
197int launch_data_get_fd(const launch_data_t) __ld_getter;
198mach_port_t launch_data_get_machport(const launch_data_t) __ld_getter;
199long long launch_data_get_integer(const launch_data_t) __ld_getter;
200bool launch_data_get_bool(const launch_data_t) __ld_getter;
201double launch_data_get_real(const launch_data_t) __ld_getter;
202const char * launch_data_get_string(const launch_data_t) __ld_getter;
203void * launch_data_get_opaque(const launch_data_t) __ld_getter;
204size_t launch_data_get_opaque_size(const launch_data_t) __ld_getter;
205int launch_data_get_errno(const launch_data_t) __ld_getter;
e91b9f68
A
206
207
208/* launch_get_fd()
209 *
210 * Use this to get the FD if you're doing asynchronous I/O with select(),
211 * poll() or kevent().
212 */
ed34e3c3 213int launch_get_fd(void) __ld_normal;
e91b9f68
A
214
215/* launch_msg()
216 *
217 * Use this API to send and receive messages.
218 * Calling launch_msg() with no message to send is a valid way to get
219 * asynchronously received messages.
220 *
221 * If a message was to be sent, it returns NULL and errno on failure.
222 *
223 * If no messages were to be sent, it returns NULL and errno is set to zero if
224 * no more asynchronous messages are available.
225 */
ed34e3c3
A
226launch_data_t launch_msg(const launch_data_t) __ld_normal;
227
228__END_DECLS
e91b9f68 229
5b0a4722
A
230#pragma GCC visibility pop
231
e91b9f68 232#endif