3764 lines
107 KiB
Text
3764 lines
107 KiB
Text
Index: demo/ascii.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/ascii.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- demo/ascii.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/ascii.cc 25 Dec 2002 14:10:14 -0000 1.4
|
|
@@ -12,11 +12,12 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
+#include "ascii.h"
|
|
+
|
|
#define Uses_TRect
|
|
#define Uses_TEvent
|
|
#define Uses_TKeys
|
|
@@ -32,11 +33,15 @@
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
-#include <strstream.h>
|
|
-#include <iomanip.h>
|
|
-
|
|
-#include "ascii.h"
|
|
|
|
+#include <iomanip>
|
|
+#include <ios>
|
|
+#include <sstream>
|
|
+#include <string>
|
|
+
|
|
+using std::ios;
|
|
+using std::ostringstream;
|
|
+using std::string;
|
|
|
|
//
|
|
// TTable functions
|
|
@@ -207,16 +212,16 @@
|
|
{
|
|
TDrawBuffer buf;
|
|
char color = getColor(6);
|
|
- char str[80];
|
|
- ostrstream statusStr( str, sizeof str );
|
|
+ string str;
|
|
+ ostringstream statusStr(str);
|
|
|
|
statusStr
|
|
<< " Char: " << (char ) ((asciiChar == 0) ? 0x20 : asciiChar)
|
|
- << " Decimal: " << setw(3) << (int) asciiChar
|
|
- << " Hex " << hex << setiosflags(ios::uppercase)
|
|
- << setw(2) << (int) asciiChar << " " << ends;
|
|
+ << " Decimal: " << std::setw(3) << (int) asciiChar
|
|
+ << " Hex " << std::hex << std::setiosflags(ios::uppercase)
|
|
+ << std::setw(2) << (int) asciiChar << " " << std::ends;
|
|
|
|
- buf.moveStr(0, str, color);
|
|
+ buf.moveStr(0, str.c_str(), color);
|
|
writeLine(0, 0, 32, 1, buf);
|
|
}
|
|
|
|
Index: demo/ascii.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/ascii.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- demo/ascii.h 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/ascii.h 25 Dec 2002 14:10:14 -0000 1.3
|
|
@@ -9,10 +9,16 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#if !defined( __ASCII_H )
|
|
#define __ASCII_H
|
|
+
|
|
+#define Uses_TEvent
|
|
+#define Uses_TWindow
|
|
+#define Uses_TView
|
|
+#include <tvision/tv.h>
|
|
|
|
const int cmAsciiTableCmdBase = 910;
|
|
const int cmCharFocused = 0;
|
|
Index: demo/calc.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/calc.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- demo/calc.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/calc.cc 25 Dec 2002 14:10:15 -0000 1.5
|
|
@@ -10,9 +10,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TRect
|
|
@@ -29,14 +28,17 @@
|
|
__link( RDialog )
|
|
__link( RButton )
|
|
|
|
+#include "calc.h"
|
|
+
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
-#include <strstream.h>
|
|
-#include <iomanip.h>
|
|
|
|
-#include "calc.h"
|
|
+#include <sstream>
|
|
+#include <iomanip>
|
|
|
|
+using std::string;
|
|
+using std::ostringstream;
|
|
|
|
#define cpCalcPalette "\x13"
|
|
|
|
@@ -158,27 +160,25 @@
|
|
|
|
void TCalcDisplay::setDisplay(double r)
|
|
{
|
|
- int len;
|
|
- char str[64];
|
|
- ostrstream displayStr( str, sizeof str );
|
|
+ string str;
|
|
+ ostringstream displayStr(str);
|
|
|
|
if(r < 0.0)
|
|
{
|
|
sign = '-';
|
|
- displayStr << -r << ends;
|
|
+ displayStr << -r << std::ends;
|
|
}
|
|
else
|
|
{
|
|
- displayStr << r << ends;
|
|
+ displayStr << r << std::ends;
|
|
sign = ' ';
|
|
}
|
|
|
|
- len = strlen(str) - 1; // Minus one so we can use as an index.
|
|
-
|
|
- if(len > DISPLAYLEN)
|
|
+ int len = str.length();
|
|
+ if (len > DISPLAYLEN)
|
|
error();
|
|
else
|
|
- strcpy(number, str);
|
|
+ strcpy(number, str.c_str());
|
|
}
|
|
|
|
|
|
Index: demo/calendar.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/calendar.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- demo/calendar.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/calendar.cc 25 Dec 2002 14:10:15 -0000 1.3
|
|
@@ -9,9 +9,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TRect
|
|
@@ -26,15 +25,19 @@
|
|
__link( RView )
|
|
__link( RWindow )
|
|
|
|
+#include "calendar.h"
|
|
+
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
-#include <strstream.h>
|
|
-#include <iomanip.h>
|
|
#include <time.h>
|
|
|
|
-#include "calendar.h"
|
|
+#include <iomanip>
|
|
+#include <sstream>
|
|
+#include <string>
|
|
|
|
+using std::string;
|
|
+using std::ostringstream;
|
|
|
|
static char *monthNames[] = {
|
|
"",
|
|
@@ -131,9 +134,9 @@
|
|
}
|
|
|
|
|
|
-void TCalendarView::draw()
|
|
+void
|
|
+TCalendarView::draw()
|
|
{
|
|
- char str[23];
|
|
char current = (char)(1 - dayOfWeek(1, month, year));
|
|
char days = (char)( daysInMonth[month] +
|
|
((year % 4 == 0 && month == 2) ? 1 : 0) );
|
|
@@ -146,38 +149,40 @@
|
|
|
|
buf.moveChar(0, ' ', color, 22);
|
|
|
|
- ostrstream s1( str, sizeof str);
|
|
- s1 << setw(9) << monthNames[month] << " " << setw(4) << year
|
|
- << " " << (char) 30 << " " << (char) 31 << " " << ends;
|
|
+ ostringstream s1;
|
|
+ s1 << std::setw(9) << monthNames[month]
|
|
+ << " " << std::setw(4) << year
|
|
+ << " " << (char) 30
|
|
+ << " " << (char) 31 <<
|
|
+ " " << std::ends;
|
|
|
|
- buf.moveStr(0, str, color);
|
|
+ buf.moveStr(0, s1.str().c_str(), color);
|
|
writeLine(0, 0, 22, 1, buf);
|
|
|
|
buf.moveChar(0, ' ', color, 22);
|
|
buf.moveStr(0, "Su Mo Tu We Th Fr Sa", color);
|
|
writeLine(0, 1, 22, 1, buf);
|
|
|
|
- for(i = 1; i <= 6; i++)
|
|
- {
|
|
+ for (i = 1; i <= 6; i++) {
|
|
buf.moveChar(0, ' ', color, 22);
|
|
- for(j = 0; j <= 6; j++)
|
|
- {
|
|
- if(current < 1 || current > days)
|
|
+ for(j = 0; j <= 6; j++) {
|
|
+ if (current < 1 || current > days) {
|
|
buf.moveStr((short)(j*3), " ", color);
|
|
- else
|
|
- {
|
|
- ostrstream s2( str, sizeof str );
|
|
- s2 << setw(2) << (int) current << ends;
|
|
- if(year == curYear && month == curMonth && current ==
|
|
- (int)curDay)
|
|
- buf.moveStr((short)(j*3), str, boldColor);
|
|
- else
|
|
- buf.moveStr((short)(j*3), str, color);
|
|
- }
|
|
+ } else {
|
|
+ ostringstream s2;
|
|
+ s2 << std::setw(2) << (int) current << std::ends;
|
|
+ if (year == curYear &&
|
|
+ month == curMonth &&
|
|
+ current == (int)curDay) {
|
|
+ buf.moveStr((short)(j*3), s2.str().c_str(), boldColor);
|
|
+ } else {
|
|
+ buf.moveStr((short)(j*3), s2.str().c_str(), color);
|
|
+ }
|
|
+ }
|
|
current++;
|
|
- }
|
|
+ }
|
|
writeLine(0, (short)(i+1), 22, 1, buf);
|
|
- }
|
|
+ }
|
|
}
|
|
|
|
|
|
Index: demo/fileview.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/fileview.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- demo/fileview.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/fileview.cc 27 Dec 2002 23:16:40 -0000 1.4
|
|
@@ -9,9 +9,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_MsgBox
|
|
@@ -26,16 +25,17 @@
|
|
__link(RScroller)
|
|
__link(RScrollBar)
|
|
|
|
+#include "tvcmds.h"
|
|
+#include "fileview.h"
|
|
+
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
|
|
-#include <fstream.h>
|
|
-
|
|
-#include "tvcmds.h"
|
|
-#include "fileview.h"
|
|
+#include <fstream>
|
|
|
|
+using std::ifstream;
|
|
|
|
const char * const TFileViewer::name = "TFileViewer";
|
|
|
|
@@ -107,10 +107,7 @@
|
|
else
|
|
{
|
|
char line[maxLineLength+1];
|
|
- while( !lowMemory() &&
|
|
- !fileToView.eof() &&
|
|
- fileToView.get( line, sizeof line ) != 0
|
|
- )
|
|
+ while(!fileToView.eof() && fileToView.get( line, sizeof line ) != 0)
|
|
{
|
|
char c;
|
|
fileToView.get(c); // grab trailing newline
|
|
Index: demo/gadgets.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/gadgets.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- demo/gadgets.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/gadgets.cc 25 Dec 2002 14:10:15 -0000 1.3
|
|
@@ -14,9 +14,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TRect
|
|
@@ -24,14 +23,15 @@
|
|
#define Uses_TDrawBuffer
|
|
#include <tvision/tv.h>
|
|
|
|
+#include "gadgets.h"
|
|
+
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
-#include <strstream.h>
|
|
-#include <iomanip.h>
|
|
#include <time.h>
|
|
|
|
-#include "gadgets.h"
|
|
+#include <sstream>
|
|
+#include <iomanip>
|
|
|
|
//extern "C" unsigned long farcoreleft( void );
|
|
|
|
@@ -84,7 +84,7 @@
|
|
struct farheapinfo heap;
|
|
#endif
|
|
|
|
- ostrstream totalStr( heapStr, sizeof heapStr);
|
|
+ ostringstream totalStr( heapStr, sizeof heapStr);
|
|
|
|
//#if defined( __DPMI32__ )
|
|
// switch( _HEAPEMPTY )
|
|
Index: demo/mousedlg.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/mousedlg.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- demo/mousedlg.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/mousedlg.cc 25 Dec 2002 14:10:15 -0000 1.3
|
|
@@ -11,9 +11,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TRect
|
|
@@ -29,14 +28,11 @@
|
|
#define Uses_TEventQueue
|
|
#include <tvision/tv.h>
|
|
|
|
+#include "mousedlg.h"
|
|
+
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
-#include <strstream.h>
|
|
-#include <iomanip.h>
|
|
-
|
|
-#include "mousedlg.h"
|
|
-
|
|
|
|
#define cpMousePalette "\x07\x08"
|
|
|
|
Index: demo/puzzle.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/puzzle.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- demo/puzzle.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/puzzle.cc 25 Dec 2002 14:10:15 -0000 1.3
|
|
@@ -9,9 +9,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TRect
|
|
@@ -26,20 +25,16 @@
|
|
__link( RView )
|
|
__link( RWindow )
|
|
|
|
+#include "puzzle.h"
|
|
+
|
|
#include <string.h>
|
|
#include <stdio.h> /* SS: for sprintf(...) */
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
-#include <strstream.h>
|
|
-#include <iomanip.h>
|
|
#include <time.h>
|
|
#include <unistd.h>
|
|
|
|
-#include "puzzle.h"
|
|
-
|
|
-
|
|
#define cpPuzzlePalette "\x06\x07"
|
|
-
|
|
|
|
//
|
|
// TPuzzleView functions & static variables
|
|
Index: demo/tvdemo1.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/demo/tvdemo1.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- demo/tvdemo1.cc 20 Dec 2002 12:06:16 -0000 1.1
|
|
+++ demo/tvdemo1.cc 25 Dec 2002 14:10:15 -0000 1.4
|
|
@@ -9,9 +9,8 @@
|
|
* Copyright (c) 1994 by Borland International
|
|
* All Rights Reserved.
|
|
*
|
|
- */
|
|
-/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TView
|
|
@@ -40,6 +39,8 @@
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
+using std::ios;
|
|
+
|
|
/* SS: changed */
|
|
|
|
//#ifdef __DPMI32__
|
|
@@ -135,7 +136,7 @@
|
|
if ((event.message.command == cmHelp) && ( helpInUse == False))
|
|
{
|
|
helpInUse = True;
|
|
- helpStrm = new fpstream(HELP_FILENAME, ios::in|ios::bin);
|
|
+ helpStrm = new fpstream(HELP_FILENAME, ios::in|ios::binary);
|
|
hFile = new THelpFile(*helpStrm);
|
|
if (!helpStrm)
|
|
{
|
|
@@ -219,7 +220,7 @@
|
|
else
|
|
{
|
|
fclose(fp);
|
|
- fpstream *f = new fpstream("TVDEMO.DST", ios::in|ios::bin);
|
|
+ fpstream *f = new fpstream("TVDEMO.DST", ios::in|ios::binary);
|
|
if( !f )
|
|
messageBox("Could not open desktop file", mfOKButton | mfError);
|
|
else
|
|
@@ -238,7 +239,7 @@
|
|
|
|
void TVDemo::saveDesktop()
|
|
{
|
|
- fpstream *f = new fpstream("TVDEMO.DST", ios::out|ios::bin);
|
|
+ fpstream *f = new fpstream("TVDEMO.DST", ios::out|ios::binary);
|
|
|
|
if( f )
|
|
{
|
|
Index: lib/Makefile.am
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/Makefile.am,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/Makefile.am 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/Makefile.am 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -13,7 +13,7 @@
|
|
CLEANFILES = tvision
|
|
|
|
pkginclude_HEADERS = \
|
|
-app.h buffers.h colorsel.h dialogs.h drawbuf.h editors.h \
|
|
+app.h colorsel.h dialogs.h drawbuf.h editors.h \
|
|
help.h helpbase.h menus.h msgbox.h objects.h outline.h resource.h \
|
|
stddlg.h system.h textview.h tkeys.h tobjstrm.h ttypes.h tv.h \
|
|
tvconfig.h tvobjs.h util.h validate.h views.h
|
|
@@ -37,7 +37,7 @@
|
|
TSortedCollection.cc TStaticText.cc TStatusLine.cc TStrListMaker.cc \
|
|
TStringCollection.cc TValidator.cc TView.cc TWindow.cc allnames.cc asm.cc \
|
|
colorsel.cc drivers.cc editstat.cc help.cc helpbase.cc histlist.cc menu.cc \
|
|
-misc.cc msgbox.cc new.cc palette.cc sall.cc stddlg.cc system.cc textview.cc \
|
|
+misc.cc msgbox.cc palette.cc sall.cc stddlg.cc system.cc textview.cc \
|
|
tobjstrm.cc tvtext.cc
|
|
|
|
libtvision_la_SOURCES = tvision TApplication.cc TBackground.cc TButton.cc \
|
|
@@ -53,5 +53,5 @@
|
|
TSortedCollection.cc TStaticText.cc TStatusLine.cc TStrListMaker.cc \
|
|
TStringCollection.cc TValidator.cc TView.cc TWindow.cc allnames.cc asm.cc \
|
|
colorsel.cc drivers.cc editstat.cc help.cc helpbase.cc histlist.cc menu.cc \
|
|
-misc.cc msgbox.cc new.cc palette.cc sall.cc stddlg.cc system.cc textview.cc \
|
|
+misc.cc msgbox.cc palette.cc sall.cc stddlg.cc system.cc textview.cc \
|
|
tobjstrm.cc tvtext.cc
|
|
Index: lib/TApplication.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TApplication.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/TApplication.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TApplication.cc 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -14,9 +14,6 @@
|
|
#define Uses_TObject
|
|
#define Uses_TMouse
|
|
#define Uses_TApplication
|
|
-#ifndef __UNPATCHED
|
|
-#define Uses_TVMemMgr
|
|
-#endif
|
|
#include <tvision/tv.h>
|
|
|
|
void initHistory();
|
|
@@ -41,9 +38,6 @@
|
|
/* SS: changed */
|
|
|
|
TScreen::suspend();
|
|
-#ifndef __UNPATCHED
|
|
- TVMemMgr::suspend(); // Release discardable memory.
|
|
-#endif
|
|
}
|
|
|
|
void TApplication::resume()
|
|
Index: lib/TFileEditor.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TFileEditor.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- lib/TFileEditor.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TFileEditor.cc 25 Dec 2002 14:10:17 -0000 1.5
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TProgram
|
|
@@ -18,12 +19,18 @@
|
|
#define Uses_ipstream
|
|
#include <tvision/tv.h>
|
|
|
|
-#include <fstream.h>
|
|
+#include <fstream>
|
|
+
|
|
#include <limits.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
+using std::ifstream;
|
|
+using std::ios;
|
|
+using std::ofstream;
|
|
+using std::streampos;
|
|
+
|
|
inline ushort min( ushort u1, ushort u2 )
|
|
{
|
|
return u1 < u2 ? u1 : u2;
|
|
@@ -89,7 +96,7 @@
|
|
|
|
Boolean TFileEditor::loadFile()
|
|
{
|
|
- ifstream f( fileName, ios::in | ios::bin );
|
|
+ ifstream f( fileName, ios::in | ios::binary );
|
|
if( !f )
|
|
{
|
|
setBufLen( 0 );
|
|
@@ -97,7 +104,7 @@
|
|
}
|
|
else
|
|
{
|
|
- uint fSize = filelength( f.rdbuf()->fd() );
|
|
+ streampos fSize = filelength(f);
|
|
if( setBufSize(fSize) == False )
|
|
{
|
|
editorDialog( edOutOfMemory );
|
|
@@ -161,7 +168,7 @@
|
|
rename( fileName, backupName );
|
|
}
|
|
|
|
- ofstream f( fileName, ios::out | ios::bin );
|
|
+ ofstream f( fileName, ios::out | ios::binary );
|
|
|
|
if( !f )
|
|
{
|
|
Index: lib/TFileList.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TFileList.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/TFileList.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TFileList.cc 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -9,7 +9,6 @@
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
*/
|
|
|
|
-#define Uses_TVMemMgr
|
|
#define Uses_MsgBox
|
|
#define Uses_TFileList
|
|
#define Uses_TRect
|
|
@@ -130,21 +129,7 @@
|
|
t.ft_year = broken->tm_year - 80;
|
|
time = *(long *) &t;
|
|
}
|
|
-
|
|
- void *operator new( size_t );
|
|
-
|
|
};
|
|
-
|
|
-void *DirSearchRec::operator new( size_t sz )
|
|
-{
|
|
- void *temp = ::operator new( sz );
|
|
- if( TVMemMgr::safetyPoolExhausted() )
|
|
- {
|
|
- delete temp;
|
|
- temp = 0;
|
|
- }
|
|
- return temp;
|
|
-}
|
|
|
|
void TFileList::readDirectory( const char *aWildCard )
|
|
{
|
|
Index: lib/TGroup.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TGroup.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/TGroup.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TGroup.cc 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -16,7 +16,6 @@
|
|
#define Uses_TEvent
|
|
#define Uses_opstream
|
|
#define Uses_ipstream
|
|
-#define Uses_TVMemMgr
|
|
#include <tvision/tv.h>
|
|
|
|
TView *TheTopView = 0;
|
|
Index: lib/TIndicator.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TIndicator.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- lib/TIndicator.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TIndicator.cc 25 Dec 2002 14:10:17 -0000 1.5
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TIndicator
|
|
@@ -18,7 +19,13 @@
|
|
#include <tvision/tv.h>
|
|
|
|
#include <string.h>
|
|
-#include <strstream.h>
|
|
+
|
|
+#include <sstream>
|
|
+#include <string>
|
|
+
|
|
+using std::ends;
|
|
+using std::ostringstream;
|
|
+using std::string;
|
|
|
|
#define cpIndicator "\x02\x03"
|
|
|
|
@@ -32,7 +39,6 @@
|
|
{
|
|
uchar color, frame;
|
|
TDrawBuffer b;
|
|
- char s[15];
|
|
|
|
if( (state & sfDragging) == 0 )
|
|
{
|
|
@@ -48,12 +54,14 @@
|
|
b.moveChar( 0, frame, color, size.x );
|
|
if( modified )
|
|
b.putChar( 0, 15 );
|
|
- ostrstream os( s, 15 );
|
|
-
|
|
- os << ' ' << (location.y+1)
|
|
- << ':' << (location.x+1) << ' ' << ends;
|
|
|
|
- b.moveCStr( 8-int(strchr(s, ':')-s), s, color);
|
|
+ string s;
|
|
+ ostringstream os(s);
|
|
+ os << ' ' << (location.y+1) << ':' << (location.x+1) << ' ' << ends;
|
|
+
|
|
+ b.moveCStr(8 - int(strchr(s.c_str(), ':') - s.c_str()),
|
|
+ s.c_str(),
|
|
+ color);
|
|
writeBuf(0, 0, size.x, 1, b);
|
|
}
|
|
|
|
Index: lib/TMemo.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TMemo.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- lib/TMemo.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TMemo.cc 25 Dec 2002 14:10:17 -0000 1.4
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TKeys
|
|
@@ -19,6 +20,8 @@
|
|
|
|
#include <string.h>
|
|
|
|
+using std::ios;
|
|
+
|
|
#define cpMemo "\x1A\x1B"
|
|
|
|
TMemo::TMemo( const TRect& bounds,
|
|
@@ -86,7 +89,7 @@
|
|
setBufLen( length );
|
|
}
|
|
else
|
|
- is.seekg( is.tellg() + length );
|
|
+ is.seekg( length, ios::cur );
|
|
return this;
|
|
}
|
|
|
|
Index: lib/TProgram.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TProgram.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/TProgram.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TProgram.cc 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -22,9 +22,6 @@
|
|
#define Uses_TStatusDef
|
|
#define Uses_TStatusItem
|
|
#define Uses_TDialog
|
|
-#ifndef __UNPATCHED
|
|
-#define Uses_TVMemMgr
|
|
-#endif
|
|
#include <tvision/tv.h>
|
|
|
|
// Public variables
|
|
@@ -90,9 +87,6 @@
|
|
menuBar = 0;
|
|
deskTop = 0;
|
|
TGroup::shutDown();
|
|
-#ifndef __UNPATCHED
|
|
- TVMemMgr::clearSafetyPool(); // Release the safety pool buffer.
|
|
-#endif
|
|
}
|
|
|
|
Boolean TProgram::canMoveFocus()
|
|
@@ -309,11 +303,6 @@
|
|
return NULL;
|
|
}
|
|
|
|
-
|
|
-void TProgram::outOfMemory()
|
|
-{
|
|
-}
|
|
-
|
|
void TProgram::putEvent( TEvent & event )
|
|
{
|
|
pending = event;
|
|
@@ -339,12 +328,6 @@
|
|
{
|
|
if( p == 0 )
|
|
return 0;
|
|
- if( lowMemory() )
|
|
- {
|
|
- destroy( p );
|
|
- outOfMemory();
|
|
- return 0;
|
|
- }
|
|
if( !p->valid( cmValid ) )
|
|
{
|
|
destroy( p );
|
|
Index: lib/TResourceFile.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TResourceFile.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.7
|
|
diff -u -r1.1 -r1.7
|
|
--- lib/TResourceFile.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TResourceFile.cc 25 Dec 2002 14:10:17 -0000 1.7
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TResourceFile
|
|
@@ -17,88 +18,82 @@
|
|
#define Uses_TResourceCollection
|
|
#include <tvision/tv.h>
|
|
|
|
+#include <assert.h>
|
|
+
|
|
+#include <ios>
|
|
+
|
|
+using std::ios;
|
|
+using std::streampos;
|
|
+
|
|
/*
|
|
* SS: Warning, this file is non-portable. It is not used by any of the
|
|
* classes in the library.
|
|
*/
|
|
const long rStreamMagic = 0x52504246uL; // 'FBPR'
|
|
|
|
-struct Count_type
|
|
-{
|
|
- ushort lastCount;
|
|
- ushort pageCount;
|
|
-};
|
|
|
|
-struct Info_type
|
|
-{
|
|
- ushort infoType;
|
|
- long infoSize;
|
|
-};
|
|
-
|
|
-struct THeader
|
|
-{
|
|
- ushort signature;
|
|
- union
|
|
- {
|
|
- Count_type count;
|
|
- Info_type info;
|
|
- };
|
|
-};
|
|
+TResourceFile::TResourceFile( fpstream *aStream )
|
|
+ : TObject(),
|
|
+ stream(aStream),
|
|
+ basePos(stream->tellp())
|
|
+{
|
|
+ struct Count_type {
|
|
+ ushort lastCount;
|
|
+ ushort pageCount;
|
|
+ };
|
|
+
|
|
+ struct Info_type {
|
|
+ ushort infoType;
|
|
+ long infoSize;
|
|
+ };
|
|
+
|
|
+ struct THeader {
|
|
+ ushort signature;
|
|
+ union {
|
|
+ Count_type count;
|
|
+ Info_type info;
|
|
+ };
|
|
+ };
|
|
+
|
|
+ streampos streamSize = filelength(*stream);
|
|
+ THeader header;
|
|
+ int found = 0;
|
|
|
|
-
|
|
-TResourceFile::TResourceFile( fpstream *aStream ) : TObject()
|
|
-{
|
|
- THeader *header;
|
|
- int handle;
|
|
- int found;
|
|
int repeat;
|
|
- long streamSize;
|
|
-
|
|
- stream = aStream;
|
|
- basePos = stream->tellp();
|
|
- handle = stream->rdbuf()->fd();
|
|
- streamSize = filelength(handle);
|
|
- header = new THeader;
|
|
- found = 0;
|
|
do {
|
|
repeat = 0;
|
|
if (basePos <= (streamSize - (long)sizeof(THeader)))
|
|
{
|
|
stream->seekg(basePos, ios::beg);
|
|
- stream->readBytes(header, sizeof(THeader));
|
|
- if (header->signature == 0x5a4d)
|
|
+ stream->readBytes(&header, sizeof(THeader));
|
|
+ if (header.signature == 0x5a4d)
|
|
{
|
|
- basePos += ((header->count.pageCount * 512L) -
|
|
- (-header->count.lastCount & 511));
|
|
+ basePos += ((header.count.pageCount * 512L) -
|
|
+ (-header.count.lastCount & 511));
|
|
repeat = 1;
|
|
}
|
|
- else if (header->signature == 0x4246)
|
|
+ else if (header.signature == 0x4246)
|
|
{
|
|
- if (header->info.infoType == 0x5250)
|
|
+ if (header.info.infoType == 0x5250)
|
|
found = 1;
|
|
else
|
|
{
|
|
basePos +=
|
|
- header->info.infoSize + 16 - (header->info.infoSize)%16;
|
|
+ header.info.infoSize + 16 - (header.info.infoSize)%16;
|
|
repeat = 1;
|
|
}
|
|
}
|
|
}
|
|
- } while (repeat);
|
|
+ } while (repeat);
|
|
|
|
- delete header;
|
|
-
|
|
- if (found)
|
|
- {
|
|
- stream->seekg(basePos + sizeof(long) * 2, ios::beg);
|
|
- *stream >> indexPos;
|
|
- stream->seekg(basePos + indexPos, ios::beg);
|
|
- *stream >> index;
|
|
- }
|
|
- else
|
|
- {
|
|
- indexPos = sizeof(long) * 3;
|
|
- index = new TResourceCollection(0, 8);
|
|
+ if (found) {
|
|
+ stream->seekg(basePos + sizeof(long) * 2, ios::beg);
|
|
+ *stream >> indexPos;
|
|
+ stream->seekg(basePos + indexPos, ios::beg);
|
|
+ *stream >> index;
|
|
+ } else {
|
|
+ indexPos = sizeof(long) * 3;
|
|
+ index = new TResourceCollection(0, 8);
|
|
}
|
|
}
|
|
|
|
@@ -127,16 +120,17 @@
|
|
|
|
void TResourceFile::flush()
|
|
{
|
|
- long lenRez;
|
|
-
|
|
- if (modified == True)
|
|
- {
|
|
+ if (modified == True) {
|
|
stream->seekp(basePos + indexPos, ios::beg);
|
|
*stream << index;
|
|
- lenRez = stream->tellp() - basePos - sizeof(long) * 2;
|
|
+#if 1
|
|
+ assert(0); /* XXX */
|
|
+#else
|
|
+ long lenRez = stream->tellp() - basePos - sizeof(long) * 2;
|
|
stream->seekp(basePos, ios::beg);
|
|
*stream << rStreamMagic;
|
|
*stream << lenRez;
|
|
+#endif
|
|
*stream << indexPos;
|
|
stream->flush();
|
|
modified = False;
|
|
Index: lib/TStrListMaker.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/TStrListMaker.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- lib/TStrListMaker.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/TStrListMaker.cc 25 Dec 2002 14:10:17 -0000 1.4
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TStringList
|
|
Index: lib/app.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/app.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/app.h 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/app.h 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -666,18 +666,6 @@
|
|
*/
|
|
virtual void initScreen();
|
|
/**
|
|
- * Called on out of memory condition.
|
|
- *
|
|
- * It is called from @ref validView() whenever @ref lowMemory() returns
|
|
- * True.
|
|
- *
|
|
- * This happens when there is few free memory. Of course this should
|
|
- * rarely happen. This method may be redefined to tell the user (by
|
|
- * calling @ref messageBox() for example) that there is not free memory
|
|
- * to end the current task.
|
|
- */
|
|
- virtual void outOfMemory();
|
|
- /**
|
|
* Sets a pending event.
|
|
*
|
|
* Puts an event in the pending state, by storing a copy of the `event'
|
|
@@ -726,10 +714,6 @@
|
|
*
|
|
* First, if `p' is 0 the call returns 0.
|
|
*
|
|
- * Next, if @ref lowMemory() returns True the view pointed by `p' is
|
|
- * released by calling @ref TObject::destroy() followed by
|
|
- * @ref outOfMemory() and the function returns 0.
|
|
- *
|
|
* Last if a call to `p->valid(cmValid)' returns False the view pointed by
|
|
* `p' is released and the function returns 0.
|
|
* @see TView::valid
|
|
@@ -746,7 +730,7 @@
|
|
*
|
|
* This method releases all the resources allocated by TProgram. It sets
|
|
* pointers @ref statusLine, @ref menuBar and @ref deskTop to 0 and then
|
|
- * calls @ref TGroup::shutDown() and @ref TVMemMgr::clearSafetyPool().
|
|
+ * calls @ref TGroup::shutDown().
|
|
*/
|
|
virtual void shutDown();
|
|
/**
|
|
Index: lib/helpbase.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/helpbase.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- lib/helpbase.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/helpbase.cc 25 Dec 2002 14:10:17 -0000 1.5
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TStreamableClass
|
|
@@ -31,6 +32,8 @@
|
|
#include <string.h>
|
|
#include <sys/stat.h>
|
|
|
|
+using std::streampos;
|
|
+
|
|
TCrossRefHandler crossRefHandler = notAssigned;
|
|
|
|
// THelpTopic
|
|
@@ -549,15 +552,10 @@
|
|
|
|
THelpFile::THelpFile( fpstream& s )
|
|
{
|
|
- long magic;
|
|
- int handle;
|
|
- long size;
|
|
+ long magic = 0;
|
|
|
|
- magic = 0;
|
|
- s.seekg(0);
|
|
- handle = s.rdbuf()->fd();
|
|
- size = filelength(handle);
|
|
s.seekg(0);
|
|
+ streampos size = filelength(s);
|
|
if (size > (long)sizeof(magic))
|
|
s >> magic;
|
|
if (magic != magicHeader)
|
|
@@ -580,24 +578,15 @@
|
|
|
|
THelpFile::~THelpFile(void)
|
|
{
|
|
- long magic, size;
|
|
- int handle;
|
|
|
|
if (modified == True)
|
|
{
|
|
stream->seekp(indexPos);
|
|
*stream << index;
|
|
+ long magic = magicHeader;
|
|
stream->seekp(0);
|
|
- magic = magicHeader;
|
|
- handle = stream->rdbuf()->fd();
|
|
-//
|
|
-// note: at this time, a bug in filelength leaves the seek pointer at
|
|
-// the end of file, so we must save and restore the seek pointer
|
|
-// around the call; this can be removed when filelength is fixed.
|
|
-//
|
|
- streampos sp=stream->tellp();
|
|
- size = filelength(handle) - 8;
|
|
- stream->seekp(sp);
|
|
+ streampos size = filelength(*stream);
|
|
+ size =- 8;
|
|
*stream << magic;
|
|
*stream << size;
|
|
*stream << indexPos;
|
|
Index: lib/histlist.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/histlist.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/histlist.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/histlist.cc 27 Dec 2002 23:16:43 -0000 1.2
|
|
@@ -21,25 +21,11 @@
|
|
|
|
HistRec( uchar nId, const char *nStr );
|
|
|
|
- void *operator new( size_t );
|
|
- void *operator new( size_t, HistRec * );
|
|
-
|
|
uchar id;
|
|
uchar len;
|
|
char str[1];
|
|
|
|
};
|
|
-
|
|
-void *HistRec::operator new( size_t, HistRec *hr )
|
|
-{
|
|
- return hr;
|
|
-}
|
|
-
|
|
-void *HistRec::operator new( size_t )
|
|
-{
|
|
- abort();
|
|
- return 0;
|
|
-}
|
|
|
|
inline HistRec::HistRec( uchar nId, const char *nStr ) :
|
|
id( nId ),
|
|
Index: lib/misc.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/misc.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/misc.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/misc.cc 27 Dec 2002 23:16:44 -0000 1.2
|
|
@@ -14,7 +14,6 @@
|
|
#define Uses_TGroup
|
|
#define Uses_TEvent
|
|
#define Uses_TObject
|
|
-#define Uses_TVMemMgr
|
|
#define Uses_TView
|
|
#define Uses_pstream
|
|
#include <tvision/tv.h>
|
|
@@ -37,11 +36,6 @@
|
|
return event.message.infoPtr;
|
|
else
|
|
return 0;
|
|
-}
|
|
-
|
|
-Boolean lowMemory()
|
|
-{
|
|
- return Boolean(TVMemMgr::safetyPoolExhausted());
|
|
}
|
|
|
|
/* from NEWSTR.CPP */
|
|
Index: lib/system.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/system.cc,v
|
|
retrieving revision 1.2
|
|
retrieving revision 1.8
|
|
diff -u -r1.2 -r1.8
|
|
--- lib/system.cc 20 Dec 2002 12:19:01 -0000 1.2
|
|
+++ lib/system.cc 25 Dec 2002 14:10:17 -0000 1.8
|
|
@@ -23,11 +23,12 @@
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
+ *
|
|
+ * Modified by Sergey Clushin <serg@lamport.ru>, <Clushin@deol.ru>
|
|
+ * Modified by Dmitrij Korovkin <tkf@glasnet.ru>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
-/* Modified by Sergey Clushin <serg@lamport.ru>, <Clushin@deol.ru> */
|
|
-/* Modified by Dmitrij Korovkin <tkf@glasnet.ru> */
|
|
-
|
|
#define Uses_TButton
|
|
#define Uses_TColorSelector
|
|
#define Uses_TDeskTop
|
|
@@ -47,10 +48,11 @@
|
|
#define Uses_TStatusLine
|
|
#include <tvision/tv.h>
|
|
|
|
+#include <fstream>
|
|
+#include <iostream>
|
|
+
|
|
#include <ctype.h>
|
|
#include <fcntl.h>
|
|
-#include <fstream.h>
|
|
-#include <iostream.h>
|
|
#include <signal.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
@@ -62,6 +64,13 @@
|
|
|
|
#include <config.h> /* configuration file */
|
|
|
|
+using std::endl;
|
|
+using std::ios;
|
|
+using std::istream;
|
|
+using std::ofstream;
|
|
+using std::streambuf;
|
|
+using std::streampos;
|
|
+
|
|
#ifdef ENABLE_FBSDM
|
|
/* #include <machine/console.h> */
|
|
#define CONS_MOUSECTL _IOWR('c', 10, mouse_info_t)
|
|
@@ -2300,36 +2309,24 @@
|
|
}
|
|
}
|
|
|
|
-/*
|
|
- * Returns the length of a file.
|
|
+/**
|
|
+ * Returns the length of the file associated with the stream.
|
|
*/
|
|
-
|
|
-long int filelength(int fd)
|
|
+streampos
|
|
+filelength(istream &s)
|
|
{
|
|
- struct stat s;
|
|
-
|
|
/*
|
|
- * This should handle any regular file.
|
|
+ * First get curent position, then get position after seeking
|
|
+ * from begining to the end, finally seek back to original
|
|
+ * position.
|
|
*/
|
|
- if (fstat(fd, &s) == 0 && s.st_size > 0) return s.st_size;
|
|
- else
|
|
- {
|
|
- char buf[1024];
|
|
- int len, size = 0;
|
|
+ streampos curpos = s.tellg();
|
|
|
|
- /*
|
|
- * This works with special files which are not empty, even if
|
|
- * their size is zero, like those in the `/proc' directory.
|
|
- */
|
|
- off_t old = lseek(fd, 0, SEEK_CUR); /* save position */
|
|
- lseek(fd, 0, SEEK_SET); /* go to the beginning */
|
|
- while ((len = read(fd, buf, sizeof(buf))) > 0)
|
|
- {
|
|
- size += len;
|
|
- }
|
|
- lseek(fd, old, SEEK_SET); /* restore old position */
|
|
- return size;
|
|
- }
|
|
+ s.seekg(0, ios::end);
|
|
+ streampos size = s.tellg();
|
|
+
|
|
+ s.seekg(curpos);
|
|
+ return size;
|
|
}
|
|
|
|
/*
|
|
Index: lib/textview.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/textview.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- lib/textview.cc 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/textview.cc 25 Dec 2002 14:10:17 -0000 1.4
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TTextDevice
|
|
@@ -15,6 +16,9 @@
|
|
#include <tvision/tv.h>
|
|
|
|
#include <string.h>
|
|
+
|
|
+using std::ostream;
|
|
+using std::streamsize;
|
|
|
|
TTextDevice::TTextDevice( const TRect& bounds,
|
|
TScrollBar *aHScrollBar,
|
|
Index: lib/textview.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/textview.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- lib/textview.h 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/textview.h 25 Dec 2002 14:10:17 -0000 1.3
|
|
@@ -7,6 +7,7 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#if defined( Uses_TTextDevice ) && !defined( __TTextDevice )
|
|
@@ -16,7 +17,7 @@
|
|
* textview.h
|
|
*/
|
|
|
|
-#include <iostream.h>
|
|
+#include <iostream>
|
|
|
|
class TRect;
|
|
class TScrollBar;
|
|
@@ -168,14 +169,12 @@
|
|
#if defined( Uses_otstream ) && !defined( __otstream )
|
|
#define __otstream
|
|
|
|
-class ostream;
|
|
-
|
|
-#include <iostream.h>
|
|
+#include <iostream>
|
|
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
-class TerminalBuf: public streambuf
|
|
+class TerminalBuf: public std::streambuf
|
|
{
|
|
protected:
|
|
/**
|
|
@@ -208,7 +207,7 @@
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
-class otstream : public ostream
|
|
+class otstream : public std::ostream
|
|
{
|
|
protected:
|
|
/**
|
|
Index: lib/tobjstrm.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/tobjstrm.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.9
|
|
diff -u -r1.1 -r1.9
|
|
--- lib/tobjstrm.h 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/tobjstrm.h 27 Dec 2002 23:16:44 -0000 1.9
|
|
@@ -1,5 +1,5 @@
|
|
-/*
|
|
- * tobjstrm.h
|
|
+/**
|
|
+ * @file tobjstrm.h
|
|
*
|
|
* Turbo Vision - Version 2.0
|
|
*
|
|
@@ -7,11 +7,14 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
-/** \file tobjstrm.h
|
|
- * tobjstrm.h
|
|
- */
|
|
+#include <ios>
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <limits.h>
|
|
|
|
/**
|
|
* Undocumented.
|
|
@@ -19,13 +22,11 @@
|
|
typedef unsigned P_id_type;
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class TStreamable */
|
|
/* */
|
|
/* This is the base class for all storable objects. It provides */
|
|
/* three member functions, streamableName(), read(), and write(), which */
|
|
/* must be overridden in every derived class. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if !defined( __fLink_def )
|
|
@@ -117,18 +118,12 @@
|
|
#endif // Uses_TStreamable
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class TStreamableClass */
|
|
-/* */
|
|
-/* Used internally by TStreamableTypes and pstream. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_TStreamableClass ) && !defined( __TStreamableClass )
|
|
#define __TStreamableClass
|
|
|
|
-#include <limits.h>
|
|
-
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
@@ -154,9 +149,9 @@
|
|
*/
|
|
class TStreamableClass
|
|
{
|
|
- friend TStreamableTypes;
|
|
- friend opstream;
|
|
- friend ipstream;
|
|
+ friend class TStreamableTypes;
|
|
+ friend class opstream;
|
|
+ friend class ipstream;
|
|
public:
|
|
/**
|
|
* Creates a TStreamable object with the given name and the given builder
|
|
@@ -184,7 +179,7 @@
|
|
* typedef TStreamable *(*BUILDER)();
|
|
* </pre>
|
|
*/
|
|
- TStreamableClass( const char *aName, BUILDER aBuild, int aDelta );
|
|
+ TStreamableClass(const char *aName, BUILDER aBuild, int aDelta );
|
|
private:
|
|
const char *name;
|
|
BUILDER build;
|
|
@@ -194,13 +189,7 @@
|
|
#endif // Uses_TStreamableClass
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class TStreamableTypes */
|
|
-/* */
|
|
-/* Maintains a database of all registered types in the application. */
|
|
-/* Used by opstream and ipstream to find the functions to read and */
|
|
-/* write objects. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_TStreamableTypes ) && !defined( __TStreamableTypes )
|
|
@@ -235,20 +224,12 @@
|
|
/**
|
|
* Registers the argument class by inserting `d' in the collection.
|
|
*/
|
|
- void registerType( const TStreamableClass *d );
|
|
+ void registerType(const TStreamableClass *d );
|
|
/**
|
|
* Returns a pointer to the class in the collection corresponding to the
|
|
* argument `name', or returns 0 if no match.
|
|
*/
|
|
- const TStreamableClass *lookup( const char *name );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- void *operator new( size_t sz ) { return ::operator new( sz ); }
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- void *operator new( size_t, void * );
|
|
+ const TStreamableClass *lookup(const char name[]);
|
|
private:
|
|
/**
|
|
* Undocumented.
|
|
@@ -263,15 +244,7 @@
|
|
#endif // Uses_TStreamableTypes
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class TPWrittenObjects */
|
|
-/* */
|
|
-/* Maintains a database of all objects that have been written to the */
|
|
-/* current object stream. */
|
|
-/* */
|
|
-/* Used by opstream when it writes a pointer onto a stream to determine */
|
|
-/* whether the object pointed to has already been written to the stream. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_TPWrittenObjects ) && !defined( __TPWrittenObjects )
|
|
@@ -286,7 +259,7 @@
|
|
*/
|
|
class TPWrittenObjects : public TNSSortedCollection
|
|
{
|
|
- friend opstream;
|
|
+ friend class opstream;
|
|
public:
|
|
/**
|
|
* Undocumented.
|
|
@@ -306,11 +279,11 @@
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
- void registerObject( const void *adr );
|
|
+ void registerObject(const void *adr );
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
- P_id_type find( const void *adr );
|
|
+ P_id_type find(const void *adr );
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
@@ -326,11 +299,7 @@
|
|
};
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class TPWObj */
|
|
-/* */
|
|
-/* Used internally by TPWrittenObjects. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
@@ -341,9 +310,9 @@
|
|
*/
|
|
class TPWObj
|
|
{
|
|
- friend TPWrittenObjects;
|
|
+ friend class TPWrittenObjects;
|
|
private:
|
|
- TPWObj( const void *adr, P_id_type id );
|
|
+ TPWObj(const void *adr, P_id_type id );
|
|
const void *address;
|
|
P_id_type ident;
|
|
};
|
|
@@ -351,15 +320,7 @@
|
|
#endif // Uses_TPWrittenObjects
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class TPReadObjects */
|
|
-/* */
|
|
-/* Maintains a database of all objects that have been read from the */
|
|
-/* current persistent stream. */
|
|
-/* */
|
|
-/* Used by ipstream when it reads a pointer from a stream to determine */
|
|
-/* the address of the object being referred to. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_TPReadObjects ) && !defined( __TPReadObjects )
|
|
@@ -375,7 +336,7 @@
|
|
*/
|
|
class TPReadObjects : public TNSCollection
|
|
{
|
|
- friend ipstream;
|
|
+ friend class ipstream;
|
|
public:
|
|
/**
|
|
* Undocumented.
|
|
@@ -393,7 +354,7 @@
|
|
* Sets the collection @ref limit to 0 without destroying the collection.
|
|
*/
|
|
~TPReadObjects();
|
|
- void registerObject( const void *adr );
|
|
+ void registerObject(const void *adr );
|
|
const void *find( P_id_type id );
|
|
P_id_type curId;
|
|
};
|
|
@@ -401,164 +362,62 @@
|
|
#endif // Uses_TPReadObjects
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class pstream */
|
|
-/* */
|
|
-/* Base class for handling streamable objects. */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_pstream ) && !defined( __pstream )
|
|
#define __pstream
|
|
|
|
-class streambuf;
|
|
-
|
|
-#include <iostream.h>
|
|
-
|
|
class TStreamableTypes;
|
|
|
|
/**
|
|
* pstream is the base class for handling streamable objects.
|
|
* @short The base class for handling streamable objects
|
|
*/
|
|
-class pstream
|
|
-{
|
|
- friend TStreamableTypes;
|
|
+class pstream {
|
|
+protected:
|
|
+ /**
|
|
+ * Pointer to the @ref TStreamableTypes data base of all registered types
|
|
+ * in this application.
|
|
+ */
|
|
+ static TStreamableTypes *types;
|
|
+
|
|
public:
|
|
+ pstream();
|
|
+ virtual ~pstream();
|
|
+
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
enum StreamableError { peNotRegistered, peInvalidType };
|
|
+
|
|
/**
|
|
* Undocumented.
|
|
*/
|
|
enum PointerTypes { ptNull, ptIndexed, ptObject };
|
|
- /**
|
|
- * This form creates a buffered pstream with the given buffer and sets the
|
|
- * @ref bp data member to `buf'. The @ref state data member is set to 0.
|
|
- */
|
|
- pstream( streambuf *buf );
|
|
- /**
|
|
- * Destroys the pstream object.
|
|
- */
|
|
- virtual ~pstream();
|
|
- /**
|
|
- * Returns the current @ref state value.
|
|
- */
|
|
- int rdstate() const;
|
|
- /**
|
|
- * Returns nonzero on end of stream.
|
|
- */
|
|
- int eof() const;
|
|
- /**
|
|
- * Returns nonzero if a stream operation fails.
|
|
- */
|
|
- int fail() const;
|
|
- /**
|
|
- * Returns nonzero if an error occurs.
|
|
- */
|
|
- int bad() const;
|
|
- /**
|
|
- * Returns nonzero if no state bits are set (that is, no errors occurred).
|
|
- */
|
|
- int good() const;
|
|
- /**
|
|
- * Set the stream @ref state data member to the given value (defaults
|
|
- * to 0).
|
|
- */
|
|
- void clear( int sState = 0 );
|
|
- /**
|
|
- * Overloads the pointer-to-void cast operator.
|
|
- *
|
|
- * Returns 0 if operation has failed (that is, @ref fail() returned
|
|
- * nonzero); otherwise returns nonzero.
|
|
- */
|
|
- operator void *() const;
|
|
- /**
|
|
- * Overloads the NOT operator. Returns the value returned by @ref fail().
|
|
- */
|
|
- int operator ! () const;
|
|
- /**
|
|
- * Returns the @ref bp pointer to this stream's assigned buffer.
|
|
- */
|
|
- streambuf * rdbuf() const;
|
|
- /**
|
|
- * Creates the associated @ref TStreamableTypes object types. Called by the
|
|
- * @ref TStreamableClass constructor.
|
|
- */
|
|
+
|
|
+ void error(StreamableError);
|
|
+ void error(StreamableError, const TStreamable &);
|
|
+
|
|
static void initTypes();
|
|
- /**
|
|
- * Sets the given error condition, where StreamableError is defined as
|
|
- * follows:
|
|
- *
|
|
- * <pre>
|
|
- * enum StreamableError { peNotRegistered, peInvalidType };
|
|
- * </pre>
|
|
- */
|
|
- void error( StreamableError );
|
|
- /**
|
|
- * Sets the given error condition, where StreamableError is defined as
|
|
- * follows:
|
|
- *
|
|
- * <pre>
|
|
- * enum StreamableError { peNotRegistered, peInvalidType };
|
|
- * </pre>
|
|
- */
|
|
- void error( StreamableError, const TStreamable& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- static void registerType( TStreamableClass *ts );
|
|
-protected:
|
|
- /**
|
|
- * This form allocates a default buffer.
|
|
- */
|
|
- pstream();
|
|
- /**
|
|
- * Pointer to the stream buffer.
|
|
- */
|
|
- streambuf *bp;
|
|
- /**
|
|
- * The format state flags, as enumerated in ios. Use @ref rdstate() to
|
|
- * access the current state.
|
|
- */
|
|
- int state;
|
|
- /**
|
|
- * Initializes the stream: sets @ref state to 0 and @ref bp to `sbp'.
|
|
- */
|
|
- void init( streambuf *sbp );
|
|
- /**
|
|
- * Updates the @ref state data member with state |= (b & 0 xFF).
|
|
- */
|
|
- void setstate( int b );
|
|
- /**
|
|
- * Pointer to the @ref TStreamableTypes data base of all registered types
|
|
- * in this application.
|
|
- */
|
|
- static TStreamableTypes * types;
|
|
+ static void registerType(TStreamableClass *ts);
|
|
};
|
|
|
|
#endif // Uses_pstream
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class ipstream */
|
|
-/* */
|
|
-/* Base class for reading streamable objects */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_ipstream ) && !defined( __ipstream )
|
|
#define __ipstream
|
|
|
|
-#include <iostream.h>
|
|
-
|
|
class TStreamableClass;
|
|
|
|
/**
|
|
* ipstream, a specialized input stream derivative of @ref pstream, is the
|
|
* base class for reading (extracting) streamable objects. ipstream is
|
|
- * analogous to istream, defined in `iostream.h' for the standard C++ stream
|
|
+ * analogous to istream, defined in `iostream' for the standard C++ stream
|
|
* library. ipstream is a friend class of @ref TPReadObjects.
|
|
*
|
|
* The overloaded operators >> extract (read) from the given ipstream object
|
|
@@ -566,176 +425,69 @@
|
|
* to chain >> operations in the usual way. The data type of the argument
|
|
* determines how the read is performed. For example, reading a signed char
|
|
* is implemented using @ref readByte().
|
|
+ *
|
|
* @see opstream
|
|
+ *
|
|
* @short The base class for reading (extracting) streamable objects from
|
|
* streams
|
|
*/
|
|
-class ipstream : virtual public pstream
|
|
-{
|
|
-public:
|
|
- /**
|
|
- * This form creates a buffered ipstream with the given buffer and sets
|
|
- * the @ref bp data member to `buf'. The @ref state data member is set
|
|
- * to 0.
|
|
- */
|
|
- ipstream( streambuf *buf );
|
|
- /**
|
|
- * Destroys the ipstream object.
|
|
- */
|
|
- ~ipstream();
|
|
- /**
|
|
- * Returns the (absolute) current stream position.
|
|
- */
|
|
- streampos tellg();
|
|
- /**
|
|
- * This form moves the stream position to the absolute position given by
|
|
- * `pos'.
|
|
- */
|
|
- ipstream& seekg( streampos pos );
|
|
- /**
|
|
- * This form moves to a position relative to the current position by an
|
|
- * offset `off' (+ or -) starting at `dir'. Parameter `dir' can be set to:
|
|
- *
|
|
- * <pre>
|
|
- * beg (start of stream)
|
|
- *
|
|
- * cur (current stream position)
|
|
- *
|
|
- * end (end of stream)
|
|
- * </pre>
|
|
- */
|
|
- ipstream& seekg( streamoff off, ios::seek_dir dir );
|
|
- /**
|
|
- * Returns the character at the current stream position.
|
|
- */
|
|
- uchar readByte();
|
|
- /**
|
|
- * Reads `sz' bytes from current stream position, and writes them to
|
|
- * the address given in `data'.
|
|
- */
|
|
- void readBytes( void *data, size_t sz );
|
|
- /**
|
|
- * Returns the word at the current stream position.
|
|
- */
|
|
- ushort readWord();
|
|
- /**
|
|
- * Returns a string read from the current stream position.
|
|
- */
|
|
- char * readString();
|
|
- /**
|
|
- * Returns a string read from the current stream position.
|
|
- */
|
|
- char * readString( char *buf, unsigned maxLen );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, char& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, signed char& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, unsigned char& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, signed short& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, unsigned short& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, signed int& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, unsigned int& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, signed long& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, unsigned long& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, float& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, double& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, long double& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, TStreamable& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend ipstream& operator >> ( ipstream&, void *& );
|
|
-protected:
|
|
- /**
|
|
- * This form does nothing.
|
|
- */
|
|
- ipstream();
|
|
- /**
|
|
- * Returns the @ref TStreamableClass object corresponding to the class
|
|
- * name stored at the current position.
|
|
- */
|
|
- const TStreamableClass * readPrefix();
|
|
- /**
|
|
- * Invokes the appropriate read function to read from the stream to the
|
|
- * object `mem'. If `mem' is 0, the appropriate build function is called
|
|
- * first.
|
|
- */
|
|
- void * readData( const TStreamableClass *c, TStreamable *mem );
|
|
- /**
|
|
- * Reads and checks the final byte of an object's name field.
|
|
- */
|
|
- void readSuffix();
|
|
- /**
|
|
- * Returns a pointer to the object corresponding to `id'.
|
|
- */
|
|
- const void * find( P_id_type id );
|
|
- /**
|
|
- * Registers the class of the object pointed by `adr'.
|
|
- */
|
|
- void registerObject( const void *adr );
|
|
+class ipstream : virtual public pstream, public std::istream {
|
|
private:
|
|
TPReadObjects objs;
|
|
|
|
+protected:
|
|
+ const TStreamableClass *readPrefix();
|
|
+ void *readData(const TStreamableClass *c, TStreamable *mem);
|
|
+ void readSuffix();
|
|
+ const void *find(P_id_type id);
|
|
+ void registerObject(const void *adr);
|
|
+
|
|
+ ushort readWord();
|
|
+ ulong readLong();
|
|
+
|
|
+public:
|
|
+ ipstream(std::streambuf *buf);
|
|
+ ~ipstream();
|
|
+
|
|
+ ipstream &seekg(std::streampos pos);
|
|
+ ipstream &seekg(std::streamoff off, std::ios::seekdir dir);
|
|
+
|
|
+ uchar readByte();
|
|
+ void readBytes(void *data, std::streamsize sz);
|
|
+ char *readString();
|
|
+ char *readString(char *buf, unsigned maxLen);
|
|
+
|
|
+ ipstream &operator>>(char &);
|
|
+ ipstream &operator>>(signed char &);
|
|
+ ipstream &operator>>(unsigned char &);
|
|
+ ipstream &operator>>(signed short &);
|
|
+ ipstream &operator>>(unsigned short &);
|
|
+ ipstream &operator>>(signed int &);
|
|
+ ipstream &operator>>(unsigned int &);
|
|
+ ipstream &operator>>(signed long &);
|
|
+ ipstream &operator>>(unsigned long &);
|
|
+ ipstream &operator>>(float &);
|
|
+ ipstream &operator>>(double &);
|
|
+ ipstream &operator>>(long double &);
|
|
+ ipstream &operator>>(TStreamable &);
|
|
+ ipstream &operator>>(void *&);
|
|
};
|
|
|
|
#endif // Uses_ipstream
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class opstream */
|
|
-/* */
|
|
-/* Base class for writing streamable objects */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_opstream ) && !defined( __opstream )
|
|
#define __opstream
|
|
|
|
-#include <iostream.h>
|
|
-
|
|
class TStreamableClass;
|
|
|
|
/**
|
|
* opstream, a specialized output stream derivative of @ref pstream, is the
|
|
* base class for writing (inserting) streamable objects. opstream is
|
|
- * analogous to ostream, defined in `iostream.h' for the standard C++ stream
|
|
+ * analogous to ostream, defined in `iostream' for the standard C++ stream
|
|
* library. opstream is a friend class of @ref TPWrittenObjects.
|
|
*
|
|
* The overloaded operators << insert (write) the given argument to the given
|
|
@@ -743,469 +495,146 @@
|
|
* to chain << operations in the usual way. The data type of the argument
|
|
* determines the form of write operation employed. For example, writing a
|
|
* signed char is implemented using @ref writeByte().
|
|
+ *
|
|
* @see ipstream
|
|
+ *
|
|
* @short The base class for writing (inserting) streamable objects into
|
|
* streams
|
|
*/
|
|
-class opstream : virtual public pstream
|
|
-{
|
|
+class opstream : virtual public pstream, public std::ostream {
|
|
+ TPWrittenObjects objs;
|
|
+
|
|
+protected:
|
|
+ void writePrefix(const TStreamable &);
|
|
+ void writeData(TStreamable &);
|
|
+ void writeSuffix(const TStreamable &);
|
|
+ P_id_type find(const void *adr);
|
|
+ void registerObject(const void *adr);
|
|
+
|
|
public:
|
|
- /**
|
|
- * This form creates a buffered opstream with the given buffer and sets
|
|
- * the @ref bp data member to `buf'. The @ref state data member is set
|
|
- * to 0.
|
|
- */
|
|
- opstream( streambuf *buf );
|
|
- /**
|
|
- * Destroys the opstream object.
|
|
- */
|
|
+ opstream(std::streambuf *buf);
|
|
~opstream();
|
|
- /**
|
|
- * Returns the (absolute) current stream position.
|
|
- */
|
|
- streampos tellp();
|
|
- /**
|
|
- * This form moves the stream's current position to the absolute position
|
|
- * given by `pos'.
|
|
- */
|
|
- opstream& seekp( streampos pos );
|
|
- /**
|
|
- * This form moves to a position relative to the current position by an
|
|
- * offset `off' (+ or -) starting at `dir'. Parameter `dir' can be set to:
|
|
- *
|
|
- * <pre>
|
|
- * beg (start of stream)
|
|
- *
|
|
- * cur (current stream position)
|
|
- *
|
|
- * end (end of stream)
|
|
- * </pre>
|
|
- */
|
|
- opstream& seekp( streamoff off, ios::seek_dir dir );
|
|
- /**
|
|
- * Flushes the stream.
|
|
- */
|
|
+ opstream& seekp(std::streampos pos);
|
|
+ opstream& seekp(std::streamoff off, std::ios::seekdir dir);
|
|
opstream& flush();
|
|
- /**
|
|
- * Writes character `ch' to the stream.
|
|
- */
|
|
- void writeByte( uchar ch );
|
|
- /**
|
|
- * Writes `sz' bytes from `data' buffer to the stream.
|
|
- */
|
|
- void writeBytes( const void *data, size_t sz );
|
|
- /**
|
|
- * Writes the word `us' to the stream.
|
|
- */
|
|
- void writeWord( ushort us );
|
|
- /**
|
|
- * Writes `str' to the stream (together with a leading length byte).
|
|
- */
|
|
- void writeString( const char *str );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, char );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, signed char );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, unsigned char );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, signed short );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, unsigned short );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, signed int );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, unsigned int );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, signed long );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, unsigned long );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, float );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, double );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, long double );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, TStreamable& );
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- friend opstream& operator << ( opstream&, TStreamable * );
|
|
-protected:
|
|
- /**
|
|
- * This form allocates a default buffer.
|
|
- */
|
|
- opstream();
|
|
- /**
|
|
- * Writes the class name prefix to the stream.
|
|
- *
|
|
- * The << operator uses this function to write a prefix and suffix around
|
|
- * the data written with @ref writeData(). The prefix/suffix is used to
|
|
- * ensure type-safe stream I/O.
|
|
- */
|
|
- void writePrefix( const TStreamable& );
|
|
- /**
|
|
- * Writes data to the stream by calling the appropriate class's write
|
|
- * member function for the object being written.
|
|
- */
|
|
- void writeData( TStreamable& );
|
|
- /**
|
|
- * Writes the class name suffix to the stream.
|
|
- *
|
|
- * The << operator uses this function to write a prefix and suffix around
|
|
- * the data written with @ref writeData(). The prefix/suffix is used to
|
|
- * ensure type-safe stream I/O.
|
|
- */
|
|
- void writeSuffix( const TStreamable& );
|
|
- /**
|
|
- * Returns the type ID for the object ad address `adr'.
|
|
- */
|
|
- P_id_type find( const void *adr );
|
|
- /**
|
|
- * Registers the class of the object ad address `adr'.
|
|
- */
|
|
- void registerObject( const void *adr );
|
|
-private:
|
|
- TPWrittenObjects *objs;
|
|
+
|
|
+ void writeByte(uchar ch);
|
|
+ void writeBytes(const void *data, std::streamsize sz);
|
|
+ void writeWord(ushort us);
|
|
+ void writeString(const char *str);
|
|
+
|
|
+ opstream &operator<<(char);
|
|
+ opstream &operator<<(signed char);
|
|
+ opstream &operator<<(unsigned char);
|
|
+ opstream &operator<<(signed short);
|
|
+ opstream &operator<<(unsigned short);
|
|
+ opstream &operator<<(signed int);
|
|
+ opstream &operator<<(unsigned int);
|
|
+ opstream &operator<<(signed long);
|
|
+ opstream &operator<<(unsigned long);
|
|
+ opstream &operator<<(float);
|
|
+ opstream &operator<<(double);
|
|
+ opstream &operator<<(long double);
|
|
+ opstream &operator<<(TStreamable &);
|
|
+ opstream &operator<<(TStreamable *);
|
|
};
|
|
|
|
#endif // Uses_opstream
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class iopstream */
|
|
-/* */
|
|
-/* Base class for reading and writing streamable objects */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_iopstream ) && !defined( __iopstream )
|
|
#define __iopstream
|
|
|
|
-#include <iostream.h>
|
|
-
|
|
/**
|
|
* Class iopstream is a simple "mix" of its bases, @ref opstream and
|
|
* @ref ipstream. It provides the base class for simultaneous writing and
|
|
* reading streamable objects.
|
|
+ *
|
|
* @short The base class for simultaneous writing and reading streamable
|
|
* objects to and from streams
|
|
*/
|
|
-class iopstream : public ipstream, public opstream
|
|
-{
|
|
+class iopstream : public ipstream, public opstream {
|
|
public:
|
|
- /**
|
|
- * Creates a buffered iopstream with the given buffer and sets the @ref bp
|
|
- * data member to `buf'. The @ref state data member is set to 0.
|
|
- */
|
|
- iopstream( streambuf *buf );
|
|
- /**
|
|
- * Destroys the iopstream object.
|
|
- */
|
|
+ iopstream(std::streambuf *buf);
|
|
~iopstream();
|
|
-protected:
|
|
- /**
|
|
- * Undocumented.
|
|
- */
|
|
- iopstream();
|
|
};
|
|
|
|
#endif // Uses_iopstream
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
-/* class fpbase */
|
|
-/* */
|
|
-/* Base class for handling streamable objects on file streams */
|
|
-/* */
|
|
-/* ------------------------------------------------------------------------*/
|
|
-
|
|
-#if defined( Uses_fpbase ) && !defined( __fpbase )
|
|
-#define __fpbase
|
|
-
|
|
-#include <fstream.h>
|
|
-
|
|
-/**
|
|
- * fpbase provides the basic operations common to all object file stream I/O.
|
|
- * @short Base class for handling streamable objects on file streams
|
|
- */
|
|
-class fpbase : virtual public pstream
|
|
-{
|
|
-public:
|
|
- /**
|
|
- * Creates a buffered fpbase object.
|
|
- */
|
|
- fpbase();
|
|
- /**
|
|
- * Creates a buffered fpbase object. You can open a file and attach it to
|
|
- * the stream by specifying the `name', `omode', and `prot' (protection)
|
|
- * arguments.
|
|
- */
|
|
- fpbase( const char *name, int omode, int prot = filebuf::openprot );
|
|
- /**
|
|
- * Creates a buffered fpbase object. You can open a file and attach it to
|
|
- * the stream by specifying the file descriptor, `f'.
|
|
- */
|
|
- fpbase( int f );
|
|
- /**
|
|
- * Creates a buffered fpbase object. You can set the size and initial
|
|
- * contents of the buffer with the `len' and `b' arguments. You can open
|
|
- * a file and attach it to the stream by specifying the file descriptor,
|
|
- * `f'.
|
|
- */
|
|
- fpbase( int f, char *b, int len);
|
|
- /**
|
|
- * Destroys the fpbase object.
|
|
- */
|
|
- ~fpbase();
|
|
- /**
|
|
- * Opens the named file in the given mode (app, ate, in, out, binary,
|
|
- * trunc, nocreate, noreplace) and protection. The opened file is
|
|
- * attached to this stream.
|
|
- */
|
|
- void open( const char *name, int omode, int prot = filebuf::openprot );
|
|
- /**
|
|
- * Attaches the file with descriptor `f' to this stream if possible.
|
|
- */
|
|
- void attach( int f );
|
|
- /**
|
|
- * Closes the stream and associated file.
|
|
- */
|
|
- void close();
|
|
- /**
|
|
- * Allocates a buffer of size `len'.
|
|
- */
|
|
- void setbuf( char *buf, int len );
|
|
- /**
|
|
- * Returns a pointer to the current file buffer.
|
|
- */
|
|
- filebuf * rdbuf();
|
|
-private:
|
|
- filebuf buf;
|
|
-};
|
|
-
|
|
-#endif // Uses_fpbase
|
|
-
|
|
-/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class ifpstream */
|
|
-/* */
|
|
-/* Base class for reading streamable objects from file streams */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_ifpstream ) && !defined( __ifpstream )
|
|
#define __ifpstream
|
|
|
|
-#include <iostream.h>
|
|
-
|
|
/**
|
|
- * ifpstream is a simple "mix" of its bases, @ref fpbase and @ref ipstream.
|
|
- * It provides the base class for reading (extracting) streamable objects
|
|
- * from file streams.
|
|
- * @short Provides the base class for reading (extracting) streamable objects
|
|
+ * ifpstream provides the base class for reading (extracting)
|
|
+ * streamable objects from file streams.
|
|
+ *
|
|
+ * @short The base class for reading (extracting) streamable objects
|
|
* from file streams.
|
|
*/
|
|
-class ifpstream : public fpbase, public ipstream
|
|
-{
|
|
+class ifpstream : public ipstream {
|
|
+ std::filebuf buf;
|
|
public:
|
|
- /**
|
|
- * Creates a buffered ifpstream object.
|
|
- */
|
|
ifpstream();
|
|
- /**
|
|
- * Creates a buffered ifpstream object. You can open a file and attach it
|
|
- * to the stream by specifying the `name', `omode', and `prot'
|
|
- * (protection) arguments.
|
|
- */
|
|
- ifpstream(const char *name, int omode = ios::in,
|
|
- int prot = filebuf::openprot );
|
|
- /**
|
|
- * Creates a buffered ifpstream object. You can open a file and attach it
|
|
- * to the stream by specifying the file descriptor, `f'.
|
|
- */
|
|
- ifpstream( int f );
|
|
- /**
|
|
- * Creates a buffered ifpstream object. You can set the size and initial
|
|
- * contents of the buffer with the `len' and `b' arguments. You can open
|
|
- * a file and attach it to the stream by specifying the file descriptor,
|
|
- * `f'.
|
|
- */
|
|
- ifpstream( int f, char *b, int len );
|
|
- /**
|
|
- * Destroys the ifpstream object.
|
|
- */
|
|
+ ifpstream(const char name[], std::ios::openmode omode = std::ios::in);
|
|
~ifpstream();
|
|
- /**
|
|
- * Returns a pointer to the current file buffer.
|
|
- */
|
|
- filebuf * rdbuf();
|
|
- /**
|
|
- * Opens the the named file in the given mode (app, ate, in, out, binary,
|
|
- * trunc, nocreate, or noreplace) and protection. The default mode is in
|
|
- * (input) with openprot protection. The opened file is attached to this
|
|
- * stream.
|
|
- */
|
|
- void open( const char *name, int omode = ios::in,
|
|
- int prot = filebuf::openprot );
|
|
+ void open(const char name[], std::ios::openmode omode = std::ios::in);
|
|
};
|
|
|
|
#endif // Uses_ifpstream
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class ofpstream */
|
|
-/* */
|
|
-/* Base class for writing streamable objects to file streams */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_ofpstream ) && !defined( __ofpstream )
|
|
#define __ofpstream
|
|
|
|
-#include <iostream.h>
|
|
-
|
|
/**
|
|
- * Class ofpstream is a simple "mix" of its bases, @ref fpbase and
|
|
- * @ref opstream. It provides the base class for writing (inserting)
|
|
+ * ofpstream provides the base class for writing (inserting)
|
|
* streamable objects to file streams.
|
|
- * @short Provides the base class for writing (inserting) streamable objects
|
|
- * to file streams
|
|
+ *
|
|
+ * @short The base class for writing (inserting) streamable objects
|
|
+ * to file streams.
|
|
*/
|
|
-class ofpstream : public fpbase, public opstream
|
|
-{
|
|
+class ofpstream : public opstream {
|
|
+ std::filebuf buf;
|
|
public:
|
|
- /**
|
|
- * Creates a buffered ofpstream object.
|
|
- */
|
|
ofpstream();
|
|
- /**
|
|
- * Creates a buffered ofpstream object. You can open a file and attach it
|
|
- * to the stream by specifying the `name', `omode', and `prot'
|
|
- * (protection) arguments.
|
|
- */
|
|
- ofpstream( const char *name, int omode = ios::out, int prot =
|
|
- filebuf::openprot );
|
|
- /**
|
|
- * Creates a buffered ofpstream object. You can open a file and attach it
|
|
- * to the stream by specifying the file descriptor, `f'.
|
|
- */
|
|
- ofpstream( int f );
|
|
- /**
|
|
- * Creates a buffered ofpstream object. You can set the size and initial
|
|
- * contents of the buffer using the `len' and `b' arguments. You can open
|
|
- * a file and attach it to the stream by specifying the file descriptor,
|
|
- * `f'.
|
|
- */
|
|
- ofpstream( int f, char *b, int len );
|
|
- /**
|
|
- * Destroys the ofpstream object.
|
|
- */
|
|
+ ofpstream(const char name[], std::ios::openmode omode = std::ios::out);
|
|
~ofpstream();
|
|
- /**
|
|
- * Returns the current file buffer.
|
|
- */
|
|
- filebuf * rdbuf();
|
|
- /**
|
|
- * Opens the the named file in the given mode (app, ate, in, out, binary,
|
|
- * trunc, nocreate, or noreplace) and protection. The default mode is out
|
|
- * (output) with openprot protection. The opened file is attached to this
|
|
- * stream.
|
|
- */
|
|
- void open( const char *name, int omode = ios::out,
|
|
- int prot = filebuf::openprot );
|
|
+ void open(const char name[], std::ios::openmode omode = std::ios::out);
|
|
};
|
|
|
|
#endif // Uses_ofpstream
|
|
|
|
/* ------------------------------------------------------------------------*/
|
|
-/* */
|
|
/* class fpstream */
|
|
-/* */
|
|
-/* Base class for reading and writing streamable objects to */
|
|
-/* bidirectional file streams */
|
|
-/* */
|
|
/* ------------------------------------------------------------------------*/
|
|
|
|
#if defined( Uses_fpstream ) && !defined( __fpstream )
|
|
#define __fpstream
|
|
|
|
-#include <iostream.h>
|
|
-
|
|
/**
|
|
- * fpstream is a simple "mix" of its bases, @ref fpbase and @ref iopstream.
|
|
- * It provides the base class for simultaneous writing and reading streamable
|
|
- * objects to bidirectional file streams. It is analogous to class fstream,
|
|
- * defined in `fstream.h' for the standard C++ stream library.
|
|
- * @short Provides the base class for simultaneous writing and reading
|
|
- * streamable objects to bidirectional file streams
|
|
+ * fpstream provides the base class for simultaneous writing and
|
|
+ * reading streamable objects to bidirectional file streams.
|
|
+ *
|
|
+ * @short The base class for simultaneous writing and reading
|
|
+ * streamable objects to bidirectional file streams.
|
|
*/
|
|
-class fpstream : public fpbase, public iopstream
|
|
-{
|
|
+class fpstream : public iopstream {
|
|
+ std::filebuf buf;
|
|
public:
|
|
- /**
|
|
- * Creates a buffered fpstream object.
|
|
- */
|
|
fpstream();
|
|
- /**
|
|
- * Creates a buffered fpstream object. You can open a file and attach it
|
|
- * to the stream by specifying the `name', `omode', and `prot'
|
|
- * (protection) arguments.
|
|
- */
|
|
- fpstream( const char *name, int omode, int prot = filebuf::openprot );
|
|
- /**
|
|
- * Creates a buffered fpstream object. You can open a file and attach it
|
|
- * to the stream by specifying the file descriptor, `f'.
|
|
- */
|
|
- fpstream( int f );
|
|
- /**
|
|
- * Creates a buffered fpstream object. You can set the size and initial
|
|
- * contents of the buffer using the `len' and `b' arguments. You can open
|
|
- * a file and attach it to the stream by specifying the file descriptor,
|
|
- * `f'.
|
|
- */
|
|
- fpstream( int f, char *b, int len );
|
|
- /**
|
|
- * Destroys the fpstream object.
|
|
- */
|
|
+ fpstream(const char name[], std::ios::openmode omode);
|
|
~fpstream();
|
|
- /**
|
|
- * Returns the data member bp.
|
|
- */
|
|
- filebuf * rdbuf();
|
|
- /**
|
|
- * Opens the named file in the given mode (app, ate, in, out, binary,
|
|
- * trunc, nocreate, noreplace) and protection. The opened file is
|
|
- * attatched to this stream.
|
|
- */
|
|
- void open( const char *name, int omode, int prot = filebuf::openprot );
|
|
+ void open(const char name[], std::ios::openmode omode);
|
|
};
|
|
|
|
#endif // Uses_fpstream
|
|
Index: lib/tv.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/tv.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- lib/tv.h 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/tv.h 27 Dec 2002 23:16:44 -0000 1.4
|
|
@@ -1,5 +1,5 @@
|
|
-/*
|
|
- * tv.h
|
|
+/**
|
|
+ * @file tv.h
|
|
*
|
|
* Turbo Vision - Version 2.0
|
|
*
|
|
@@ -36,11 +36,9 @@
|
|
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
-/** \file tv.h
|
|
- * tv.h
|
|
- */
|
|
|
|
#define _TV_VERSION 0x0200
|
|
|
|
@@ -375,10 +373,6 @@
|
|
#if defined( Uses_TDialog )
|
|
#define Uses_TWindow
|
|
#define __INC_DIALOGS_H
|
|
-#endif
|
|
-
|
|
-#if defined( Uses_TVMemMgr )
|
|
-#define __INC_BUFFERS_H
|
|
#endif
|
|
|
|
#if defined( Uses_TWindow )
|
|
Index: lib/tvobjs.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/tvobjs.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.2
|
|
diff -u -r1.1 -r1.2
|
|
--- lib/tvobjs.h 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/tvobjs.h 27 Dec 2002 23:16:44 -0000 1.2
|
|
@@ -42,7 +42,7 @@
|
|
* Destroys the object pointed by `o'.
|
|
*
|
|
* destroy() deletes an object `o' of a type derived from TObject; that
|
|
- * is, any object created with operator new(). destroy() terminates the
|
|
+ * is, any object created with new. destroy() terminates the
|
|
* object, correctly freeing the memory that it occupies.
|
|
*
|
|
* It calls `o->shutDown()' and after does `delete o'.
|
|
Index: lib/util.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/lib/util.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- lib/util.h 20 Dec 2002 12:06:20 -0000 1.1
|
|
+++ lib/util.h 27 Dec 2002 23:16:44 -0000 1.5
|
|
@@ -1,5 +1,5 @@
|
|
/*
|
|
- * util.h
|
|
+ * @file util.h
|
|
*
|
|
* Turbo Vision - Version 2.0
|
|
*
|
|
@@ -7,14 +7,13 @@
|
|
* All Rights Reserved.
|
|
*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#if !defined( __UTIL_H )
|
|
#define __UTIL_H
|
|
|
|
-/** \file util.h
|
|
- * util.h
|
|
- */
|
|
+#include <streambuf>
|
|
|
|
/**
|
|
* Undocumented.
|
|
@@ -166,13 +165,6 @@
|
|
*/
|
|
void *message( TView *receiver, ushort what, ushort command, void *infoPtr );
|
|
|
|
-/** \fn lowMemory()
|
|
- * Calls TVMemMgr::safetyPoolExhausted() to check the state of the safety
|
|
- * pool.
|
|
- * @see TVMemMgr::safetyPoolExhausted
|
|
- */
|
|
-Boolean lowMemory();
|
|
-
|
|
/** \fn newStr( const char *s )
|
|
* Dynamic string creation. If `s' is a null pointer, newStr() returns a 0
|
|
* pointer; otherwise, strlen(s)+ 1 bytes are allocated, containing a copy of
|
|
@@ -209,9 +201,7 @@
|
|
* Undocumented.
|
|
*/
|
|
void expandPath(const char *path, char *dir, char *file);
|
|
-/**
|
|
- * Undocumented.
|
|
- */
|
|
-long int filelength(int fd);
|
|
+
|
|
+std::streampos filelength(std::istream &s);
|
|
|
|
#endif // __UTIL_H
|
|
Index: tutorial/background.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/background.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- tutorial/background.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/background.cc 25 Dec 2002 14:10:19 -0000 1.4
|
|
@@ -2,6 +2,7 @@
|
|
* TVision example: how to change the background pattern
|
|
*
|
|
* Written by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TApplication
|
|
@@ -20,7 +21,7 @@
|
|
{
|
|
}
|
|
|
|
-void main()
|
|
+int main()
|
|
{
|
|
TDeskTop::defaultBkgrnd = '?';
|
|
Demo a;
|
|
Index: tutorial/load.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/load.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/load.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/load.cc 25 Dec 2002 14:10:19 -0000 1.3
|
|
@@ -2,6 +2,7 @@
|
|
* TVision example: how to create custom views
|
|
*
|
|
* Written by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TApplication
|
|
@@ -18,10 +19,13 @@
|
|
|
|
#include <tvision/tv.h>
|
|
|
|
-#include <fstream.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <time.h>
|
|
+
|
|
+#include <fstream>
|
|
+
|
|
+using std::ifstream;
|
|
|
|
enum
|
|
{
|
|
Index: tutorial/nomenus.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/nomenus.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/nomenus.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/nomenus.cc 25 Dec 2002 14:10:19 -0000 1.3
|
|
@@ -2,6 +2,7 @@
|
|
* TVision example: how to handle dialogs without menu bar and status line
|
|
*
|
|
* Written by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_MsgBox
|
|
@@ -80,7 +81,7 @@
|
|
{
|
|
public:
|
|
TMyApp();
|
|
- ushort doWork();
|
|
+ void doWork();
|
|
ushort newDialog(DialogData &data);
|
|
static TDeskTop *initDeskTop(TRect r);
|
|
};
|
|
@@ -163,7 +164,7 @@
|
|
|
|
//open dialogs here
|
|
|
|
-ushort TMyApp::doWork()
|
|
+void TMyApp::doWork()
|
|
{
|
|
messageBox("\003Welcome to the cheese ordering system",
|
|
mfInformation + mfOKButton);
|
|
Index: tutorial/splash.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/splash.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- tutorial/splash.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/splash.cc 25 Dec 2002 14:10:19 -0000 1.4
|
|
@@ -2,6 +2,7 @@
|
|
* TVision example: how to show a dialog box at startup
|
|
*
|
|
* Written by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TApplication
|
|
@@ -84,7 +85,7 @@
|
|
executeDialog(aboutBox);
|
|
}
|
|
|
|
-void main()
|
|
+int main()
|
|
{
|
|
Demo a;
|
|
a.run();
|
|
Index: tutorial/tvedit.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvedit.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- tutorial/tvedit.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvedit.cc 25 Dec 2002 14:10:19 -0000 1.4
|
|
@@ -2,6 +2,7 @@
|
|
* TVision example: a simple text editor
|
|
*
|
|
* Written by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_MsgBox
|
|
@@ -27,13 +28,13 @@
|
|
#define Uses_TStatusItem
|
|
#define Uses_TStatusLine
|
|
#define Uses_TSubMenu
|
|
-
|
|
-#include <fstream.h>
|
|
-#include <signal.h>
|
|
-#include <stdarg.h>
|
|
-#include <stdio.h>
|
|
#include <tvision/tv.h>
|
|
|
|
+#include <assert.h>
|
|
+extern "C" {
|
|
+ #include <signal.h>
|
|
+}
|
|
+
|
|
//new command codes; standard commands are defined in views.h
|
|
|
|
enum
|
|
@@ -235,6 +235,8 @@
|
|
va_end(ap);
|
|
return doReplacePrompt(*cursor);
|
|
}
|
|
+ assert(0); /* what should the return value be if we fall through? */
|
|
+ return 0;
|
|
}
|
|
|
|
//executes a dialog in modal state; similar to TProgram::execute(), but this
|
|
Index: tutorial/tvguid04.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid04.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid04.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid04.cc 25 Dec 2002 14:10:19 -0000 1.3
|
|
@@ -7,10 +7,9 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
-#include <stdlib.h> // for random()
|
|
-
|
|
#define Uses_TEvent
|
|
#define Uses_TApplication
|
|
#define Uses_TKeys
|
|
@@ -24,6 +23,8 @@
|
|
#define Uses_TDeskTop
|
|
#define Uses_TWindow
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <stdlib.h> // for random()
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid05.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid05.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid05.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid05.cc 25 Dec 2002 14:10:19 -0000 1.3
|
|
@@ -7,10 +7,9 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
-#include <stdlib.h> // for random()
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TApplication
|
|
@@ -26,6 +25,8 @@
|
|
#define Uses_TView
|
|
#define Uses_TWindow
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <stdlib.h> // for random()
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid06.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid06.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid06.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid06.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,17 +7,11 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
/****** imperfect draw method--see tvguid07 for improvement *****/
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -34,6 +28,18 @@
|
|
#define Uses_TView
|
|
#define Uses_TWindow
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::ifstream;
|
|
+using std::cout;
|
|
+using std::endl;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid07.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid07.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid07.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid07.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,17 +7,11 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid06 except for improved draw method
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -34,6 +28,18 @@
|
|
#define Uses_TView
|
|
#define Uses_TWindow
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream> // for ifstream
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid08.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid08.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid08.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid08.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid07 except for scrolling interior
|
|
// add TDemoWindow::makeInterior
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -37,6 +31,18 @@
|
|
#define Uses_TScroller
|
|
#define Uses_TScrollBar
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::ifstream;
|
|
+using std::cout;
|
|
+using std::endl;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid09.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid09.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid09.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid09.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid08 except for multiple panes
|
|
// modify TDemoWindow::makeInterior and constructor
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -38,6 +32,18 @@
|
|
#define Uses_TScroller
|
|
#define Uses_TScrollBar
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::ifstream;
|
|
+using std::cout;
|
|
+using std::endl;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid10.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid10.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid10.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid10.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid09 except for better handling of resizing
|
|
// add TDemoWindow::sizeLimits
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -38,6 +32,18 @@
|
|
#define Uses_TScroller
|
|
#define Uses_TScrollBar
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid11.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid11.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid11.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid11.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid10 except for added dialog box
|
|
// modify TMyApp
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -38,6 +32,18 @@
|
|
#define Uses_TScrollBar
|
|
#define Uses_TDialog
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
// note the extra #define above
|
|
|
|
Index: tutorial/tvguid12.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid12.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid12.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid12.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid11 except for making the dialog modal
|
|
// modify TMyApp::newDialog
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -38,6 +32,18 @@
|
|
#define Uses_TScrollBar
|
|
#define Uses_TDialog
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvguid13.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid13.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid13.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid13.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid12 except for extra buttons in dialog
|
|
// modify TMyApp::newDialog
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -39,6 +33,18 @@
|
|
#define Uses_TDialog
|
|
#define Uses_TButton
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
// note the extra #define above
|
|
|
|
Index: tutorial/tvguid14.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid14.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid14.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid14.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid13 except for extra checkboxes, radiobuttons, and labels
|
|
// modify TMyApp::newDialog
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -43,6 +37,18 @@
|
|
#define Uses_TRadioButtons
|
|
#define Uses_TLabel
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <iostream>
|
|
+#include <fstream>
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
// note the extra #defines above
|
|
|
|
Index: tutorial/tvguid15.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid15.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvguid15.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid15.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid14 except for extra input line in dialog
|
|
// modify TMyApp::newDialog
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -45,6 +39,17 @@
|
|
#define Uses_TLabel
|
|
#define Uses_TInputLine
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <fstream> // for ifstream
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
// note the extra #define above
|
|
|
|
Index: tutorial/tvguid16.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvguid16.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.4
|
|
diff -u -r1.1 -r1.4
|
|
--- tutorial/tvguid16.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvguid16.cc 25 Dec 2002 14:10:20 -0000 1.4
|
|
@@ -7,18 +7,12 @@
|
|
/*---------------------------------------------------------*/
|
|
/*
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
// same as tvguid15 except for saving and restoring dialog contents
|
|
// modify TMyApp::newDialog
|
|
|
|
-#include <stdlib.h> // for exit(), random()
|
|
-#include <iostream.h>
|
|
-#include <fstream.h> // for ifstream
|
|
-#include <stdio.h> // for puts() etc
|
|
-#include <string.h> // for strlen etc
|
|
-#include <ctype.h>
|
|
-
|
|
#define Uses_TEventQueue
|
|
#define Uses_TEvent
|
|
#define Uses_TProgram
|
|
@@ -45,6 +39,17 @@
|
|
#define Uses_TLabel
|
|
#define Uses_TInputLine
|
|
#include <tvision/tv.h>
|
|
+
|
|
+#include <fstream> // for ifstream
|
|
+
|
|
+#include <stdlib.h> // for exit(), random()
|
|
+#include <stdio.h> // for puts() etc
|
|
+#include <string.h> // for strlen etc
|
|
+#include <ctype.h>
|
|
+
|
|
+using std::cout;
|
|
+using std::endl;
|
|
+using std::ifstream;
|
|
|
|
const int cmMyFileOpen = 200; // assign new command values
|
|
const int cmMyNewWin = 201;
|
|
Index: tutorial/tvlife.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/tvlife.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.3
|
|
diff -u -r1.1 -r1.3
|
|
--- tutorial/tvlife.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/tvlife.cc 25 Dec 2002 14:10:20 -0000 1.3
|
|
@@ -7,6 +7,8 @@
|
|
* Clicking with the left button inside the life window will cause a dot to
|
|
* appear at the cursor location. Clicking with the right mouse button will
|
|
* remove the dot. This allows the user to create his/her own patterns.
|
|
+ *
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TApplication
|
|
@@ -22,9 +24,9 @@
|
|
#define Uses_TStatusLine
|
|
#define Uses_TSubMenu
|
|
#define Uses_TWindow
|
|
+#include <tvision/tv.h>
|
|
|
|
#include <stdlib.h>
|
|
-#include <tvision/tv.h>
|
|
|
|
enum
|
|
{
|
|
@@ -463,8 +465,8 @@
|
|
|
|
#define NPATS (sizeof patterns / sizeof patterns[0])
|
|
|
|
-TLifeInterior::TLifeInterior(TRect& bounds): TView(bounds), board(0),
|
|
- running(0)
|
|
+TLifeInterior::TLifeInterior(TRect& bounds)
|
|
+ : TView(bounds), running(0), board(NULL)
|
|
{
|
|
eventMask = evMouseDown | evKeyDown | evCommand | evBroadcast;
|
|
growMode = gfGrowHiX | gfGrowHiY;
|
|
@@ -528,16 +530,17 @@
|
|
|
|
#if 1
|
|
int i = size.x * size.y;
|
|
- ushort buf[size.x * size.y];
|
|
+ ushort *buf = new ushort[i];
|
|
ushort *to = buf;
|
|
|
|
while (i-- > 0)
|
|
{
|
|
- if (*from++ != 0) *to = (color << 8) | '*';
|
|
- else *to = (color << 8) | ' ';
|
|
+ *to = (*from++ != 0) ? '*' : ' ';
|
|
+ *to |= (color << 8);
|
|
to++;
|
|
}
|
|
writeBuf(0, 0, size.x, size.y, buf);
|
|
+ delete[] buf;
|
|
#else
|
|
TDrawBuffer b;
|
|
b.moveChar(0, ' ', color, size.x);
|
|
@@ -806,7 +809,7 @@
|
|
wc += cmRandom;
|
|
wc += cmStartStop;
|
|
wc += cmTile;
|
|
- for (int i = 0; i < NPATS; i++) //scan pattern commands
|
|
+ for (uint i = 0; i < NPATS; i++) //scan pattern commands
|
|
{
|
|
wc += cmPat01 + i; //add pattern commands
|
|
}
|
|
Index: tutorial/validator.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tutorial/validator.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- tutorial/validator.cc 20 Dec 2002 12:06:23 -0000 1.1
|
|
+++ tutorial/validator.cc 25 Dec 2002 14:10:21 -0000 1.5
|
|
@@ -2,6 +2,7 @@
|
|
* TVision example: how to use range validators in input lines
|
|
*
|
|
* Written by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#define Uses_TApplication
|
|
@@ -82,7 +83,6 @@
|
|
TWindowInit( &TDialog::initFrame )
|
|
{
|
|
TInputLine *line;
|
|
- TScrollBar *bar;
|
|
TView *obj;
|
|
|
|
options |= ofCentered;
|
|
@@ -130,7 +130,7 @@
|
|
selectNext(False);
|
|
}
|
|
|
|
-void main()
|
|
+int main()
|
|
{
|
|
Demo a;
|
|
a.run();
|
|
Index: tvhc/tvhc.cc
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tvhc/tvhc.cc,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- tvhc/tvhc.cc 20 Dec 2002 12:06:25 -0000 1.1
|
|
+++ tvhc/tvhc.cc 25 Dec 2002 14:10:22 -0000 1.5
|
|
@@ -9,6 +9,7 @@
|
|
/*
|
|
* Modified by Sergey Clushin <serg@lamport.ru>, <Clushin@deol.ru>
|
|
* Modified by Sergio Sigala <sergio@sigala.it>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
/*===== TVHC ============================================================*/
|
|
@@ -88,26 +89,51 @@
|
|
#include <tv.h>
|
|
|
|
#include "tvhc.h"
|
|
+
|
|
#include <string.h>
|
|
#include <limits.h>
|
|
#include <unistd.h>
|
|
#include <ctype.h>
|
|
#include <stdlib.h>
|
|
-#include <fstream.h>
|
|
-#include <strstream.h>
|
|
#include <errno.h>
|
|
|
|
+#include <fstream>
|
|
+#include <sstream>
|
|
+#include <string>
|
|
+
|
|
+using std::cerr;
|
|
+using std::cin;
|
|
+using std::cout;
|
|
+using std::ends;
|
|
+using std::fstream;
|
|
+using std::ios;
|
|
+using std::ostringstream;
|
|
+using std::string;
|
|
+
|
|
+static const int MAXSTRSIZE=256;
|
|
+static const char commandChar[] = ".";
|
|
+static const int bufferSize = 4096;
|
|
+
|
|
+typedef enum State { undefined, wrapping, notWrapping };
|
|
+
|
|
+static char *helpName;
|
|
+static uchar buffer[bufferSize];
|
|
+static int ofs;
|
|
+static TRefTable *refTable = 0;
|
|
+static TCrossRefNode *xRefs;
|
|
+static char line[MAXSTRSIZE] = "";
|
|
+static Boolean lineInBuffer = False;
|
|
+static int lineCount = 0;
|
|
+
|
|
//======================= File Management ===============================//
|
|
|
|
-TProtectedStream::TProtectedStream( char *aFileName, ushort aMode ) :
|
|
+TProtectedStream::TProtectedStream( char *aFileName, ios::openmode aMode) :
|
|
fstream( aFileName, aMode )
|
|
{
|
|
strcpy(fileName, aFileName);
|
|
mode = aMode;
|
|
}
|
|
|
|
-void error(char *text);
|
|
-
|
|
//----- replaceExt(fileName, nExt, force) -------------------------------//
|
|
// Replace the extension of the given file with the given extension. //
|
|
// If an extension already exists Force indicates if it should be //
|
|
@@ -121,8 +147,8 @@
|
|
char name[MAXFILE];
|
|
char ext[MAXEXT];
|
|
char drive[MAXDRIVE];
|
|
- char buffer[MAXPATH];
|
|
- ostrstream os(buffer, MAXPATH);
|
|
+ string buffer;
|
|
+ ostringstream os(buffer);
|
|
|
|
fnsplit(fileName, drive, dir, name, ext);
|
|
if (force || (strlen(ext) == 0))
|
|
@@ -139,12 +165,10 @@
|
|
// Returns true if the file exists false otherwise. /
|
|
//-----------------------------------------------------------------------/
|
|
|
|
-Boolean fExists(char *fileName)
|
|
+static bool
|
|
+fExists(const string &fileName)
|
|
{
|
|
- if (access(fileName, R_OK) != 0)
|
|
- return(False);
|
|
- else
|
|
- return(True);
|
|
+ return (access(fileName.c_str(), R_OK) == 0) ? true : false;
|
|
}
|
|
|
|
//======================== Line Management ==============================//
|
|
@@ -194,7 +218,8 @@
|
|
// Used by Error and Warning to print the message. //
|
|
//-----------------------------------------------------------------------//
|
|
|
|
-void prntMsg( char *pref, char *text )
|
|
+void
|
|
+prntMsg(const string &pref, char *text)
|
|
{
|
|
if (lineCount > 0)
|
|
cout << pref << ": " << helpName << "("
|
|
@@ -208,7 +233,8 @@
|
|
// Used to indicate an error. Terminates the program //
|
|
//-----------------------------------------------------------------------//
|
|
|
|
-void error( char *text )
|
|
+void
|
|
+error(char *text)
|
|
{
|
|
prntMsg("Error", text);
|
|
exit(1);
|
|
@@ -852,7 +878,7 @@
|
|
void doWriteSymbol(void *p, void *p1)
|
|
{
|
|
int numBlanks, i;
|
|
- ostrstream os(line, MAXSTRSIZE);
|
|
+ ostringstream os(line);
|
|
|
|
TProtectedStream *symbFile = (TProtectedStream *)p1;
|
|
if (((TReference *)p)->resolved )
|
|
@@ -868,7 +894,7 @@
|
|
{
|
|
os << "Unresolved forward reference \""
|
|
<< ((TReference *)p)->topic << "\"" << ends;
|
|
- warning(os.str());
|
|
+ warning(const_cast<char *>(os.str().c_str()));
|
|
}
|
|
}
|
|
|
|
@@ -910,25 +936,25 @@
|
|
// it's ok to overwrite it. //
|
|
//----------------------------------------------------------------------//
|
|
|
|
-void checkOverwrite( char *fName )
|
|
+static void
|
|
+checkOverwrite(const string &fName)
|
|
{
|
|
- if (fExists(fName))
|
|
- {
|
|
+ if (fExists(fName)) {
|
|
cerr << "File already exists: " << fName << ". Overwrite? (y/n) ";
|
|
- char ch = ({ char s[MAXSTRSIZE]; cin >> s; s[0]; });
|
|
- if( toupper(ch) != 'Y' )
|
|
+
|
|
+ char ch;
|
|
+ cin >> ch;
|
|
+ if (toupper(ch) != 'Y') {
|
|
exit(1);
|
|
- }
|
|
+ }
|
|
+ }
|
|
}
|
|
|
|
//========================== Program Block ==========================//
|
|
|
|
-int main(int argc, char **argv)
|
|
+int
|
|
+main(int argc, char **argv)
|
|
{
|
|
- char* textName;
|
|
- char* symbName;
|
|
- fpstream* helpStrm;
|
|
-
|
|
// Banner messages
|
|
char initialText[] = "Help Compiler Version 1.0 Copyright (c) 1991"
|
|
" Borland International.\n";
|
|
@@ -949,25 +975,25 @@
|
|
}
|
|
|
|
// Calculate file names
|
|
- textName = argv[1];
|
|
+ char *textName = argv[1];
|
|
if (!fExists(textName))
|
|
{
|
|
strcpy(bufStr,"File ");
|
|
- strcat(bufStr,textName);
|
|
- strcat(bufStr," not found.");
|
|
+ strcat(bufStr, textName);
|
|
+ strcat(bufStr, " not found.");
|
|
error(bufStr);
|
|
}
|
|
|
|
helpName = argv[2];
|
|
- checkOverwrite( helpName );
|
|
+ checkOverwrite(helpName);
|
|
|
|
- symbName = argv[3];
|
|
- checkOverwrite( symbName );
|
|
+ char *symbName = argv[3];
|
|
+ checkOverwrite(symbName);
|
|
|
|
TProtectedStream textStrm(textName, ios::in);
|
|
TProtectedStream symbStrm(symbName, ios::out | ios::trunc);
|
|
|
|
- helpStrm = new fpstream(helpName, ios::out | ios::trunc);
|
|
- processText(textStrm, *helpStrm, symbStrm);
|
|
+ fpstream helpStrm(helpName, ios::out | ios::trunc);
|
|
+ processText(textStrm, helpStrm, symbStrm);
|
|
return 0;
|
|
}
|
|
Index: tvhc/tvhc.h
|
|
===================================================================
|
|
RCS file: /usr/home/cvs/repository/libh/lib/tvision/work/tvision-0.8/tvhc/tvhc.h,v
|
|
retrieving revision 1.1
|
|
retrieving revision 1.5
|
|
diff -u -r1.1 -r1.5
|
|
--- tvhc/tvhc.h 20 Dec 2002 12:06:25 -0000 1.1
|
|
+++ tvhc/tvhc.h 25 Dec 2002 14:10:22 -0000 1.5
|
|
@@ -8,6 +8,7 @@
|
|
|
|
/*
|
|
* Modified by Sergey Clushin <serg@lamport.ru>, <Clushin@deol.ru>
|
|
+ * Modified by Max Okumoto <okumoto@ucsd.edu>
|
|
*/
|
|
|
|
#if !defined( __TVHC_H )
|
|
@@ -21,25 +22,20 @@
|
|
|
|
#include "helpbase.h"
|
|
|
|
+#include <fstream>
|
|
|
|
const int MAXSIZE = 80;
|
|
-const int MAXSTRSIZE=256;
|
|
-const char commandChar[] = ".";
|
|
-const int bufferSize = 4096;
|
|
|
|
-typedef enum State { undefined, wrapping, notWrapping };
|
|
-
|
|
-class TProtectedStream : public fstream
|
|
+class TProtectedStream : public std::fstream
|
|
{
|
|
|
|
public:
|
|
-
|
|
- TProtectedStream( char *aFileName, ushort aMode );
|
|
+ TProtectedStream( char *aFileName, std::ios::openmode aMode );
|
|
|
|
private:
|
|
|
|
char fileName[MAXSIZE];
|
|
- ushort mode;
|
|
+ std::ios::openmode mode;
|
|
|
|
};
|
|
|
|
@@ -113,14 +109,5 @@
|
|
TTopicDefinition *next;
|
|
|
|
};
|
|
-
|
|
-char* helpName;
|
|
-uchar buffer[bufferSize];
|
|
-int ofs;
|
|
-TRefTable *refTable = 0;
|
|
-TCrossRefNode *xRefs;
|
|
-char line[MAXSTRSIZE] = "";
|
|
-Boolean lineInBuffer = False;
|
|
-int lineCount = 0;
|
|
|
|
#endif // __TVHC_H
|