]> git.saurik.com Git - wxWidgets.git/blobdiff - utils/tex2rtf/src/tex2any.h
removed tests for WXWIN_COMPATIBILITY_2_4
[wxWidgets.git] / utils / tex2rtf / src / tex2any.h
index db5b1914deee64bc07e1a0b45787907c0d314d8f..9b78d397c9c3e283106ad8032b21686b1a3994f5 100644 (file)
 /////////////////////////////////////////////////////////////////////////////
 
 #include <stdio.h>
 /////////////////////////////////////////////////////////////////////////////
 
 #include <stdio.h>
-#include "wx/wx.h"
 #include "wx/utils.h"
 #include "wx/list.h"
 #include "wx/hash.h"
 #include "wx/utils.h"
 #include "wx/list.h"
 #include "wx/hash.h"
+#include "wx/tokenzr.h"
+#include "wx/wfstream.h"
+#include "wx/txtstrm.h"
 #include "wxhlpblk.h"
 
 /*
  * Conversion modes
  *
  */
 #include "wxhlpblk.h"
 
 /*
  * Conversion modes
  *
  */
+
 #define TEX_RTF  1
 #define TEX_XLP  2
 #define TEX_HTML 3
 #define TEX_RTF  1
 #define TEX_XLP  2
 #define TEX_HTML 3
 #define FORBID_WARN       1
 #define FORBID_ABSOLUTELY 2
 
 #define FORBID_WARN       1
 #define FORBID_ABSOLUTELY 2
 
+
+#ifdef __WXMSW__
+  const unsigned long MAX_LINE_BUFFER_SIZE = 600;
+#else
+  const unsigned long MAX_LINE_BUFFER_SIZE = 11000;
+#endif
+
 class TexMacroDef: public wxObject
 {
  public:
   int no_args;
 class TexMacroDef: public wxObject
 {
  public:
   int no_args;
-  char *name;
+  wxChar *name;
   bool ignore;
   int forbidden;
   int macroId;
 
   bool ignore;
   int forbidden;
   int macroId;
 
-  TexMacroDef(int the_id, char *the_name, int n, bool ig, bool forbidLevel = FORBID_OK);
-  ~TexMacroDef(void);
+  TexMacroDef(int the_id, const wxChar *the_name, int n, bool ig, bool forbidLevel = FORBID_OK);
+  virtual ~TexMacroDef(void);
 };
 
 #define CHUNK_TYPE_MACRO    1
 };
 
 #define CHUNK_TYPE_MACRO    1
@@ -99,7 +108,7 @@ class TexChunk
   int type;
 //  char *name;
   TexMacroDef *def;
   int type;
 //  char *name;
   TexMacroDef *def;
-  char *value;
+  wxChar *value;
   int macroId;
   int no_args;
   int argn;
   int macroId;
   int no_args;
   int argn;
@@ -123,38 +132,39 @@ class TexTopic: public wxObject
   // to find there's only one page in it. We might force a book to be used if
   // a top-level topic has no children (?)
   bool hasChildren;
   // to find there's only one page in it. We might force a book to be used if
   // a top-level topic has no children (?)
   bool hasChildren;
-  char *filename;
+  wxChar *filename;
   wxStringList *keywords;
   wxStringList *keywords;
-  TexTopic(char *f = NULL);
-  ~TexTopic(void);
+  TexTopic(wxChar *f = NULL);
+  virtual ~TexTopic(void);
 };
 extern wxHashTable TopicTable;
 };
 extern wxHashTable TopicTable;
-void AddKeyWordForTopic(char *topic, char *entry, char *filename = NULL);
+void AddKeyWordForTopic(wxChar *topic, wxChar *entry, wxChar *filename = NULL);
 void ClearKeyWordTable(void);
 
 void ClearKeyWordTable(void);
 
