annotate sciworkerd/task.h @ 50:b474f0985e39

scictl: add API key support
author David Demelier <markand@malikania.fr>
date Wed, 17 Aug 2022 09:11:58 +0200
parents e52c762d8ba8
children 71cd8447e3a4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
1 /*
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
2 * task.h -- worker task management
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
3 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
4 * Copyright (c) 2021-2022 David Demelier <markand@malikania.fr>
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
5 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
8 * copyright notice and this permission notice appear in all copies.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
9 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
17 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
18
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #ifndef SCIWORKERD_TASK_H
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
20 #define SCIWORKERD_TASK_H
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
21
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
22 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
23 * \file task.h
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
24 * \brief Worker task management.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
25 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
26
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 #include <sys/types.h>
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
28
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 struct pollfd;
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
30 struct task;
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
31
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
32 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
33 * \brief Task status.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
34 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 enum taskstatus {
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
36 TASKSTATUS_PENDING, /*!< not started yet. */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
37 TASKSTATUS_RUNNING, /*!< currently running. */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
38 TASKSTATUS_EXITED, /*!< process exited normally. */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
39 TASKSTATUS_KILLED /*!< process killed killed. */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
40 };
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
41
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
42 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
43 * \brief Task termination code.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
44 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
45 struct taskcode {
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
46 int exitcode; /*!< Normal exit code (if sigcode == 0). */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
47 int sigcode; /*!< Signal termination code (exitcode == 0). */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
48 };
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
49
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
50 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
51 * Construct a new task with the given tag.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
52 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
53 * The task is just initialized, you need to call setup and start before
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
54 * continuing
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
55 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
56 * \pre tag != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
57 * \param tag the task tag
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
58 * \return a new initialized task
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
59 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
60 struct task *
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents: 18
diff changeset
61 task_new(const char *tag);
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
62
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
63 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
64 * Create a temporary file containing the script code to execute for this task.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
65 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
66 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
67 * \pre script != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
68 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
69 * \param script the script code to execute
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
70 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
71 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 int
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 task_setup(struct task *self, const char *script);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
74
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
75 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
76 * Fork the process to start the task.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
77 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
78 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
79 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
80 * \return the child PID on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
81 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
82 pid_t
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
83 task_start(struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
84
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
85 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
86 * Wait for the task to complete.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
87 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
88 * You should usually call this function when you're sure that the task is over
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
89 * otherwise it would block until it's complete.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
90 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
91 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
92 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
93 * \return 0 on success or -1 one error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
94 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
95 int
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
96 task_wait(struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
97
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
98 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
99 * Send a termination signal to the task.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
100 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
101 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
102 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
103 * \return 0 on success or -1 one error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
104 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
105 int
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
106 task_kill(struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
107
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
108 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
109 * Prepare the pollfd structure with the task pipe.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
110 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
111 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
112 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
113 * \param fd the pollfd structure to fill
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
114 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
115 void
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
116 task_prepare(struct task *self, struct pollfd *fd);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
117
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
118 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
119 * Synchronize the child output.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
120 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
121 * The following return values are possible:
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
122 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
123 * == 0: child exited
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
124 * >= 0: data has been received, keep going
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
125 * < 0: I/O error, you should kill and wait
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
126 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
127 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
128 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
129 * \param fd the pollfd structure result
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
130 * \return various condition as described
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
131 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
132 int
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
133 task_sync(struct task *self, const struct pollfd *fd);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
134
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
135 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
136 * Tells when the task has been started.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
137 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
138 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
139 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
140 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
141 time_t
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
142 task_uptime(const struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
143
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
144 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
145 * Returns the task PID.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
146 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
147 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
148 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
149 * \return the task PID
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
150 * \warning the task must be running
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
151 */
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents: 18
diff changeset
152 pid_t
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents: 18
diff changeset
153 task_pid(const struct task *self);
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents: 18
diff changeset
154
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
155 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
156 * Return the task console output.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
157 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
158 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
159 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
160 * \return the console output or NULL if none
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
161 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
162 const char *
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
163 task_console(const struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
164
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
165 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
166 * Get the task status.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
167 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
168 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
169 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
170 * \return the current task status
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
171 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
172 enum taskstatus
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
173 task_status(const struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
174
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
175 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
176 * Get the task exit or signal code
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
177 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
178 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
179 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
180 * \return the task exit/signal codes
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
181 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
182 struct taskcode
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
183 task_code(const struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
184
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
185 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
186 * Free the task and its resources.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
187 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
188 * \pre self != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
189 * \param self the task object
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
190 * \warning the task must not be running
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
191 */
18
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
192 void
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
193 task_free(struct task *self);
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
194
600204c31bf0 misc: refactor
David Demelier <markand@malikania.fr>
parents:
diff changeset
195 #endif /* !SCIWORKERD_TASK_H */