diff options
author | Ole Loots <ole@monochrom.net> | 2011-01-22 16:37:24 +0000 |
---|---|---|
committer | Ole Loots <ole@monochrom.net> | 2011-01-22 16:37:24 +0000 |
commit | 3462356059756c2095919ad0b904bd1262d4bf80 (patch) | |
tree | 5bb5e62f6bc8b0b8372d80e32855e597bf422a3e /atari/misc.c | |
parent | 7e79d32bed18a09e0f1dcb0723700507e446a80c (diff) | |
download | netsurf-3462356059756c2095919ad0b904bd1262d4bf80.tar.gz netsurf-3462356059756c2095919ad0b904bd1262d4bf80.tar.bz2 |
increased compatibility with classic TOS systems. (Getcookie() breaks on classic TOS systems.)
svn path=/trunk/netsurf/; revision=11446
Diffstat (limited to 'atari/misc.c')
-rw-r--r-- | atari/misc.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/atari/misc.c b/atari/misc.c index 674dd8639..5bfdd7f59 100644 --- a/atari/misc.c +++ b/atari/misc.c @@ -20,6 +20,8 @@ #include <stdlib.h>
#include <stdio.h>
#include <string.h>
+#include <mint/osbind.h>
+#include <mint/cookie.h>
#include <windom.h>
#include "desktop/cookies.h"
@@ -34,6 +36,35 @@ #include "atari/misc.h"
extern void * h_gem_rsrc;
+unsigned short gdosversion;
+
+void init_os_info(void)
+{
+ gdosversion = Sversion();
+}
+
+int tos_getcookie(long tag, long * value)
+{
+ COOKIE * cptr;
+ long oldsp;
+
+ if( gdosversion > TOS4VER ){
+ return( Getcookie(tag, value) );
+ }
+
+ cptr = (COOKIE*)Setexc(0x0168, -1L);
+ if(cptr != NULL) {
+ do {
+ if( cptr->c == tag ){
+ if(cptr->v != NULL ){
+ *value = cptr->v;
+ return( C_FOUND );
+ }
+ }
+ } while( (cptr++)->c != 0L );
+ }
+ return( C_NOTFOUND );
+}
void warn_user(const char *warning, const char *detail)
{
@@ -47,6 +78,7 @@ void warn_user(const char *warning, const char *detail) void die(const char *error)
{
printf("%s\n", error);
+ sleep( 3 );
exit(1);
}
|