+extern wxChar wxTex2RTFBuffer[];
 extern TexChunk     *TopLevel;
 extern wxHashTable  MacroDefs;
 extern wxStringList IgnorableInputFiles; // Ignorable \input files, e.g. psbox.tex
 
 extern TexChunk     *TopLevel;
 extern wxHashTable  MacroDefs;
 extern wxStringList IgnorableInputFiles; // Ignorable \input files, e.g. psbox.tex
 
-bool read_a_line(char *buf);
-bool TexLoadFile(char *filename);
-int ParseArg(TexChunk *thisArg, wxList& children, char *buffer, int pos,
-           char *environment = NULL, bool parseArgToBrace = TRUE, TexChunk *customMacroArgs = NULL);
-int ParseMacroBody(char *macro_name, TexChunk *parent, int no_args,
-           char *buffer, int pos, char *environment = NULL, bool parseArgToBrace = TRUE, TexChunk *customMacroArgs = NULL);
+bool read_a_line(wxChar *buf);
+bool TexLoadFile(const wxString& filename);
+int ParseArg(TexChunk *thisArg, wxList& children, wxChar *buffer, int pos,
+           wxChar *environment = NULL, bool parseArgToBrace = true, TexChunk *customMacroArgs = NULL);
+int ParseMacroBody(const wxChar *macro_name, TexChunk *parent, int no_args,
+           wxChar *buffer, int pos, wxChar *environment = NULL, bool parseArgToBrace = true, TexChunk *customMacroArgs = NULL);
 void TraverseDocument(void);
 void TraverseDocument(void);
-void TraverseFromChunk(TexChunk *chunk, wxNode *thisNode = NULL, bool childrenOnly = FALSE);
-#define TraverseChildrenFromChunk(arg) TraverseFromChunk(arg, NULL, TRUE)
+void TraverseFromChunk(TexChunk *chunk, wxNode *thisNode = NULL, bool childrenOnly = false);
+#define TraverseChildrenFromChunk(arg) TraverseFromChunk(arg, NULL, true)
 void SetCurrentOutput(FILE *fd);
 void SetCurrentOutputs(FILE *fd1, FILE *fd2);
 extern FILE *CurrentOutput1;
 extern FILE *CurrentOutput2;
 void SetCurrentOutput(FILE *fd);
 void SetCurrentOutputs(FILE *fd1, FILE *fd2);
 extern FILE *CurrentOutput1;
 extern FILE *CurrentOutput2;
-void AddMacroDef(int the_id, char *name, int n, bool ignore = FALSE, bool forbidden = FALSE);
+void AddMacroDef(int the_id, const wxChar *name, int n, bool ignore = false, bool forbidden = false);
 void TexInitialize(int bufSize);
 void TexCleanUp(void);
 void TexInitialize(int bufSize);
 void TexCleanUp(void);
-void TexOutput(char *s, bool ordinaryText = FALSE);
-char *GetArgData(TexChunk *chunk);
-char *GetArgData(void);             // Get the string for the current argument
+void TexOutput(const wxChar *s, bool ordinaryText = false);
+wxChar *GetArgData(TexChunk *chunk);
+wxChar *GetArgData(void);             // Get the string for the current argument
 int GetNoArgs(void);                // Get the number of arguments for the current macro
 TexChunk *GetArgChunk(void);        // Get the chunk for the current argument
 TexChunk *GetTopLevelChunk(void);   // Get the chunk for the top level
 int GetNoArgs(void);                // Get the number of arguments for the current macro
 TexChunk *GetArgChunk(void);        // Get the chunk for the current argument
 TexChunk *GetTopLevelChunk(void);   // Get the chunk for the top level
@@ -162,11 +172,13 @@ TexChunk *GetNextChunk(void);       // Look ahead to the next chunk
 bool IsArgOptional(void);           // Is this argument an optional argument?
 void DefineDefaultMacros(void);     // Optional set of default macros
 int GetCurrentColumn(void);         // number of characters on current line
 bool IsArgOptional(void);           // Is this argument an optional argument?
 void DefineDefaultMacros(void);     // Optional set of default macros
 int GetCurrentColumn(void);         // number of characters on current line
-char *ConvertCase(char *s);         // Convert case, according to upperCaseNames setting.
+wxChar *ConvertCase(wxChar *s);         // Convert case, according to upperCaseNames setting.
 extern wxPathList TexPathList;      // Path list, can be used for file searching.
 
 extern wxPathList TexPathList;      // Path list, can be used for file searching.
 
+extern bool StringMatch(const wxChar *one, const wxChar *two, bool subString = true, bool exact = false);
+
 // Define a variable value from the .ini file
 // Define a variable value from the .ini file
-char *RegisterSetting(char *settingName, char *settingValue, bool interactive = TRUE);
+wxChar *RegisterSetting(const wxString& settingName, const wxString& settingValue, bool interactive = true);
 
 // Major document styles
 #define LATEX_REPORT    1
 
 // Major document styles
 #define LATEX_REPORT    1
@@ -180,9 +192,9 @@ extern TexChunk *DocumentAuthor;
 extern TexChunk *DocumentDate;
 extern int DocumentStyle;
 extern int MinorDocumentStyle;
 extern TexChunk *DocumentDate;
 extern int DocumentStyle;
 extern int MinorDocumentStyle;
-extern char *BibliographyStyleString;
-extern char *DocumentStyleString;
-extern char *MinorDocumentStyleString;
+extern wxChar *BibliographyStyleString;
+extern wxChar *DocumentStyleString;
+extern wxChar *MinorDocumentStyleString;
 
 extern int normalFont;
 extern int smallFont;
 
 extern int normalFont;
 extern int smallFont;
@@ -205,10 +217,12 @@ extern int sectionFont;
 extern int subsectionFont;
 extern int titleFont;
 extern int authorFont;
 extern int subsectionFont;
 extern int titleFont;
 extern int authorFont;
-extern bool winHelp;  // Output in Windows Help format if TRUE, linear otherwise
+extern bool winHelp;  // Output in Windows Help format if true, linear otherwise
 extern bool isInteractive;
 extern bool runTwice;
 extern int convertMode;
 extern bool isInteractive;
 extern bool runTwice;
 extern int convertMode;
+extern bool checkCurlyBraces;
+extern bool checkSyntax;
 extern bool stopRunning;
 extern int  mirrorMargins;
 extern bool headerRule;
 extern bool stopRunning;
 extern int  mirrorMargins;
 extern bool headerRule;
@@ -222,38 +236,42 @@ extern bool useWord; // Insert Word table of contents, etc. etc.
 extern bool indexSubsections; // put subsections in index
 extern bool compatibilityMode;
 extern bool generateHPJ;      // Generate WinHelp HPJ file
 extern bool indexSubsections; // put subsections in index
 extern bool compatibilityMode;
 extern bool generateHPJ;      // Generate WinHelp HPJ file
-extern char *winHelpTitle;    // Title for Windows Help file
+extern wxChar *winHelpTitle;    // Title for Windows Help file
 extern int defaultTableColumnWidth;
 extern int defaultTableColumnWidth;
-extern char *bitmapMethod;
+extern wxChar *bitmapMethod;
 extern bool truncateFilenames; // Truncate for DOS
 extern int  winHelpVersion;    // Version e.g. 4 for Win95
 extern bool winHelpContents;   // Generate .cnt file
 extern bool htmlIndex;         // Generate .htx HTML index file
 extern bool htmlFrameContents; // Use frames for HTML contents page
 extern bool truncateFilenames; // Truncate for DOS
 extern int  winHelpVersion;    // Version e.g. 4 for Win95
 extern bool winHelpContents;   // Generate .cnt file
 extern bool htmlIndex;         // Generate .htx HTML index file
 extern bool htmlFrameContents; // Use frames for HTML contents page
+extern wxChar *htmlStylesheet; // Use this CSS stylesheet for HTML pages
 extern int  contentsDepth;     // Depth of contents for linear RTF files
 extern bool upperCaseNames;    // Filenames; default is lower case
 extern int  contentsDepth;     // Depth of contents for linear RTF files
 extern bool upperCaseNames;    // Filenames; default is lower case
-extern char *backgroundImageString; // HTML background image
-extern char *backgroundColourString; // HTML background colour
-extern char *textColourString; // HTML text colour
-extern char *linkColourString; // HTML link colour
-extern char *followedLinkColourString; // HTML followed link colour
+extern wxChar *backgroundImageString; // HTML background image
+extern wxChar *backgroundColourString; // HTML background colour
+extern wxChar *textColourString; // HTML text colour
+extern wxChar *linkColourString; // HTML link colour
+extern wxChar *followedLinkColourString; // HTML followed link colour
 extern bool combineSubSections; // Stop splitting files below section
 extern bool combineSubSections; // Stop splitting files below section
+extern bool htmlWorkshopFiles;  // generate HTML Help Workshop project files
+extern bool ignoreBadRefs;      // Don't insert (REF NOT FOUND)
+extern wxChar *htmlFaceName;      // HTML face name
 
 // Names to help with internationalisation
 
 // Names to help with internationalisation
-extern char *ContentsNameString;
-extern char *AbstractNameString;
-extern char *GlossaryNameString;
-extern char *ReferencesNameString;
-extern char *FiguresNameString;
-extern char *TablesNameString;
-extern char *FigureNameString;
-extern char *TableNameString;
-extern char *IndexNameString;
-extern char *ChapterNameString;
-extern char *SectionNameString;
-extern char *SubsectionNameString;
-extern char *SubsubsectionNameString;
-extern char *UpNameString;
+extern wxChar *ContentsNameString;
+extern wxChar *AbstractNameString;
+extern wxChar *GlossaryNameString;
+extern wxChar *ReferencesNameString;
+extern wxChar *FiguresNameString;
+extern wxChar *TablesNameString;
+extern wxChar *FigureNameString;
+extern wxChar *TableNameString;
+extern wxChar *IndexNameString;
+extern wxChar *ChapterNameString;
+extern wxChar *SectionNameString;
+extern wxChar *SubsectionNameString;
+extern wxChar *SubsubsectionNameString;
+extern wxChar *UpNameString;
 
 /*
  * HTML button identifiers: what kind of browse buttons
 
 /*
  * HTML button identifiers: what kind of browse buttons
@@ -298,26 +316,24 @@ extern TexChunk *      CentreHeaderEven;
 extern TexChunk *      CentreFooterEven;
 extern TexChunk *      RightHeaderEven;
 extern TexChunk *      RightFooterEven;
 extern TexChunk *      CentreFooterEven;
 extern TexChunk *      RightHeaderEven;
 extern TexChunk *      RightFooterEven;
-extern char *          PageStyle;
+extern wxChar *        PageStyle;
 
 // Repeat the currentSection, either real (Chapter) or simulated (References)
 extern void OutputCurrentSection(void);
 
 // Repeat the currentSection, either real (Chapter) or simulated (References)
 extern void OutputCurrentSection(void);
-extern void OutputCurrentSectionToString(char *buf);
-extern void OutputChunkToString(TexChunk *chunk, char *buf);
-
-extern char *fakeCurrentSection;
+extern void OutputCurrentSectionToString(wxChar *buf);
+extern void OutputChunkToString(TexChunk *chunk, wxChar *buf);
 
 // Called by Tex2Any to simulate a section
 
 // Called by Tex2Any to simulate a section
-extern void FakeCurrentSection(char *fakeSection, bool addToContents = TRUE);
+extern void FakeCurrentSection(wxChar *fakeSection, bool addToContents = true);
 
 /*
  * Local to Tex2Any library
  *
  */
 
 /*
  * Local to Tex2Any library
  *
  */
