Merge git://spitspat.com/git/factor
commit
4b7bc7ef6d
|
@ -0,0 +1,110 @@
|
||||||
|
#!/bin/bash -e
|
||||||
|
|
||||||
|
# Programs returning != 0 will not cause script to exit
|
||||||
|
set +e
|
||||||
|
|
||||||
|
# Case insensitive string comparison
|
||||||
|
shopt -s nocaseglob
|
||||||
|
shopt -s nocasematch
|
||||||
|
|
||||||
|
ensure_program_installed() {
|
||||||
|
echo -n "Checking for $1..."
|
||||||
|
result=`type -p $1`
|
||||||
|
if ! [[ -n $result ]] ; then
|
||||||
|
echo "not found!"
|
||||||
|
echo "Install $1 and try again."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "found!"
|
||||||
|
}
|
||||||
|
|
||||||
|
check_ret() {
|
||||||
|
RET=$?
|
||||||
|
if [[ $RET -ne 0 ]] ; then
|
||||||
|
echo $1 failed
|
||||||
|
exit 5
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
ensure_program_installed uname
|
||||||
|
ensure_program_installed git
|
||||||
|
ensure_program_installed wget
|
||||||
|
ensure_program_installed gcc
|
||||||
|
ensure_program_installed make
|
||||||
|
|
||||||
|
GCC_VERSION=`gcc --version`
|
||||||
|
if [[ $GCC_VERSION == *3.3.* ]] ; then
|
||||||
|
echo "You have a known buggy version of gcc (3.3)"
|
||||||
|
echo "Install gcc 3.4 or higher and try again."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# OS
|
||||||
|
OS=
|
||||||
|
uname_s=`uname -s`
|
||||||
|
case $uname_s in
|
||||||
|
CYGWIN_NT-5.2-WOW64) OS=windows-nt;;
|
||||||
|
*CYGWIN_NT*) OS=windows-nt;;
|
||||||
|
*CYGWIN*) OS=windows-nt;;
|
||||||
|
*darwin*) OS=macosx;;
|
||||||
|
*linux*) OS=linux;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Architecture
|
||||||
|
ARCH=
|
||||||
|
uname_m=`uname -m`
|
||||||
|
case $uname_m in
|
||||||
|
i386) ARCH=x86;;
|
||||||
|
i686) ARCH=x86;;
|
||||||
|
*86) ARCH=x86;;
|
||||||
|
"Power Macintosh") ARCH=ppc;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
WORD=
|
||||||
|
C_WORD=factor-word-size
|
||||||
|
# Word size
|
||||||
|
echo "#include <stdio.h>" > $C_WORD.c
|
||||||
|
echo "int main() { printf(\"%d\", 8*sizeof(long)); return 0; }" >> $C_WORD.c
|
||||||
|
gcc -o $C_WORD $C_WORD.c
|
||||||
|
WORD=$(./$C_WORD)
|
||||||
|
check_ret $C_WORD
|
||||||
|
rm -f $C_WORD*
|
||||||
|
|
||||||
|
case $OS in
|
||||||
|
windows-nt) FACTOR_BINARY=factor-nt;;
|
||||||
|
macosx) FACTOR_BINARY=./Factor.app/Contents/MacOS/factor;;
|
||||||
|
*) FACTOR_BINARY=factor;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
MAKE_TARGET=$OS-$ARCH-$WORD
|
||||||
|
BOOT_IMAGE=boot.$ARCH.$WORD.image
|
||||||
|
|
||||||
|
echo OS=$OS
|
||||||
|
echo ARCH=$ARCH
|
||||||
|
echo WORD=$WORD
|
||||||
|
echo FACTOR_BINARY=$FACTOR_BINARY
|
||||||
|
echo MAKE_TARGET=$MAKE_TARGET
|
||||||
|
echo BOOT_IMAGE=$BOOT_IMAGE
|
||||||
|
|
||||||
|
if ! [[ -n $OS && -n $ARCH && -n $WORD ]] ; then
|
||||||
|
echo "OS, ARCH, or WORD is empty. Please report this"
|
||||||
|
exit 4
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Downloading the git repository from factorcode.org..."
|
||||||
|
git clone git://factorcode.org/git/factor.git
|
||||||
|
check_ret git
|
||||||
|
|
||||||
|
cd factor
|
||||||
|
check_ret cd
|
||||||
|
|
||||||
|
make $MAKE_TARGET
|
||||||
|
check_ret make
|
||||||
|
|
||||||
|
echo "Deleting old images..."
|
||||||
|
rm $BOOT_IMAGE > /dev/null 2>&1
|
||||||
|
rm $BOOT_IMAGE.* > /dev/null 2>&1
|
||||||
|
wget http://factorcode.org/images/latest/$BOOT_IMAGE
|
||||||
|
check_ret wget
|
||||||
|
|
||||||
|
./$FACTOR_BINARY -i=$BOOT_IMAGE
|
|
@ -23,31 +23,40 @@ DEFINE_PRIMITIVE(cd)
|
||||||
SetCurrentDirectory(unbox_u16_string());
|
SetCurrentDirectory(unbox_u16_string());
|
||||||
}
|
}
|
||||||
|
|
||||||
void seh_call(void (*func)(), exception_handler_t *handler)
|
long exception_handler(PEXCEPTION_RECORD rec, void *frame, void *ctx, void *dispatch)
|
||||||
|
{
|
||||||
|
CONTEXT *c = (CONTEXT*)ctx;
|
||||||
|
void *esp = NULL;
|
||||||
|
if(in_code_heap_p(c->Eip))
|
||||||
|
esp = (void*)c->Esp;
|
||||||
|
printf("ExceptionCode = 0x%08x\n", rec->ExceptionCode);
|
||||||
|
printf("AccessViolationCode = 0x%08x\n", EXCEPTION_ACCESS_VIOLATION);
|
||||||
|
printf("DivideByZeroCode1 = 0x%08x\n", EXCEPTION_FLT_DIVIDE_BY_ZERO);
|
||||||
|
printf("DivideByZeroCode2 = 0x%08x\n", EXCEPTION_INT_DIVIDE_BY_ZERO);
|
||||||
|
printf("addr=0x%08x\n", rec->ExceptionInformation[1]);
|
||||||
|
printf("eax=0x%08x\n", c->Eax);
|
||||||
|
printf("eax=0x%08x\n", c->Ebx);
|
||||||
|
printf("eip=0x%08x\n", c->Eip);
|
||||||
|
printf("esp=0x%08x\n", c->Esp);
|
||||||
|
|
||||||
|
printf("calculated esp: 0x%08x\n", esp);
|
||||||
|
|
||||||
|
if(rec->ExceptionCode == EXCEPTION_ACCESS_VIOLATION)
|
||||||
|
memory_protection_error(rec->ExceptionInformation[1], esp);
|
||||||
|
else if(rec->ExceptionCode == EXCEPTION_FLT_DIVIDE_BY_ZERO
|
||||||
|
|| rec->ExceptionCode == EXCEPTION_INT_DIVIDE_BY_ZERO)
|
||||||
|
general_error(ERROR_DIVIDE_BY_ZERO,F,F,esp);
|
||||||
|
else
|
||||||
|
signal_error(11,esp);
|
||||||
|
return -1; /* unreachable */
|
||||||
|
}
|
||||||
|
|
||||||
|
void c_to_factor_toplevel(CELL quot)
|
||||||
{
|
{
|
||||||
exception_record_t record;
|
exception_record_t record;
|
||||||
asm volatile("mov %%fs:0, %0" : "=r" (record.next_handler));
|
asm volatile("mov %%fs:0, %0" : "=r" (record.next_handler));
|
||||||
asm volatile("mov %0, %%fs:0" : : "r" (&record));
|
asm volatile("mov %0, %%fs:0" : : "r" (&record));
|
||||||
record.handler_func = handler;
|
record.handler_func = exception_handler;
|
||||||
func();
|
c_to_factor(quot);
|
||||||
asm volatile("mov %0, %%fs:0" : "=r" (record.next_handler));
|
asm volatile("mov %0, %%fs:0" : "=r" (record.next_handler));
|
||||||
}
|
}
|
||||||
|
|
||||||
long exception_handler(PEXCEPTION_RECORD rec, void *frame, void *ctx, void *dispatch)
|
|
||||||
{
|
|
||||||
if(rec->ExceptionCode == EXCEPTION_ACCESS_VIOLATION)
|
|
||||||
memory_protection_error(
|
|
||||||
rec->ExceptionInformation[1],
|
|
||||||
native_stack_pointer());
|
|
||||||
else if(rec->ExceptionCode == EXCEPTION_FLT_DIVIDE_BY_ZERO
|
|
||||||
|| rec->ExceptionCode == EXCEPTION_INT_DIVIDE_BY_ZERO)
|
|
||||||
general_error(ERROR_DIVIDE_BY_ZERO,F,F,false,(void*)rec->ExceptionInformation[1]);
|
|
||||||
else
|
|
||||||
signal_error(11,(void*)rec->ExceptionInformation[1]);
|
|
||||||
return -1; /* unreachable */
|
|
||||||
}
|
|
||||||
|
|
||||||
void run_toplevel(void)
|
|
||||||
{
|
|
||||||
seh_call(run, exception_handler);
|
|
||||||
}
|
|
||||||
|
|
|
@ -51,7 +51,7 @@ void ffi_dlopen (F_DLL *dll, bool error)
|
||||||
{
|
{
|
||||||
dll->dll = NULL;
|
dll->dll = NULL;
|
||||||
if(error)
|
if(error)
|
||||||
general_error(ERROR_FFI,F,
|
general_error(ERROR_FFI,F,F,
|
||||||
tag_object(get_error_message()));
|
tag_object(get_error_message()));
|
||||||
else
|
else
|
||||||
return;
|
return;
|
||||||
|
@ -204,9 +204,3 @@ void sleep_millis(DWORD msec)
|
||||||
{
|
{
|
||||||
Sleep(msec);
|
Sleep(msec);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run(void)
|
|
||||||
{
|
|
||||||
interpreter();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue