libamxp  1.4.0
Patterns C Implementation
amxp_subproc.h
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** SPDX-License-Identifier: BSD-2-Clause-Patent
4 **
5 ** SPDX-FileCopyrightText: Copyright (c) 2023 SoftAtHome
6 **
7 ** Redistribution and use in source and binary forms, with or without modification,
8 ** are permitted provided that the following conditions are met:
9 **
10 ** 1. Redistributions of source code must retain the above copyright notice,
11 ** this list of conditions and the following disclaimer.
12 **
13 ** 2. Redistributions in binary form must reproduce the above copyright notice,
14 ** this list of conditions and the following disclaimer in the documentation
15 ** and/or other materials provided with the distribution.
16 **
17 ** Subject to the terms and conditions of this license, each copyright holder
18 ** and contributor hereby grants to those receiving rights under this license
19 ** a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable
20 ** (except for failure to satisfy the conditions of this license) patent license
21 ** to make, have made, use, offer to sell, sell, import, and otherwise transfer
22 ** this software, where such license applies only to those patent claims, already
23 ** acquired or hereafter acquired, licensable by such copyright holder or contributor
24 ** that are necessarily infringed by:
25 **
26 ** (a) their Contribution(s) (the licensed copyrights of copyright holders and
27 ** non-copyrightable additions of contributors, in source or binary form) alone;
28 ** or
29 **
30 ** (b) combination of their Contribution(s) with the work of authorship to which
31 ** such Contribution(s) was added by such copyright holder or contributor, if,
32 ** at the time the Contribution is added, such addition causes such combination
33 ** to be necessarily infringed. The patent license shall not apply to any other
34 ** combinations which include the Contribution.
35 **
36 ** Except as expressly stated above, no rights or licenses from any copyright
37 ** holder or contributor is granted under this license, whether expressly, by
38 ** implication, estoppel or otherwise.
39 **
40 ** DISCLAIMER
41 **
42 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
43 ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44 ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 ** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
46 ** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
48 ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
49 ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
50 ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
51 ** USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
52 **
53 ****************************************************************************/
54 
55 
56 #if !defined(__AMXP_SUBPROC_H__)
57 #define __AMXP_SUBPROC_H__
58 
59 #ifdef __cplusplus
60 extern "C"
61 {
62 #endif
63 
64 #include <sys/types.h>
65 #include <amxc/amxc_llist.h>
66 #include <amxp/amxp_signal.h>
67 
87 typedef struct _subproc_t {
88  amxc_llist_it_t it;
89  pid_t pid;
90  bool is_running;
91  int fd[3][2];
95  int status;
97 
116 int amxp_subproc_new(amxp_subproc_t** subproc);
117 
131 int amxp_subproc_delete(amxp_subproc_t** subproc);
132 
147 int amxp_subproc_open_fd(amxp_subproc_t* subproc, int requested);
148 
172 int amxp_subproc_vstart(amxp_subproc_t* const subproc,
173  char** argv);
174 
197 int amxp_subproc_start(amxp_subproc_t* const subproc,
198  char* cmd,
199  ...);
200 
235 int amxp_subproc_astart(amxp_subproc_t* const subproc,
236  amxc_array_t* cmd);
237 
261 int amxp_subproc_kill(const amxp_subproc_t* const subproc, const int sig);
262 
279 int amxp_subproc_wait(amxp_subproc_t* subproc, int timeout_msec);
280 
303 int amxp_subproc_vstart_wait(amxp_subproc_t* subproc, int timeout_msec, char** cmd);
304 
327 int amxp_subproc_start_wait(amxp_subproc_t* subproc, int timeout_msec, char* cmd, ...);
328 
344 amxp_subproc_t* amxp_subproc_find(const int pid);
345 
359 pid_t amxp_subproc_get_pid(const amxp_subproc_t* const subproc);
360 
381 
394 bool amxp_subproc_is_running(const amxp_subproc_t* const subproc);
395 
410 
426 
442 
457 
458 #ifdef __cplusplus
459 }
460 #endif
461 
462 #endif // __AMXP_SUBPROC_H__
Ambiorix signal manager and signal API header file.
amxp_subproc_t * amxp_subproc_find(const int pid)
Retrieve a amxp_subproc_t for a child process using it's process identifier.
Definition: amxp_subproc.c:402
int amxp_subproc_open_fd(amxp_subproc_t *subproc, int requested)
Opens standard file descriptor to the child process.
Definition: amxp_subproc.c:263
bool amxp_subproc_is_running(const amxp_subproc_t *const subproc)
Checks if the child process is running.
Definition: amxp_subproc.c:423
int amxp_subproc_new(amxp_subproc_t **subproc)
Constructor function, creates a new child process data structure.
Definition: amxp_subproc.c:215
int amxp_subproc_get_exitstatus(amxp_subproc_t *subproc)
Gets the exit code of the child process.
Definition: amxp_subproc.c:537
int amxp_subproc_start(amxp_subproc_t *const subproc, char *cmd,...)
Start a child process.
Definition: amxp_subproc.c:330
int amxp_subproc_kill(const amxp_subproc_t *const subproc, const int sig)
Sends a Linux signal to the child process.
Definition: amxp_subproc.c:391
int amxp_subproc_ifexited(amxp_subproc_t *subproc)
Checks if the child process terminated normally.
Definition: amxp_subproc.c:517
int amxp_subproc_start_wait(amxp_subproc_t *subproc, int timeout_msec, char *cmd,...)
Starts a child process and waits until it exits.
Definition: amxp_subproc.c:480
int amxp_subproc_wait(amxp_subproc_t *subproc, int timeout_msec)
Waits until the child process has stopped.
Definition: amxp_subproc.c:428
int amxp_subproc_vstart(amxp_subproc_t *const subproc, char **argv)
Start a child process.
Definition: amxp_subproc.c:288
int amxp_subproc_vstart_wait(amxp_subproc_t *subproc, int timeout_msec, char **cmd)
Starts a child process and waits until it exits.
Definition: amxp_subproc.c:466
int amxp_subproc_astart(amxp_subproc_t *const subproc, amxc_array_t *cmd)
Start a child process.
Definition: amxp_subproc.c:365
int amxp_subproc_ifsignaled(amxp_subproc_t *subproc)
Checks if the child process was stopped because of an uncaught Linux signal.
Definition: amxp_subproc.c:527
struct _subproc_t amxp_subproc_t
Child process information structure.
amxp_signal_mngr_t * amxp_subproc_get_sigmngr(const amxp_subproc_t *const subproc)
Get the Signal managers of the child process.
Definition: amxp_subproc.c:419
int amxp_subproc_get_termsig(amxp_subproc_t *subproc)
Gets the Linux signal id that caused the child process to stop.
Definition: amxp_subproc.c:547
int amxp_subproc_delete(amxp_subproc_t **subproc)
Destructor function, deletes a child process data structure.
Definition: amxp_subproc.c:239
pid_t amxp_subproc_get_pid(const amxp_subproc_t *const subproc)
Get the PID of a child process.
Definition: amxp_subproc.c:415
Structure containing the signal manager information.
Definition: amxp_signal.h:103
Child process information structure.
Definition: amxp_subproc.h:87
amxp_signal_mngr_t * sigmngr
Definition: amxp_subproc.h:93
amxc_llist_it_t it
Definition: amxp_subproc.h:88
int fd[3][2]
Definition: amxp_subproc.h:91
bool is_running
Definition: amxp_subproc.h:90