summaryrefslogtreecommitdiff
path: root/atari/misc.c
diff options
context:
space:
mode:
authorOle Loots <ole@monochrom.net>2011-01-22 16:37:24 +0000
committerOle Loots <ole@monochrom.net>2011-01-22 16:37:24 +0000
commit3462356059756c2095919ad0b904bd1262d4bf80 (patch)
tree5bb5e62f6bc8b0b8372d80e32855e597bf422a3e /atari/misc.c
parent7e79d32bed18a09e0f1dcb0723700507e446a80c (diff)
downloadnetsurf-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.c32
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);
}