]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/tools/build/src/engine/execcmd.h
2 * Copyright 1993, 1995 Christopher Seiwald.
4 * This file is part of Jam - see jam.c for Copyright information.
8 * execcmd.h - execute a shell script.
10 * Defines the interface to be implemented in platform specific implementation
11 * modules as well as different shared utility functions prepared in the
20 #include "jam_strings.h"
21 #include "timestamp.h"
24 typedef struct timing_info
32 typedef void (* ExecCmdCallback
)
36 timing_info
const * const,
37 char const * const cmd_stdout
,
38 char const * const cmd_stderr
,
39 int const cmd_exit_reason
42 /* Global initialization. Must be called after setting
43 * globs.jobs. May be called multiple times. */
44 void exec_init( void );
46 void exec_done( void );
48 /* Status codes passed to ExecCmdCallback routines. */
50 #define EXEC_CMD_FAIL 1
51 #define EXEC_CMD_INTR 2
55 string
const * command
,
57 int32_t * error_length
,
58 int32_t * error_max_length
61 /* exec_check() return codes. */
62 #define EXEC_CHECK_OK 101
63 #define EXEC_CHECK_NOOP 102
64 #define EXEC_CHECK_LINE_TOO_LONG 103
65 #define EXEC_CHECK_TOO_LONG 104
67 /* Prevents action output from being written
68 * immediately to stdout/stderr.
70 #define EXEC_CMD_QUIET 1
74 string
const * command
,
84 /******************************************************************************
86 * Utility functions defined in the execcmd.c module. *
88 ******************************************************************************/
90 /* Constructs a list of command-line elements using the format specified by the
93 void argv_from_shell( char const * * argv
, LIST
* shell
, char const * command
,
96 /* Interrupt routine bumping the internal interrupt counter. Needs to be
97 * registered by platform specific exec*.c modules.
99 void onintr( int disp
);
101 /* Returns whether an interrupt has been detected so far. */
102 int interrupted( void );
104 /* Checks whether the given shell list is actually a request to execute raw
105 * commands without an external shell.
107 int is_raw_command_request( LIST
* shell
);
109 /* Utility worker for exec_check() checking whether all the given command lines
110 * are under the specified length limit.
112 int check_cmd_for_too_long_lines( char const * command
, int32_t max
,
113 int32_t * const error_length
, int32_t * const error_max_length
);
115 /* Maximum shell command line length.
117 int32_t shell_maxline();