-extern char *currentArgData;
-extern bool haveArgData; // If TRUE, we're simulating the data.
-void StartSimulateArgument(char *data);
+
+extern wxChar *currentArgData;
+extern bool haveArgData; // If true, we're simulating the data.
+void StartSimulateArgument(wxChar *data);
 void EndSimulateArgument(void);
 
 /*
 void EndSimulateArgument(void);
 
 /*
@@ -329,7 +345,7 @@ void EndSimulateArgument(void);
 void OnMacro(int macroId, int no_args, bool start);
 
 // Called on start/end of argument examination.
 void OnMacro(int macroId, int no_args, bool start);
 
 // Called on start/end of argument examination.
-// Return TRUE at the start of an argument to traverse
+// Return true at the start of an argument to traverse
 // (output) the argument.
 bool OnArgument(int macroId, int arg_no, bool start);
 
 // (output) the argument.
 bool OnArgument(int macroId, int arg_no, bool start);
 
@@ -340,13 +356,13 @@ void DefaultOnMacro(int macroId, int no_args, bool start);
 bool DefaultOnArgument(int macroId, int arg_no, bool start);
 
 // Called on error
 bool DefaultOnArgument(int macroId, int arg_no, bool start);
 
 // Called on error
-void OnError(char *msg);
+void OnError(const wxChar *msg);
 
 // Called for information
 
 // Called for information
-void OnInform(char *msg);
+void OnInform(const wxChar *msg);
 
 // Special yield wrapper
 
 // Special yield wrapper
-void Tex2RTFYield(bool force = FALSE);
+void Tex2RTFYield(bool force = false);
 
 /*
  * Useful utilities
 
 /*
  * Useful utilities
@@ -355,13 +371,13 @@ void Tex2RTFYield(bool force = FALSE);
 
 // Look for \label macro, use this ref name if found or
 // make up a topic name otherwise.
 
 // Look for \label macro, use this ref name if found or
 // make up a topic name otherwise.
-char *FindTopicName(TexChunk *chunk);
+wxChar *FindTopicName(TexChunk *chunk);
 // Force the current topic to be this (e.g. force 'references' label).
 // Force the current topic to be this (e.g. force 'references' label).
-void ForceTopicName(char *name);
+void ForceTopicName(const wxChar *name);
 void ResetTopicCounter(void);
 
 // Parse unit eg. 14, 12pt, 34cm and return value in points.
 void ResetTopicCounter(void);
 
 // Parse unit eg. 14, 12pt, 34cm and return value in points.
-int ParseUnitArgument(char *unitArg);
+int ParseUnitArgument(wxChar *unitArg);
 
 // Set small, large, normal etc. point sizes for reference size
 void SetFontSizes(int pointSize);
 
 // Set small, large, normal etc. point sizes for reference size
 void SetFontSizes(int pointSize);
@@ -371,8 +387,8 @@ void SetFontSizes(int pointSize);
  * IF one exists. Inserts zero into buffer.
  *
  */
  * IF one exists. Inserts zero into buffer.
  *
  */
