NeoMutt  2025-12-11-694-ga89709
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
filter.h File Reference

Pass files through external commands (filters) More...

#include <stdio.h>
#include <sys/types.h>
+ Include dependency graph for filter.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define EXEC_SHELL   "/bin/sh"
 Default shell to use for executing commands.
 

Functions

pid_t filter_create (const char *cmd, FILE **fp_in, FILE **fp_out, FILE **fp_err, char **envlist)
 Set up filter program.
 
pid_t filter_create_fd (const char *cmd, FILE **fp_in, FILE **fp_out, FILE **fp_err, int fdin, int fdout, int fderr, char **envlist)
 Run a command on a pipe (optionally connect stdin/stdout)
 
int filter_wait (pid_t pid)
 Wait for the exit of a process and return its status.
 

Detailed Description

Pass files through external commands (filters)

Authors
  • Richard Russon

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Definition in file filter.h.

Macro Definition Documentation

◆ EXEC_SHELL

#define EXEC_SHELL   "/bin/sh"

Default shell to use for executing commands.

Definition at line 30 of file filter.h.

Function Documentation

◆ filter_create()

pid_t filter_create ( const char * cmd,
FILE ** fp_in,
FILE ** fp_out,
FILE ** fp_err,
char ** envlist )

Set up filter program.

Parameters
[in]cmdCommand string
[out]fp_inFILE pointer of stdin
[out]fp_outFILE pointer of stdout
[out]fp_errFILE pointer of stderr
[in]envlistEnvironment variables
Return values
numPID of filter

Definition at line 217 of file filter.c.

218{
219 return filter_create_fd(cmd, fp_in, fp_out, fp_err, -1, -1, -1, envlist);
220}
pid_t filter_create_fd(const char *cmd, FILE **fp_in, FILE **fp_out, FILE **fp_err, int fdin, int fdout, int fderr, char **envlist)
Run a command on a pipe (optionally connect stdin/stdout)
Definition filter.c:62
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ filter_create_fd()

pid_t filter_create_fd ( const char * cmd,
FILE ** fp_in,
FILE ** fp_out,
FILE ** fp_err,
int fdin,
int fdout,
int fderr,
char ** envlist )

Run a command on a pipe (optionally connect stdin/stdout)

Parameters
[in]cmdCommand line to invoke using sh -c
[out]fp_inFile stream pointing to stdin for the command process, can be NULL
[out]fp_outFile stream pointing to stdout for the command process, can be NULL
[out]fp_errFile stream pointing to stderr for the command process, can be NULL
[in]fdinIf fp_in is NULL and fdin is not -1 then fdin will be used as stdin for the command process
[in]fdoutIf fp_out is NULL and fdout is not -1 then fdout will be used as stdout for the command process
[in]fderrIf fp_err is NULL and fderr is not -1 then fderr will be used as stderr for the command process
[in]envlistEnvironment variables
Return values
numPID of the created process
-1Error creating pipes or forking

This function provides multiple mechanisms to handle IO sharing for the command process. File streams are prioritized over file descriptors if present.

filter_create_fd(commandline, NULL, NULL, NULL, -1, -1, -1);

Additionally, fp_in, fp_out, and fp_err will point to FILE* streams representing the processes stdin, stdout, and stderr.

Definition at line 62 of file filter.c.

64{
65 int pin[2], pout[2], perr[2], pid;
66
67 /* Create pipes for each requested I/O stream (stdin, stdout, stderr).
68 * On failure, clean up any already-created pipes before returning. */
69 if (fp_in)
70 {
71 *fp_in = NULL;
72 if (pipe(pin) == -1)
73 return -1;
74 }
75
76 if (fp_out)
77 {
78 *fp_out = NULL;
79 if (pipe(pout) == -1)
80 {
81 if (fp_in)
82 {
83 close(pin[0]);
84 close(pin[1]);
85 }
86 return -1;
87 }
88 }
89
90 if (fp_err)
91 {
92 *fp_err = NULL;
93 if (pipe(perr) == -1)
94 {
95 if (fp_in)
96 {
97 close(pin[0]);
98 close(pin[1]);
99 }
100 if (fp_out)
101 {
102 close(pout[0]);
103 close(pout[1]);
104 }
105 return -1;
106 }
107 }
108
109 /* Block signals around fork to prevent child from inheriting pending signals */
111
112 pid = fork();
113 if (pid == 0)
114 {
115 /* Child process: redirect pipe ends to stdin/stdout/stderr via dup2(),
116 * or use the caller-supplied file descriptors as fallback */
119
120 if (fp_in)
121 {
122 close(pin[1]);
123 dup2(pin[0], 0);
124 close(pin[0]);
125 }
126 else if (fdin != -1)
127 {
128 dup2(fdin, 0);
129 close(fdin);
130 }
131
132 if (fp_out)
133 {
134 close(pout[0]);
135 dup2(pout[1], 1);
136 close(pout[1]);
137 }
138 else if (fdout != -1)
139 {
140 dup2(fdout, 1);
141 close(fdout);
142 }
143
144 if (fp_err)
145 {
146 close(perr[0]);
147 dup2(perr[1], 2);
148 close(perr[1]);
149 }
150 else if (fderr != -1)
151 {
152 dup2(fderr, 2);
153 close(fderr);
154 }
155
156 execle(EXEC_SHELL, "sh", "-c", cmd, NULL, envlist);
157 _exit(127);
158 }
159 else if (pid == -1)
160 {
161 /* Fork failed: clean up all pipe file descriptors */
163
164 if (fp_in)
165 {
166 close(pin[0]);
167 close(pin[1]);
168 }
169
170 if (fp_out)
171 {
172 close(pout[0]);
173 close(pout[1]);
174 }
175
176 if (fp_err)
177 {
178 close(perr[0]);
179 close(perr[1]);
180 }
181
182 return -1;
183 }
184
185 /* Parent process: close the child's end of each pipe and wrap
186 * the parent's end in a FILE stream for the caller */
187 if (fp_out)
188 {
189 close(pout[1]);
190 *fp_out = fdopen(pout[0], "r");
191 }
192
193 if (fp_in)
194 {
195 close(pin[0]);
196 *fp_in = fdopen(pin[1], "w");
197 }
198
199 if (fp_err)
200 {
201 close(perr[1]);
202 *fp_err = fdopen(perr[0], "r");
203 }
204
205 return pid;
206}
#define EXEC_SHELL
Default shell to use for executing commands.
Definition filter.h:30
void mutt_sig_reset_child_signals(void)
Reset ignored signals back to the default.
Definition signal.c:336
void mutt_sig_block_system(void)
Block signals before calling exec()
Definition signal.c:260
void mutt_sig_unblock_system(bool restore)
Restore previously blocked signals.
Definition signal.c:284
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ filter_wait()

int filter_wait ( pid_t pid)

Wait for the exit of a process and return its status.

Parameters
pidProcess id of the process to wait for
Return values
numExit status of the process identified by pid
-1Error

Definition at line 228 of file filter.c.

229{
230 int rc = 0;
231
232 waitpid(pid, &rc, 0);
234 rc = WIFEXITED(rc) ? WEXITSTATUS(rc) : -1;
235
236 return rc;
237}
+ Here is the call graph for this function:
+ Here is the caller graph for this function: