shithub: choc

Download patch

ref: 443163fc15088ab226234e9a4509eb3183574217
parent: c8b201dd2ad041eda3147b59abaacb2d2359c6d5
author: Simon Howard <fraggle@gmail.com>
date: Sun Oct 9 16:19:21 EDT 2005

Handle blinking text in ENDOOM lumps properly.

Subversion-branch: /trunk/chocolate-doom
Subversion-revision: 183

--- a/src/i_system.c
+++ b/src/i_system.c
@@ -1,7 +1,7 @@
 // Emacs style mode select   -*- C++ -*- 
 //-----------------------------------------------------------------------------
 //
-// $Id: i_system.c 148 2005-10-02 03:23:54Z fraggle $
+// $Id: i_system.c 183 2005-10-09 20:19:21Z fraggle $
 //
 // Copyright(C) 1993-1996 Id Software, Inc.
 // Copyright(C) 2005 Simon Howard
@@ -22,6 +22,9 @@
 // 02111-1307, USA.
 //
 // $Log$
+// Revision 1.13  2005/10/09 20:19:21  fraggle
+// Handle blinking text in ENDOOM lumps properly.
+//
 // Revision 1.12  2005/10/02 03:23:54  fraggle
 // Fix the length of time that ENDOOM is displayed for
 //
@@ -66,7 +69,7 @@
 //-----------------------------------------------------------------------------
 
 static const char
-rcsid[] = "$Id: i_system.c 148 2005-10-02 03:23:54Z fraggle $";
+rcsid[] = "$Id: i_system.c 183 2005-10-09 20:19:21Z fraggle $";
 
 
 #include <stdlib.h>
@@ -191,8 +194,6 @@
     screendata = TXT_GetScreenData();
     memcpy(screendata, endoom_data, 4000);
 
-    TXT_UpdateScreen();
-    
     // Wait for 10 seconds, or until a keypress or mouse click
 
     waiting = true;
@@ -200,9 +201,11 @@
 
     while (waiting && I_GetTime() < start_ms + 350)
     {
+        TXT_UpdateScreen();
+
         if (!SDL_PollEvent(&ev))
         {
-            I_Sleep(100);
+            I_Sleep(50);
             continue;
         }
 
--- a/textscreen/txt_main.c
+++ b/textscreen/txt_main.c
@@ -1,7 +1,7 @@
 // Emacs style mode select   -*- C++ -*- 
 //-----------------------------------------------------------------------------
 //
-// $Id: txt_main.c 181 2005-10-09 16:42:46Z fraggle $
+// $Id: txt_main.c 183 2005-10-09 20:19:21Z fraggle $
 //
 // Copyright(C) 1993-1996 Id Software, Inc.
 // Copyright(C) 2005 Simon Howard
@@ -22,6 +22,9 @@
 // 02111-1307, USA.
 //
 // $Log$
+// Revision 1.3  2005/10/09 20:19:21  fraggle
+// Handle blinking text in ENDOOM lumps properly.
+//
 // Revision 1.2  2005/10/09 16:42:46  fraggle
 // Cannot do arithmetic on void pointers in standard C
 //
@@ -117,6 +120,16 @@
 
     fg = p[1] & 0xf;
     bg = (p[1] >> 4) & 0xf;
+
+    if (bg & 0x8)
+    {
+        // blinking
+
+        bg &= ~0x8;
+
+        if (SDL_GetTicks() % 500 < 250)
+            fg = bg;
+    }
 
     p = &int10_font_16[character * CHAR_H];