-void StripExtension(char *buffer);
+
+void StripExtension(wxChar *buffer);
 
 /*
  * Reference structure
 
 /*
  * Reference structure
@@ -382,39 +398,28 @@ void StripExtension(char *buffer);
 class TexRef: public wxObject
 {
  public:
 class TexRef: public wxObject
 {
  public:
-  char *refLabel;      // Reference label
-  char *refFile;       // Reference filename (can be NULL)
-  char *sectionNumber; // Section or figure number (as a string)
-  char *sectionName; // name e.g. 'section'
-  TexRef(char *label, char *file, char *section, char *sectionN = NULL)
-  {
-    refLabel = copystring(label);
-    refFile = file ? copystring(file) : (char*) NULL;
-    sectionNumber = section ? copystring(section) : copystring("??");
-    sectionName = sectionN ? copystring(sectionN) : copystring("??");
-  }
-  ~TexRef(void)
-  {
-    delete[] refLabel; delete[] refFile; delete[] sectionNumber; delete[] sectionName;
-  }
+  wxChar *refLabel;      // Reference label
+  wxChar *refFile;       // Reference filename (can be NULL)
+  wxChar *sectionNumber; // Section or figure number (as a string)
+  wxChar *sectionName; // name e.g. 'section'
+  TexRef(const wxChar *label, const wxChar *file, const wxChar *section, const wxChar *sectionN = NULL);
+  virtual ~TexRef(void);
 };
 
 };
 
-extern wxHashTable TexReferences;
-
 /*
  * Add a reference
  *
  */
 /*
  * Add a reference
  *
  */
-void AddTexRef(char *name, char *file = NULL, char *sectionName = NULL,
+
+void AddTexRef(wxChar *name, wxChar *file = NULL, wxChar *sectionName = NULL,
          int chapter = 0, int section = 0, int subsection = 0, int subsubsection = 0);
 
 /*
  * Read and write reference file (.ref), to resolve refs for second pass.
  *
  */
          int chapter = 0, int section = 0, int subsection = 0, int subsubsection = 0);
 
 /*
  * Read and write reference file (.ref), to resolve refs for second pass.
  *
  */
-void WriteTexReferences(char *filename);
-void ReadTexReferences(char *filename);
+void WriteTexReferences(wxChar *filename);
+void ReadTexReferences(wxChar *filename);
 
 /*
  * Bibliography stuff
 
 /*
  * Bibliography stuff
@@ -424,33 +429,33 @@ void ReadTexReferences(char *filename);
 class BibEntry: public wxObject
 {
  public:
 class BibEntry: public wxObject
 {
  public:
-  char *key;
+  wxChar *key;
 
   /*
    * book, inbook, article, phdthesis, inproceedings, techreport
    */
 
   /*
    * book, inbook, article, phdthesis, inproceedings, techreport
    */
-  char *type;
+  wxChar *type;
 
   /*
    * Possible fields
    *
    */
 
   /*
    * Possible fields
    *
    */
