cmd: START needs to be an internal command.
[wine/multimedia.git] / programs / cmd / wcmd.h
blob5f343b55086e539c88546fabc50d21f0ceb35c28
1 /*
2 * CMD - Wine-compatible command line interface.
4 * Copyright (C) 1999 D A Pickles
5 * Copyright (C) 2007 J Edmeades
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 #define IDI_ICON1 1
23 #include <windows.h>
24 #include <windef.h>
25 #ifndef RC_INVOKED
26 #include <string.h>
27 #include <stdlib.h>
28 #include <stdarg.h>
29 #include <stdio.h>
30 #include <ctype.h>
31 #include <wine/unicode.h>
33 /* msdn specified max for Win XP */
34 #define MAXSTRING 8192
36 /* Data structure to hold commands delimitors/separators */
38 typedef enum _CMDdelimiters {
39 CMD_NONE, /* End of line or single & */
40 CMD_ONFAILURE, /* || */
41 CMD_ONSUCCESS, /* && */
42 CMD_PIPE /* Single | */
43 } CMD_DELIMITERS;
45 /* Data structure to hold commands to be processed */
47 typedef struct _CMD_LIST {
48 WCHAR *command; /* Command string to execute */
49 WCHAR *redirects; /* Redirects in place */
50 struct _CMD_LIST *nextcommand; /* Next command string to execute */
51 CMD_DELIMITERS prevDelim; /* Previous delimiter */
52 int bracketDepth;/* How deep bracketing have we got to */
53 WCHAR pipeFile[MAX_PATH]; /* Where to get input from for pipes */
54 } CMD_LIST;
56 void WCMD_assoc (const WCHAR *, BOOL);
57 void WCMD_batch (WCHAR *, WCHAR *, int, WCHAR *, HANDLE);
58 void WCMD_call (WCHAR *command);
59 void WCMD_change_tty (void);
60 void WCMD_choice (const WCHAR *);
61 void WCMD_clear_screen (void);
62 void WCMD_color (void);
63 void WCMD_copy (void);
64 void WCMD_create_dir (WCHAR *);
65 BOOL WCMD_delete (WCHAR *);
66 void WCMD_directory (WCHAR *);
67 void WCMD_echo (const WCHAR *);
68 void WCMD_endlocal (void);
69 void WCMD_enter_paged_mode(const WCHAR *);
70 void WCMD_exit (CMD_LIST **cmdList);
71 void WCMD_for (WCHAR *, CMD_LIST **cmdList);
72 void WCMD_give_help (const WCHAR *command);
73 void WCMD_goto (CMD_LIST **cmdList);
74 void WCMD_if (WCHAR *, CMD_LIST **cmdList);
75 void WCMD_leave_paged_mode(void);
76 void WCMD_more (WCHAR *);
77 void WCMD_move (void);
78 WCHAR* CDECL WCMD_format_string (const WCHAR *format, ...);
79 void CDECL WCMD_output (const WCHAR *format, ...);
80 void CDECL WCMD_output_stderr (const WCHAR *format, ...);
81 void WCMD_output_asis (const WCHAR *message);
82 void WCMD_output_asis_stderr (const WCHAR *message);
83 void WCMD_pause (void);
84 void WCMD_popd (void);
85 void WCMD_print_error (void);
86 void WCMD_pushd (const WCHAR *command);
87 void WCMD_remove_dir (WCHAR *command);
88 void WCMD_rename (void);
89 void WCMD_run_program (WCHAR *command, int called);
90 void WCMD_setlocal (const WCHAR *command);
91 void WCMD_setshow_date (void);
92 void WCMD_setshow_default (const WCHAR *command);
93 void WCMD_setshow_env (WCHAR *command);
94 void WCMD_setshow_path (const WCHAR *command);
95 void WCMD_setshow_prompt (void);
96 void WCMD_setshow_time (void);
97 void WCMD_shift (const WCHAR *command);
98 void WCMD_start (const WCHAR *command);
99 void WCMD_title (const WCHAR *);
100 void WCMD_type (WCHAR *);
101 void WCMD_verify (const WCHAR *command);
102 void WCMD_version (void);
103 int WCMD_volume (BOOL set_label, const WCHAR *command);
105 static inline BOOL WCMD_is_console_handle(HANDLE h)
107 return (((DWORD_PTR)h) & 3) == 3;
109 WCHAR *WCMD_fgets (WCHAR *buf, DWORD n, HANDLE stream);
110 WCHAR *WCMD_parameter (WCHAR *s, int n, WCHAR **start, WCHAR **end);
111 WCHAR *WCMD_skip_leading_spaces (WCHAR *string);
112 BOOL WCMD_keyword_ws_found(const WCHAR *keyword, int len, const WCHAR *ptr);
113 void WCMD_HandleTildaModifiers(WCHAR **start, const WCHAR *forVariable, const WCHAR *forValue, BOOL justFors);
115 void WCMD_splitpath(const WCHAR* path, WCHAR* drv, WCHAR* dir, WCHAR* name, WCHAR* ext);
116 void WCMD_strip_quotes(WCHAR *cmd);
117 WCHAR *WCMD_LoadMessage(UINT id);
118 WCHAR *WCMD_strdupW(const WCHAR *input);
119 void WCMD_strsubstW(WCHAR *start, const WCHAR* next, const WCHAR* insert, int len);
120 BOOL WCMD_ReadFile(const HANDLE hIn, WCHAR *intoBuf, const DWORD maxChars, LPDWORD charsRead);
122 WCHAR *WCMD_ReadAndParseLine(const WCHAR *initialcmd, CMD_LIST **output, HANDLE readFrom);
123 CMD_LIST *WCMD_process_commands(CMD_LIST *thisCmd, BOOL oneBracket,
124 const WCHAR *var, const WCHAR *val);
125 void WCMD_free_commands(CMD_LIST *cmds);
126 void WCMD_execute (const WCHAR *orig_command, const WCHAR *redirects,
127 const WCHAR *parameter, const WCHAR *substitution,
128 CMD_LIST **cmdList);
130 /* Data structure to hold context when executing batch files */
132 typedef struct _BATCH_CONTEXT {
133 WCHAR *command; /* The command which invoked the batch file */
134 HANDLE h; /* Handle to the open batch file */
135 WCHAR *batchfileW; /* Name of same */
136 int shift_count[10]; /* Offset in terms of shifts for %0 - %9 */
137 struct _BATCH_CONTEXT *prev_context; /* Pointer to the previous context block */
138 BOOL skip_rest; /* Skip the rest of the batch program and exit */
139 CMD_LIST *toExecute; /* Commands left to be executed */
140 } BATCH_CONTEXT;
142 /* Data structure to handle building lists during recursive calls */
144 struct env_stack
146 struct env_stack *next;
147 union {
148 int stackdepth; /* Only used for pushd and popd */
149 WCHAR cwd; /* Only used for set/endlocal */
150 } u;
151 WCHAR *strings;
154 /* Data structure to save setlocal and pushd information */
156 typedef struct _DIRECTORY_STACK
158 struct _DIRECTORY_STACK *next;
159 WCHAR *dirName;
160 WCHAR *fileName;
161 } DIRECTORY_STACK;
164 * Global variables quals, param1, param2 contain the current qualifiers
165 * (uppercased and concatenated) and parameters entered, with environment
166 * variables and batch parameters substitution already done.
168 extern WCHAR quals[MAX_PATH], param1[MAXSTRING], param2[MAXSTRING];
169 extern DWORD errorlevel;
170 extern BATCH_CONTEXT *context;
172 #endif /* !RC_INVOKED */
175 * Serial nos of builtin commands. These constants must be in step with
176 * the list of strings defined in wcmd.rc, and WCMD_EXIT *must* always be
177 * the last one.
179 * Yes it *would* be nice to use an enumeration here, but the Resource
180 * Compiler won't accept resource IDs from enumerations :-(
183 #define WCMD_CALL 0
184 #define WCMD_CD 1
185 #define WCMD_CHDIR 2
186 #define WCMD_CLS 3
187 #define WCMD_COPY 4
188 #define WCMD_CTTY 5
189 #define WCMD_DATE 6
190 #define WCMD_DEL 7
191 #define WCMD_DIR 8
192 #define WCMD_ECHO 9
193 #define WCMD_ERASE 10
194 #define WCMD_FOR 11
195 #define WCMD_GOTO 12
196 #define WCMD_HELP 13
197 #define WCMD_IF 14
198 #define WCMD_LABEL 15
199 #define WCMD_MD 16
200 #define WCMD_MKDIR 17
201 #define WCMD_MOVE 18
202 #define WCMD_PATH 19
203 #define WCMD_PAUSE 20
204 #define WCMD_PROMPT 21
205 #define WCMD_REM 22
206 #define WCMD_REN 23
207 #define WCMD_RENAME 24
208 #define WCMD_RD 25
209 #define WCMD_RMDIR 26
210 #define WCMD_SET 27
211 #define WCMD_SHIFT 28
212 #define WCMD_START 29
213 #define WCMD_TIME 30
214 #define WCMD_TITLE 31
215 #define WCMD_TYPE 32
216 #define WCMD_VERIFY 33
217 #define WCMD_VER 34
218 #define WCMD_VOL 35
220 #define WCMD_ENDLOCAL 36
221 #define WCMD_SETLOCAL 37
222 #define WCMD_PUSHD 38
223 #define WCMD_POPD 39
224 #define WCMD_ASSOC 40
225 #define WCMD_COLOR 41
226 #define WCMD_FTYPE 42
227 #define WCMD_MORE 43
228 #define WCMD_CHOICE 44
230 /* Must be last in list */
231 #define WCMD_EXIT 45
233 /* Some standard messages */
234 extern const WCHAR newline[];
235 extern const WCHAR space[];
236 extern const WCHAR nullW[];
237 extern const WCHAR dotW[];
238 extern const WCHAR dotdotW[];
239 extern const WCHAR starW[];
240 extern const WCHAR slashW[];
241 extern const WCHAR equalW[];
242 extern WCHAR anykey[];
243 extern WCHAR version_string[];
245 /* Translated messages */
246 #define WCMD_ALLHELP 1000
247 #define WCMD_CONFIRM 1001
248 #define WCMD_YES 1002
249 #define WCMD_NO 1003
250 #define WCMD_NOASSOC 1004
251 #define WCMD_NOFTYPE 1005
252 #define WCMD_OVERWRITE 1006
253 #define WCMD_MORESTR 1007
254 #define WCMD_TRUNCATEDLINE 1008
255 #define WCMD_NYI 1009
256 #define WCMD_NOARG 1010
257 #define WCMD_SYNTAXERR 1011
258 #define WCMD_FILENOTFOUND 1012
259 #define WCMD_NOCMDHELP 1013
260 #define WCMD_NOTARGET 1014
261 #define WCMD_CURRENTDATE 1015
262 #define WCMD_CURRENTTIME 1016
263 #define WCMD_NEWDATE 1017
264 #define WCMD_NEWTIME 1018
265 #define WCMD_MISSINGENV 1019
266 #define WCMD_READFAIL 1020
267 #define WCMD_CALLINSCRIPT 1021
268 #define WCMD_ALL 1022
269 #define WCMD_DELPROMPT 1023
270 #define WCMD_ECHOPROMPT 1024
271 #define WCMD_VERIFYPROMPT 1025
272 #define WCMD_VERIFYERR 1026
273 #define WCMD_ARGERR 1027
274 #define WCMD_VOLUMESERIALNO 1028
275 #define WCMD_VOLUMEPROMPT 1029
276 #define WCMD_NOPATH 1030
277 #define WCMD_ANYKEY 1031
278 #define WCMD_CONSTITLE 1032
279 #define WCMD_VERSION 1033
280 #define WCMD_MOREPROMPT 1034
281 #define WCMD_LINETOOLONG 1035
282 #define WCMD_VOLUMELABEL 1036
283 #define WCMD_VOLUMENOLABEL 1037
284 #define WCMD_YESNO 1038
285 #define WCMD_YESNOALL 1039