2 * Error codes returned by rsync.
4 * Copyright (C) 1998-2000 Andrew Tridgell
5 * Copyright (C) 2003-2007 Wayne Davison
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 3 as
9 * published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, visit the http://fsf.org website.
20 /* If you change these, please also update the string mappings in log.c and
21 * the EXIT VALUES in rsync.yo. */
24 #define RERR_SYNTAX 1 /* syntax or usage error */
25 #define RERR_PROTOCOL 2 /* protocol incompatibility */
26 #define RERR_FILESELECT 3 /* errors selecting input/output files, dirs */
27 #define RERR_UNSUPPORTED 4 /* requested action not supported */
28 #define RERR_STARTCLIENT 5 /* error starting client-server protocol */
30 #define RERR_SOCKETIO 10 /* error in socket IO */
31 #define RERR_FILEIO 11 /* error in file IO */
32 #define RERR_STREAMIO 12 /* error in rsync protocol data stream */
33 #define RERR_MESSAGEIO 13 /* errors with program diagnostics */
34 #define RERR_IPC 14 /* error in IPC code */
35 #define RERR_CRASHED 15 /* sibling crashed */
36 #define RERR_TERMINATED 16 /* sibling terminated abnormally */
38 #define RERR_SIGNAL1 19 /* status returned when sent SIGUSR1 */
39 #define RERR_SIGNAL 20 /* status returned when sent SIGINT, SIGTERM, SIGHUP */
40 #define RERR_WAITCHILD 21 /* some error returned by waitpid() */
41 #define RERR_MALLOC 22 /* error allocating core memory buffers */
42 #define RERR_PARTIAL 23 /* partial transfer */
43 #define RERR_VANISHED 24 /* file(s) vanished on sender side */
44 #define RERR_DEL_LIMIT 25 /* skipped some deletes due to --max-delete */
46 #define RERR_TIMEOUT 30 /* timeout in data send/receive */
48 /* Although it doesn't seem to be specified anywhere,
49 * ssh and the shell seem to return these values:
51 * 124 if the command exited with status 255
52 * 125 if the command is killed by a signal
53 * 126 if the command cannot be run
54 * 127 if the command is not found
56 * and we could use this to give a better explanation if the remote
57 * command is not found.
59 #define RERR_CMD_FAILED 124
60 #define RERR_CMD_KILLED 125
61 #define RERR_CMD_RUN 126
62 #define RERR_CMD_NOTFOUND 127