-  char *editor;
-  char *title;
-  char *booktitle;
-  char *author;
-  char *journal;
-  char *volume;
-  char *number;
-  char *year;
-  char *month;
-  char *pages;
-  char *chapter;
-  char *publisher;
-  char *address;
-  char *institution;
-  char *organization;
-  char *comment;
+  wxChar *editor;
+  wxChar *title;
+  wxChar *booktitle;
+  wxChar *author;
+  wxChar *journal;
+  wxChar *volume;
+  wxChar *number;
+  wxChar *year;
+  wxChar *month;
+  wxChar *pages;
+  wxChar *chapter;
+  wxChar *publisher;
+  wxChar *address;
+  wxChar *institution;
+  wxChar *organization;
+  wxChar *comment;
 
   inline BibEntry(void)
   {
 
   inline BibEntry(void)
   {
@@ -478,11 +483,11 @@ class BibEntry: public wxObject
 extern wxList BibList;
 extern wxStringList CitationList;
 
 extern wxList BibList;
 extern wxStringList CitationList;
 
-bool ReadBib(char *filename);
+bool ReadBib(wxChar *filename);
 void OutputBib(void);
 void ResolveBibReferences(void);
 void OutputBib(void);
 void ResolveBibReferences(void);
-void AddCitation(char *citeKey);
-TexRef *FindReference(char *key);
+void AddCitation(wxChar *citeKey);
+TexRef *FindReference(wxChar *key);
 
 /*
  * Ability to customize, or at least suppress unknown macro errors
 
 /*
  * Ability to customize, or at least suppress unknown macro errors
@@ -497,25 +502,26 @@ extern wxList CustomMacroList;
 
 class CustomMacro: public wxObject
 {
 
 class CustomMacro: public wxObject
 {
- public:
-  char *macroName;
-  char *macroBody;
-  int noArgs;
-  inline CustomMacro(char *name, int args, char *body)
-  {
-    noArgs = args;
-    macroName = copystring(name);
-    if (body)
-      macroBody = copystring(body);
-    else
-      macroBody = NULL;
-  }
+public:
+    wxChar *macroName;
+    wxChar *macroBody;
+    int noArgs;
+    inline CustomMacro(const wxChar *name, int args, wxChar *body)
+    {
+        noArgs = args;
+        macroName = wxStrcpy(new wxChar[wxStrlen(name) + 1], name);
+        if (body)
+            macroBody = wxStrcpy(new wxChar[wxStrlen(body) + 1], body);
+        else
+            macroBody = NULL;
+    }
+    virtual ~CustomMacro();
 };
 
 };
 
-bool ReadCustomMacros(char *filename);
+bool ReadCustomMacros(const wxString& filename);
 void ShowCustomMacros(void);
 void ShowCustomMacros(void);
-CustomMacro *FindCustomMacro(char *name);
-char *ParseMultifieldString(char *s, int *pos);
+CustomMacro *FindCustomMacro(wxChar *name);
+wxChar *ParseMultifieldString(wxChar *s, int *pos);
 
 /*
  * Colour table stuff
 
 /*
  * Colour table stuff
@@ -525,20 +531,20 @@ char *ParseMultifieldString(char *s, int *pos);
 class ColourTableEntry: public wxObject
 {
  public:
 class ColourTableEntry: public wxObject
 {
  public:
-  char *name;
+  wxChar *name;
   unsigned int red;
   unsigned int green;
   unsigned int blue;
 
   unsigned int red;
   unsigned int green;
   unsigned int blue;
 
-  ColourTableEntry(char *theName, unsigned int r,  unsigned int g,  unsigned int b);
-  ~ColourTableEntry(void);
+  ColourTableEntry(const wxChar *theName, unsigned int r,  unsigned int g,  unsigned int b);
+  virtual ~ColourTableEntry(void);
 };
 
 extern wxList ColourTable;
 };
 
 extern wxList ColourTable;
-extern void AddColour(char *theName, unsigned int r,  unsigned int g,  unsigned int b);
-extern int FindColourPosition(char *theName);
+extern void AddColour(const wxChar *theName, unsigned int r,  unsigned int g,  unsigned int b);
+extern int FindColourPosition(wxChar *theName);
 // Converts e.g. "red" -> "#FF0000"
 // Converts e.g. "red" -> "#FF0000"
-extern bool FindColourHTMLString(char *theName, char *buf);
+extern bool FindColourHTMLString(wxChar *theName, wxChar *buf);
 extern void InitialiseColourTable(void);
 
 #define ltABSTRACT          1
 extern void InitialiseColourTable(void);
 
 #define ltABSTRACT          1
@@ -824,7 +830,7 @@ extern void InitialiseColourTable(void);
 #define ltURLREF            551
 #define ltUPPERCASE         552
 #define ltUSEPACKAGE        553
 #define ltURLREF            551
 #define ltUPPERCASE         552
 #define ltUSEPACKAGE        553
-  
+
 #define ltVDOTS             570
 #define ltVERBATIMINPUT     571
 #define ltVERBATIM          572
 #define ltVDOTS             570
 #define ltVERBATIMINPUT     571
 #define ltVERBATIM          572
@@ -1062,6 +1068,3 @@ extern void InitialiseColourTable(void);
 #define ltTOPLEVEL          15000
 #define ltCUSTOM_MACRO      15001
 #define ltSOLO_BLOCK        15002
 #define ltTOPLEVEL          15000
 #define ltCUSTOM_MACRO      15001
 #define ltSOLO_BLOCK        15002
-
-
-