-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathLine.cpp
111 lines (84 loc) · 2.4 KB
/
Line.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#include "stdafx.h"
#include "MUSHclient.h"
#include "doc.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char BASED_CODE THIS_FILE[] = __FILE__;
#endif
/*
CLine is the class for "lines" from the MUSH, which are shown in the output
window.
By making them a class we can produce a collection class which is a linked
list of CLine's.
Also, the constructor allocates memory for the text of the line and its first
style item, and the destructor de-allocates the line's memory, and the style list.
*/
// CLine constructor
CLine::CLine (const long nLineNumber,
const unsigned int nWrapColumn,
const unsigned short iFlags,
const COLORREF iForeColour,
const COLORREF iBackColour,
const bool bUnicode
)
{
hard_return = false;
len = 0;
last_space = -1;
m_iPreambleOffset = 0;
m_theTime = CTime::GetCurrentTime();
QueryPerformanceCounter (&m_lineHighPerformanceTime);
m_nLineNumber = nLineNumber;
if (bUnicode)
iMemoryAllocated = nWrapColumn * 4;
else
iMemoryAllocated = nWrapColumn;
// allocate 4 bytes per character for UTF-8
#ifdef USE_REALLOC
text = (char *) malloc (iMemoryAllocated);
#else
text = new char [iMemoryAllocated];
#endif
ASSERT (text);
if (!text)
AfxThrowMemoryException ();
flags = 0; // no special flags yet (ie. normal output line)
CStyle * pStyle;
// have at least one style item in the list
styleList.AddTail (pStyle = NEWSTYLE);
pStyle->iFlags = iFlags;
pStyle->iForeColour = iForeColour;
pStyle->iBackColour = iBackColour;
} // end of CLine::CLine
// CLine destructor
CLine::~CLine ()
{
#ifdef USE_REALLOC
free (text);
#else
delete [] text;
#endif
// delete styles list
for (POSITION pos = styleList.GetHeadPosition(); pos; )
DELETESTYLE (styleList.GetNext (pos));
styleList.RemoveAll();
}
// for tracking down style allocation errors
CStyle * GetNewStyle (const char * filename, const long linenumber)
{
CStyle * pNewStyle = new CStyle;
TRACE3 ("new CStyle at %p at file %s line %ld\n",
pNewStyle,
filename,
linenumber);
return pNewStyle;
}
void DeleteStyle (CStyle * pStyle, const char * filename, const long linenumber)
{
TRACE3 ("delete CStyle at %p at file %s line %ld\n",
pStyle,
filename,
linenumber);
delete pStyle;
}