source: trunk/src/kmk/remote-stub.c@ 2269

Last change on this file since 2269 was 1993, checked in by bird, 17 years ago

Merged in current GNU Make code (CVS from 2008-10-28). Ref #55.

  • Property svn:eol-style set to native
File size: 2.9 KB
Line 
1/* Template for the remote job exportation interface to GNU Make.
2Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
31998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 Free Software
4Foundation, Inc.
5This file is part of GNU Make.
6
7GNU Make is free software; you can redistribute it and/or modify it under the
8terms of the GNU General Public License as published by the Free Software
9Foundation; either version 3 of the License, or (at your option) any later
10version.
11
12GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
13WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14A PARTICULAR PURPOSE. See the GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License along with
17this program. If not, see <http://www.gnu.org/licenses/>. */
18
19#include "make.h"
20#include "filedef.h"
21#include "job.h"
22#include "commands.h"
23
24
25char *remote_description = 0;
26
27/* Call once at startup even if no commands are run. */
28
29void
30remote_setup (void)
31{
32}
33
34/* Called before exit. */
35
36void
37remote_cleanup (void)
38{
39}
40
41
42/* Return nonzero if the next job should be done remotely. */
43
44int
45start_remote_job_p (int first_p UNUSED)
46{
47 return 0;
48}
49
50
51/* Start a remote job running the command in ARGV,
52 with environment from ENVP. It gets standard input from STDIN_FD. On
53 failure, return nonzero. On success, return zero, and set *USED_STDIN
54 to nonzero if it will actually use STDIN_FD, zero if not, set *ID_PTR to
55 a unique identification, and set *IS_REMOTE to zero if the job is local,
56 nonzero if it is remote (meaning *ID_PTR is a process ID). */
57
58int
59start_remote_job (char **argv UNUSED, char **envp UNUSED, int stdin_fd UNUSED,
60 int *is_remote UNUSED, int *id_ptr UNUSED,
61 int *used_stdin UNUSED)
62{
63 return -1;
64}
65
66
67/* Get the status of a dead remote child. Block waiting for one to die
68 if BLOCK is nonzero. Set *EXIT_CODE_PTR to the exit status, *SIGNAL_PTR
69 to the termination signal or zero if it exited normally, and *COREDUMP_PTR
70 nonzero if it dumped core. Return the ID of the child that died,
71 0 if we would have to block and !BLOCK, or < 0 if there were none. */
72
73int
74remote_status (int *exit_code_ptr UNUSED, int *signal_ptr UNUSED,
75 int *coredump_ptr UNUSED, int block UNUSED)
76{
77 errno = ECHILD;
78 return -1;
79}
80
81/* Block asynchronous notification of remote child death.
82 If this notification is done by raising the child termination
83 signal, do not block that signal. */
84void
85block_remote_children (void)
86{
87 return;
88}
89
90/* Restore asynchronous notification of remote child death.
91 If this is done by raising the child termination signal,
92 do not unblock that signal. */
93void
94unblock_remote_children (void)
95{
96 return;
97}
98
99/* Send signal SIG to child ID. Return 0 if successful, -1 if not. */
100int
101remote_kill (int id UNUSED, int sig UNUSED)
102{
103 return -1;
104}
Note: See TracBrowser for help on using the repository browser.