Tue Jun 6 12:11:41 1995 Alexandre Julliard (julliard@sunsite.unc.edu) * [controls/menu.c] Fixed bug with drawing multi-column menus with vertical separator. * [debugger/debug.l] Fixed NULL-pointer reference after readline(). * [if1632/winprocs.spec] [miscemu/int21.c] [miscemu/interrupts.c] Added interrupt vector emulation. Allows to retrieve an interrupt vector and jump to it without crashing. * [loader/ldt.c] Moved ldt.c to memory directory. * [loader/task.c] Implemented LockCurrentTask() and GetInstanceData(). * [objects/bitblt.c] Fixed a bug that caused StretchBlt() to use wrong colors when stretching a monochrome bitmap to a color display. * [objects/bitmap.c] Fixed a segmented pointer bug in CreateBitmapIndirect(). * [tools/build.c] Added possibility to have arguments for register functions; used by interrupt vectors to remove the flags from the stack. Generate a new function CallTo32_LargeStack(), that allows calling a 32-bit function using the original 32-bit stack, for functions that need more that 64k of stack. Tue May 30 10:29:56 1995 Martin von Loewis <martin@informatik.hu-berlin.de> * [if1632/shell.spec] [misc/shell.c] DoEnvironmentSubst: fixed prototype * [if1632/gdi.spec] [objects/palette.c] SetSystemPaletteUse: new function * [if1632/kernel.spec] [loader/resource.c] DirectResAlloc: new function * [if1632/user.spec] [windows/keyboard.c] SetKeyboardState: new function Mon May 29 12:58:28 1995 Bernd Schmidt <crux@pool.informatik.rwth-aachen.de> * [tools/build.c] Prevent interrupts from destroying the args for a 32 bit function by loading the correct value into %esp directly after %ss. * [loader/ne_image.c] [loader/module.c] The new instance must be created earlier in LoadModule(), so that fixups referencing it will be handled correctly. Initialize the local heap for a DGROUP in NE_LoadSegment(). * [objects/dib.c] Like RLE8 bitmaps, RLE4 bitmaps don't always end with a proper code. This used to crash Wine. Fixed. * [objects/text.c] Fix possible null pointer dereference in debugging output. * [misc/commdlg.c] Handle user input in the edit control better. Some bugs fixed. * [memory/local.c] Started implementing moveable blocks. This is unfinished (!), but at least it does not seem to break things. Wed May 24 13:26:36 1995 Bernd Schmidt <crux@pool.informatik.rwth-aachen.de> * [loader/module.c] LoadModule(): DLLs occasionally have a data segment, and they work much better if it is loaded :-) LoadLibrary(): pass HMODULE instead of HINSTANCE to NE_InitializeDLLs. FindModule(): also strip off the last backslash of the pathnames (Winhelp tried to load C:\WINDOWS\SYSTEM\COMMDLG.DLL). GetModuleHandle(): just call MODULE_FindModule, it does the same job, only better. * [loader/ne_image.c] LocalInit() the heap of a DLL in NE_InitDLL. (This is probably not really correct, it seems that all programs and DLLs try to do this themselves. But they pass weird parameters.) NE_InitializeDLLs should also call NE_InitDLL for the passed hModule. * [loader/task.c] [misc/user.c] Finish global initializations in InitTask instead of InitApp, or all the DLLs will be initialized in InitTask without any available window classes!
213 lines
4.4 KiB
Text
213 lines
4.4 KiB
Text
/* Lexical scanner for command line parsing in the Wine debugger
|
|
*
|
|
* Version 1.0
|
|
* Eric Youngdale
|
|
* 9/93
|
|
*/
|
|
|
|
%{
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include "dbg.tab.h"
|
|
#include "regpos.h"
|
|
|
|
#ifdef USE_READLINE
|
|
#undef YY_INPUT
|
|
#define YY_INPUT(buf,result,max_size) \
|
|
if ( (result = dbg_read((char *) buf, max_size )) < 0 ) \
|
|
YY_FATAL_ERROR( "read() in flex scanner failed" );
|
|
#endif
|
|
|
|
extern char * readline(char *);
|
|
static char * make_symbol(char *);
|
|
void flush_symbols();
|
|
static int syntax_error;
|
|
extern int yylval;
|
|
%}
|
|
|
|
DIGIT [0-9]
|
|
HEXDIGIT [0-9a-fA-F]
|
|
|
|
IDENTIFIER [_a-zA-Z\.~][_a-zA-Z0-9\.~]*
|
|
FILE_IDENTIFIER [_a-zA-Z\.~/][_a-zA-Z\.~/]*
|
|
|
|
%%
|
|
|
|
\n { syntax_error = 0; return '\n'; } /* Indicate end of command */
|
|
|
|
"+" { return '+'; }
|
|
|
|
"-" { return '-'; }
|
|
|
|
"/" { return '/'; }
|
|
|
|
"=" { return '='; }
|
|
|
|
"(" { return '('; }
|
|
|
|
")" { return ')'; }
|
|
|
|
"*" { return '*'; }
|
|
|
|
"?" { return HELP; }
|
|
|
|
"0x"+{HEXDIGIT}+ {
|
|
sscanf(yytext, "%x", &yylval);
|
|
return NUM;
|
|
}
|
|
|
|
{DIGIT}+ {
|
|
sscanf(yytext, "%d", &yylval);
|
|
return NUM;
|
|
}
|
|
|
|
$pc { yylval = RN_EIP; return REG;}
|
|
$sp { yylval = RN_ESP_AT_SIGNAL; return REG;}
|
|
$eip { yylval = RN_EIP; return REG;}
|
|
$esp { yylval = RN_ESP_AT_SIGNAL; return REG;}
|
|
$ebp { yylval = RN_EBP; return REG;}
|
|
$eax { yylval = RN_EAX; return REG;}
|
|
$ebx { yylval = RN_EBX; return REG;}
|
|
$ecx { yylval = RN_ECX; return REG;}
|
|
$edx { yylval = RN_EDX; return REG;}
|
|
$esi { yylval = RN_ESI; return REG;}
|
|
$edi { yylval = RN_EDI; return REG;}
|
|
|
|
$es { yylval = RN_ES; return REG;}
|
|
$ds { yylval = RN_DS; return REG;}
|
|
$cs { yylval = RN_CS; return REG;}
|
|
$ss { yylval = RN_SS; return REG;}
|
|
|
|
info|inf|in { return INFO; }
|
|
segments|segm { return SEGMENTS; }
|
|
break|brea|bre { return BREAK; }
|
|
enable|enabl|enab|ena { return ENABLE;}
|
|
disable|disabl|disab|disa|dis { return DISABLE; }
|
|
|
|
quit|qui|qu { return QUIT; }
|
|
|
|
help|hel|he { return HELP; }
|
|
|
|
set|se { return SET; }
|
|
|
|
bt { return BACKTRACE; }
|
|
|
|
cont|con|co { return CONT; }
|
|
|
|
symbolfile|symbolfil|symbolfi|symbolf|symbol|symbo|symb { return SYMBOLFILE; }
|
|
|
|
define|defin|defi|def|de { return DEFINE; }
|
|
abort|abor|abo { return ABORT; }
|
|
print|prin|pri|pr { return PRINT; }
|
|
|
|
mode { return MODE; }
|
|
|
|
regs|reg|re { return REGS; }
|
|
|
|
stack|stac|sta|st { return STACK; }
|
|
|
|
p { return 'p'; }
|
|
x { return 'x'; }
|
|
d { return 'd'; }
|
|
i { return 'i'; }
|
|
w { return 'w'; }
|
|
b { return 'b'; }
|
|
s { return 's'; }
|
|
c { return 'c'; }
|
|
q { return 'q'; }
|
|
|
|
{IDENTIFIER} {yylval = (int) make_symbol(yytext);
|
|
return IDENTIFIER;
|
|
}
|
|
|
|
{FILE_IDENTIFIER} {yylval = (int) make_symbol(yytext);
|
|
return FILE_IDENTIFIER;
|
|
}
|
|
|
|
[ \t]+ /* Eat up whitespace */
|
|
|
|
. { if(syntax_error == 0) {
|
|
syntax_error ++; fprintf(stderr, "Syntax Error\n"); }
|
|
}
|
|
|
|
%%
|
|
|
|
#ifndef yywrap
|
|
int yywrap(void) { return 1; }
|
|
#endif
|
|
|
|
#ifdef USE_READLINE
|
|
#ifndef whitespace
|
|
#define whitespace(c) (((c) == ' ') || ((c) == '\t'))
|
|
#endif
|
|
|
|
#if 0
|
|
/* Used only with GNU readline */
|
|
#include "readline/readline.h"
|
|
#include "readline/chardefs.h"
|
|
#endif
|
|
|
|
/* Strip whitespace from the start and end of STRING. */
|
|
static void stripwhite (char *string)
|
|
{
|
|
register int i = 0;
|
|
|
|
while (whitespace (string[i]))
|
|
i++;
|
|
|
|
if (i)
|
|
strcpy (string, string + i);
|
|
|
|
i = strlen (string) - 1;
|
|
|
|
while (i > 0 && whitespace (string[i]))
|
|
i--;
|
|
|
|
string[++i] = '\0';
|
|
}
|
|
|
|
dbg_read(char * buf, int size){
|
|
char * line;
|
|
int len;
|
|
|
|
do{
|
|
flush_symbols();
|
|
line = readline ("Wine-dbg>");
|
|
if (!line) return 0;
|
|
len = strlen(line);
|
|
|
|
/* Remove leading and trailing whitespace from the line.
|
|
Then, if there is anything left, add it to the history list
|
|
and execute it. */
|
|
stripwhite (line);
|
|
|
|
if (*line)
|
|
{
|
|
add_history (line);
|
|
if(size < len + 1){
|
|
fprintf(stderr,"Fatal readline goof.\n");
|
|
exit(0);
|
|
}
|
|
strcpy(buf, line);
|
|
buf[len] = '\n';
|
|
buf[len+1] = 0;
|
|
free(line);
|
|
return len + 1;
|
|
}
|
|
} while (1==1);
|
|
}
|
|
|
|
static char *local_symbols[10];
|
|
static int next_symbol;
|
|
|
|
char * make_symbol(char * symbol){
|
|
return local_symbols[next_symbol++] = strdup(symbol);
|
|
}
|
|
|
|
void
|
|
flush_symbols(){
|
|
while(--next_symbol>= 0) free(local_symbols[next_symbol]);
|
|
next_symbol = 0;
|
|
}
|
|
|
|
#endif
|