#include "wx/wx.h"
#endif
-#include <wx/hash.h>
+#include "wx/hash.h"
+
+#ifdef new
+#undef new
+#endif
#if wxUSE_IOSTREAMH
#include <iostream.h>
static char *forceTopicName = NULL;
-void ForceTopicName(char *name)
+void ForceTopicName(const char *name)
{
if (forceTopicName)
delete[] forceTopicName;
if (strcmp(units, "in") == 0)
conversionFactor = 72.0;
else if (strcmp(units, "cm") == 0)
- conversionFactor = 72.0/2.51;
+ conversionFactor = (float)72.0/(float)2.51;
else if (strcmp(units, "mm") == 0)
- conversionFactor = 72.0/25.1;
+ conversionFactor = (float)72.0/(float)25.1;
else if (strcmp(units, "pt") == 0)
conversionFactor = 1;
}
void WriteTexReferences(char *filename)
{
- ofstream ostr(filename);
+ wxSTD ofstream ostr(filename);
if (ostr.bad()) return;
char buf[200];
void ReadTexReferences(char *filename)
{
- ifstream istr(filename, ios::nocreate | ios::in);
+ if (!wxFileExists(filename))
+ return;
+
+ wxSTD ifstream istr(filename, ios::in);
+
if (istr.bad()) return;
char label[100];
istr.get(ch);
}
section[i] = 0;
+
+ // gt - needed to trick the hash table "TexReferences" into deleting the key
+ // strings it creates in the Put() function, but not the item that is
+ // created here, as that is destroyed elsewhere. Without doing this, there
+ // were massive memory leaks
+ TexReferences.DeleteContents(TRUE);
TexReferences.Put(label, new TexRef(label, file, section, sectionName));
+ TexReferences.DeleteContents(FALSE);
}
}
}
*
*/
-void BibEatWhiteSpace(istream& str)
+void BibEatWhiteSpace(wxSTD istream& str)
{
char ch = str.peek();
}
// Read word up to { or , or space
-void BibReadWord(istream& istr, char *buffer)
+void BibReadWord(wxSTD istream& istr, char *buffer)
{
int i = 0;
buffer[i] = 0;
}
// Read string (double-quoted or not) to end quote or EOL
-void BibReadToEOL(istream& istr, char *buffer)
+void BibReadToEOL(wxSTD istream& istr, char *buffer)
{
int i = 0;
buffer[i] = 0;
}
// Read }-terminated value, taking nested braces into account.
-void BibReadValue(istream& istr, char *buffer, bool ignoreBraces = TRUE,
+void BibReadValue(wxSTD istream& istr, char *buffer, bool ignoreBraces = TRUE,
bool quotesMayTerminate = TRUE)
{
int braceCount = 1;
while (!istr.eof() && !stopping)
{
// i ++;
- if (i >= 2000)
+ if (i >= 4000)
{
char buf[100];
- sprintf(buf, "Sorry, value > 2000 chars in bib file at line %ld, terminating.", BibLine);
- wxFatalError(buf, "Tex2RTF Fatal Error");
+ sprintf(buf, "Sorry, value > 4000 chars in bib file at line %ld.", BibLine);
+ wxLogError(buf, "Tex2RTF Fatal Error");
+ return;
}
istr.get(ch);
bool ReadBib(char *filename)
{
+ if (!wxFileExists(filename))
+ return FALSE;
+
char buf[300];
- ifstream istr(filename, ios::nocreate | ios::in);
+ wxSTD ifstream istr(filename, ios::in);
if (istr.bad()) return FALSE;
BibLine = 1;
OnInform("Reading .bib file...");
char ch;
- char fieldValue[2000];
+ char fieldValue[4000];
char recordType[100];
char recordKey[100];
char recordField[100];
winHelpContents = StringTobool(settingValue);
else if (StringMatch(settingName, "htmlIndex", FALSE, TRUE))
htmlIndex = StringTobool(settingValue);
+ else if (StringMatch(settingName, "htmlWorkshopFiles", FALSE, TRUE))
+ htmlWorkshopFiles = StringTobool(settingValue);
else if (StringMatch(settingName, "htmlFrameContents", FALSE, TRUE))
htmlFrameContents = StringTobool(settingValue);
else if (StringMatch(settingName, "upperCaseNames", FALSE, TRUE))
upperCaseNames = StringTobool(settingValue);
+ else if (StringMatch(settingName, "ignoreBadRefs", FALSE, TRUE))
+ ignoreBadRefs = StringTobool(settingValue);
+ else if (StringMatch(settingName, "htmlFaceName", FALSE, TRUE))
+ {
+ delete[] htmlFaceName;
+ htmlFaceName = copystring(settingValue);
+ }
else if (StringMatch(settingName, "winHelpTitle", FALSE, TRUE))
{
if (winHelpTitle)
bool ReadCustomMacros(char *filename)
{
- ifstream istr(filename, ios::nocreate | ios::in);
+ if (!wxFileExists(filename))
+ return FALSE;
+
+ wxSTD ifstream istr(filename, ios::in);
+
if (istr.bad()) return FALSE;
CustomMacroList.Clear();
*
*/
-ColourTableEntry::ColourTableEntry(char *theName, unsigned int r, unsigned int g, unsigned int b)
+ColourTableEntry::ColourTableEntry(const char *theName, unsigned int r, unsigned int g, unsigned int b)
{
name = copystring(theName);
red = r;
delete[] name;
}
-void AddColour(char *theName, unsigned int r, unsigned int g, unsigned int b)
+void AddColour(const char *theName, unsigned int r, unsigned int g, unsigned int b)
{
wxNode *node = ColourTable.Find(theName);
if (node)
yieldCount = 0;
if (yieldCount == 0)
{
- wxYield();
+ if (wxTheApp)
+ wxYield();
yieldCount = 10;
}
yieldCount --;
int i;
if (upperCaseNames)
for (i = 0; i < len; i ++)
- buf[i] = wxToUpper(s[i]);
+ buf[i] = toupper(s[i]);
else
for (i = 0; i < len; i ++)
- buf[i] = wxToLower(s[i]);
+ buf[i] = tolower(s[i]);
buf[i] = 0;
return buf;
}