Merge git://spitspat.com/git/factor
commit
3f69eba1e7
|
@ -0,0 +1,8 @@
|
||||||
|
LIBS = -lm
|
||||||
|
EXE_SUFFIX=-nt
|
||||||
|
DLL_SUFFIX=-nt
|
||||||
|
PLAF_DLL_OBJS += vm/os-windows-nt.o
|
||||||
|
PLAF_EXE_OBJS += vm/resources.o
|
||||||
|
PLAF_EXE_OBJS += vm/main-windows-nt.o
|
||||||
|
CFLAGS += -mwindows
|
||||||
|
include vm/Config.windows
|
|
@ -1,7 +1,2 @@
|
||||||
LIBS = -lm
|
include vm/Config.windows.nt
|
||||||
EXE_SUFFIX=-nt
|
include vm/Config.x86.32
|
||||||
DLL_SUFFIX=-nt
|
|
||||||
PLAF_DLL_OBJS += vm/os-windows-nt.o
|
|
||||||
PLAF_EXE_OBJS += vm/resources.o
|
|
||||||
PLAF_EXE_OBJS += vm/main-windows-nt.o
|
|
||||||
include vm/Config.x86.32 vm/Config.windows
|
|
||||||
|
|
|
@ -213,6 +213,7 @@ void dump_objects(F_FIXNUM type)
|
||||||
void factorbug(void)
|
void factorbug(void)
|
||||||
{
|
{
|
||||||
reset_stdio();
|
reset_stdio();
|
||||||
|
open_console();
|
||||||
|
|
||||||
printf("Starting low level debugger...\n");
|
printf("Starting low level debugger...\n");
|
||||||
printf(" Basic commands:\n");
|
printf(" Basic commands:\n");
|
||||||
|
|
|
@ -26,6 +26,7 @@ void default_parameters(F_PARAMETERS *p)
|
||||||
|
|
||||||
p->secure_gc = false;
|
p->secure_gc = false;
|
||||||
p->fep = false;
|
p->fep = false;
|
||||||
|
p->console = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get things started */
|
/* Get things started */
|
||||||
|
@ -110,6 +111,8 @@ void init_factor_from_args(F_CHAR *image, int argc, F_CHAR **argv, bool embedded
|
||||||
p.fep = true;
|
p.fep = true;
|
||||||
else if(STRNCMP(argv[i],STR_FORMAT("-i="),3) == 0)
|
else if(STRNCMP(argv[i],STR_FORMAT("-i="),3) == 0)
|
||||||
p.image = argv[i] + 3;
|
p.image = argv[i] + 3;
|
||||||
|
else if(STRCMP(argv[i],STR_FORMAT("-console")) == 0)
|
||||||
|
p.console = true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
init_factor(&p);
|
init_factor(&p);
|
||||||
|
@ -135,6 +138,9 @@ void init_factor_from_args(F_CHAR *image, int argc, F_CHAR **argv, bool embedded
|
||||||
|
|
||||||
nest_stacks();
|
nest_stacks();
|
||||||
|
|
||||||
|
if(p.console)
|
||||||
|
open_console();
|
||||||
|
|
||||||
if(p.fep)
|
if(p.fep)
|
||||||
factorbug();
|
factorbug();
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,7 @@ typedef struct {
|
||||||
CELL code_size;
|
CELL code_size;
|
||||||
bool secure_gc;
|
bool secure_gc;
|
||||||
bool fep;
|
bool fep;
|
||||||
|
bool console;
|
||||||
} F_PARAMETERS;
|
} F_PARAMETERS;
|
||||||
|
|
||||||
void load_image(F_PARAMETERS *p);
|
void load_image(F_PARAMETERS *p);
|
||||||
|
|
|
@ -256,3 +256,5 @@ void reset_stdio(void)
|
||||||
fcntl(0,F_SETFL,0);
|
fcntl(0,F_SETFL,0);
|
||||||
fcntl(1,F_SETFL,0);
|
fcntl(1,F_SETFL,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void open_console(void) { }
|
||||||
|
|
|
@ -39,3 +39,4 @@ s64 current_millis(void);
|
||||||
void sleep_millis(CELL msec);
|
void sleep_millis(CELL msec);
|
||||||
|
|
||||||
void reset_stdio(void);
|
void reset_stdio(void);
|
||||||
|
void open_console(void);
|
||||||
|
|
|
@ -46,3 +46,5 @@ void c_to_factor_toplevel(CELL quot)
|
||||||
{
|
{
|
||||||
c_to_factor(quot);
|
c_to_factor(quot);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void open_console(void) { }
|
||||||
|
|
|
@ -24,3 +24,4 @@ char *getenv(char *name);
|
||||||
|
|
||||||
s64 current_millis(void);
|
s64 current_millis(void);
|
||||||
void c_to_factor_toplevel(CELL quot);
|
void c_to_factor_toplevel(CELL quot);
|
||||||
|
void open_console(void);
|
||||||
|
|
|
@ -88,3 +88,17 @@ void c_to_factor_toplevel(CELL quot)
|
||||||
c_to_factor(quot);
|
c_to_factor(quot);
|
||||||
RemoveVectoredExceptionHandler((void*)exception_handler);
|
RemoveVectoredExceptionHandler((void*)exception_handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void open_console(void)
|
||||||
|
{
|
||||||
|
if(!console_open)
|
||||||
|
{
|
||||||
|
if(!AttachConsole(ATTACH_PARENT_PROCESS))
|
||||||
|
{
|
||||||
|
if(AllocConsole())
|
||||||
|
console_open = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
console_open = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -18,3 +18,5 @@ typedef char F_SYMBOL;
|
||||||
|
|
||||||
void c_to_factor_toplevel(CELL quot);
|
void c_to_factor_toplevel(CELL quot);
|
||||||
long exception_handler(PEXCEPTION_POINTERS pe);
|
long exception_handler(PEXCEPTION_POINTERS pe);
|
||||||
|
bool console_open;
|
||||||
|
void open_console(void);
|
||||||
|
|
Loading…
Reference in New Issue