a minor problem left.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@507 
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
- * Revision 1.1  1998/06/29 12:44:36  KB
- * Added my wxWindows based layout engine to the repository.
- * It arranges text and graphics for display on a wxDC.
- * This code is licensed under the LGPL.
+ * Revision 1.2  1998/08/12 08:33:23  KB
+ * Cursor and insert/delete work much better now, code streamlined, still
+ * a minor problem left.
+ *
+ * Revision 1.6  1998/07/08 11:56:56  KB
+ * M compiles and runs on Solaris 2.5/gcc 2.8/c-client gso
+ *
+ * Revision 1.5  1998/06/27 20:07:18  KB
+ * several bug fixes for kbList
+ * started adding my layout stuff
  *
  * Revision 1.1.1.1  1998/06/13 21:51:12  karsten
  * initial code
  *
  * Revision 1.1.1.1  1998/06/13 21:51:12  karsten
  * initial code
 #   pragma implementation "kbList.h"
 #endif
 
 #   pragma implementation "kbList.h"
 #endif
 
+#ifdef   M_BASEDIR
+#   include   "Mconfig.h"
+#endif
 
 kbListNode::kbListNode( void *ielement,
                         kbListNode *iprev,
 
 kbListNode::kbListNode( void *ielement,
                         kbListNode *iprev,
    else if(i.Node() == first)
    {
       push_front(element);
    else if(i.Node() == first)
    {
       push_front(element);
-      return;
-   }
-   else if(i.Node() == last)
-   {
-      push_back(element);
       return;
    }
    i = kbList::iterator(new kbListNode(element, i.Node()->prev, i.Node()));
       return;
    }
    i = kbList::iterator(new kbListNode(element, i.Node()->prev, i.Node()));
 
  * (C) 1998 by Karsten Ballüder (Ballueder@usa.net)                 *
  *                                                                  *
  * $Id$
  * (C) 1998 by Karsten Ballüder (Ballueder@usa.net)                 *
  *                                                                  *
  * $Id$
- * $Log$
- * Revision 1.1  1998/06/29 12:44:36  KB
- * Added my wxWindows based layout engine to the repository.
- * It arranges text and graphics for display on a wxDC.
- * This code is licensed under the LGPL.
- *
- * Revision 1.6  1998/06/27 20:06:10  KB
- * Added my layout code.
  *
  *******************************************************************/
 
  *
  *******************************************************************/
 
    bool empty(void) const
       { return first == NULL ; }
 
    bool empty(void) const
       { return first == NULL ; }
 
    /// if true, list owns entries
    bool        ownsEntries;
    /// pointer to first element in list
    /// if true, list owns entries
    bool        ownsEntries;
    /// pointer to first element in list
    /// pointer to last element in list
    kbListNode *last;
 
    /// pointer to last element in list
    kbListNode *last;
 
    /// forbid copy construction
    kbList(kbList const &foo);
    /// forbid assignments
    /// forbid copy construction
    kbList(kbList const &foo);
    /// forbid assignments
          /* the cast is needed for MS VC++ 5.0 */ \
          { return (type *)((kbList::iterator *)this)->operator*() ; } \
    }; \
          /* the cast is needed for MS VC++ 5.0 */ \
          { return (type *)((kbList::iterator *)this)->operator*() ; } \
    }; \
-   inline name(bool ownsEntriesFlag = true) \
+   inline name(bool ownsEntriesFlag = FALSE) \
       : kbList(ownsEntriesFlag) {} \
    \
    inline void push_back(type *element) \
       : kbList(ownsEntriesFlag) {} \
    \
    inline void push_back(type *element) \
    inline void insert(iterator & i, type *element) \
       { kbList::insert(i, (void *) element); } \
    \
    inline void insert(iterator & i, type *element) \
       { kbList::insert(i, (void *) element); } \
    \
-   void erase(iterator & i) \
+   inline void erase(iterator & i) \
       { kbList::erase(i); } \
    \
    inline iterator begin(void) const \
       { kbList::erase(i); } \
    \
    inline iterator begin(void) const \
    \
    inline iterator tail(void) const \
       { return kbList::tail(); } \
    \
    inline iterator tail(void) const \
       { return kbList::tail(); } \
+   ~name() \
+   { \
+      kbListNode *next; \
+      while ( first != NULL ) \
+      { \
+         next = first->next; \
+         if(ownsEntries) \
+            delete typecast(first->element); \
+         delete first; \
+         first = next; \
+      } \
+   } \
+   private: \
+   inline type * typecast(void *ptr) \
+      { return (type *) ptr; } \
+   }
 
 #ifdef   MCONFIG_H
 /// define the most commonly used list type once:
 
 #ifdef   MCONFIG_H
 /// define the most commonly used list type once:
 
 //-----------------------------------------------------------------------------
 
    enum ids{ ID_EDIT = 1, ID_ADD_SAMPLE, ID_CLEAR, ID_PRINT, ID_DPRINT,
 //-----------------------------------------------------------------------------
 
    enum ids{ ID_EDIT = 1, ID_ADD_SAMPLE, ID_CLEAR, ID_PRINT, ID_DPRINT,
-             ID_WXLAYOUT_DEBUG, ID_QUIT, ID_CLICK, ID_HTML, ID_TEXT };
+             ID_WXLAYOUT_DEBUG, ID_QUIT, ID_CLICK, ID_HTML, ID_TEXT, ID_TEST };
 
 
 IMPLEMENT_DYNAMIC_CLASS( MyFrame, wxFrame )
 
 
 IMPLEMENT_DYNAMIC_CLASS( MyFrame, wxFrame )
    file_menu->Append( ID_DPRINT, "Direct Print");
    file_menu->Append( ID_TEXT, "Export Text");
    file_menu->Append( ID_HTML, "Export HTML");
    file_menu->Append( ID_DPRINT, "Direct Print");
    file_menu->Append( ID_TEXT, "Export Text");
    file_menu->Append( ID_HTML, "Export HTML");
+   file_menu->Append( ID_TEST, "Test");
    file_menu->Append( ID_QUIT, "Exit");
   
    wxMenuBar *menu_bar = new wxMenuBar();
    file_menu->Append( ID_QUIT, "Exit");
   
    wxMenuBar *menu_bar = new wxMenuBar();
    case ID_CLICK:
       cerr << "Received click event." << endl;
       break;
    case ID_CLICK:
       cerr << "Received click event." << endl;
       break;
+   case ID_TEST:
+   {
+      Clear();
+      m_lwin->GetLayoutList().LineBreak();
+      m_lwin->GetLayoutList().Insert("abc");
+      m_lwin->GetLayoutList().LineBreak();
+      m_lwin->GetLayoutList().Insert("def");
+      break;
+   }
    case ID_HTML:
    {
       wxLayoutExportObject *export;
    case ID_HTML:
    {
       wxLayoutExportObject *export;
 
 #pragma implementation "wxllist.h"
 #endif
 
 #pragma implementation "wxllist.h"
 #endif
 
+// these two lines are for use in M:
+//#include "Mpch.h"
+//#include "gui/wxllist.h"
+
-#include   <wx/dc.h>
-#include   <wx/postscrp.h>
-#include   <wx/print.h>
+#ifndef USE_PCH
+#  include   "iostream.h"
+
+#  include   <wx/dc.h>
+#  include   <wx/postscrp.h>
+#  include   <wx/print.h>
+#endif
 
 #define   BASELINESTRETCH   12
 
 
 #define   BASELINESTRETCH   12
 
         << GetSize(&bl).y << " bl=" << bl; 
 }
 
         << GetSize(&bl).y << " bl=" << bl; 
 }
 
-#  define   VAR(x)   cerr << #x"=" << x << endl;
-#  define   DBG_POINT(p)   cerr << #p << ": " << p.x << ',' << p.y << endl
-#  define   TRACE(f)   cerr << #f":" << endl;
+#  define   WXL_VAR(x)   cerr << #x"=" << x << endl;
+#  define   WXL_DBG_POINT(p)   cerr << #p << ": " << p.x << ',' << p.y << endl
+#  define   WXL_TRACE(f)   cerr << #f":" << endl;
-#  define   VAR(x)   
-#  define   DBG_POINT(p)   
-#  define   TRACE(f)   
+#  define   WXL_VAR(x)   
+#  define   WXL_DBG_POINT(p)   
+#  define   WXL_TRACE(f)   
 #endif
 
 //-------------------------- wxLayoutObjectText
 #endif
 
 //-------------------------- wxLayoutObjectText
 //-------------------------- wxLayoutObjectIcon
 
 wxLayoutObjectIcon::wxLayoutObjectIcon(wxIcon *icon)
 //-------------------------- wxLayoutObjectIcon
 
 wxLayoutObjectIcon::wxLayoutObjectIcon(wxIcon *icon)
    if(size != -1)      m_FontPtSize = size;
    if(style != -1)     m_FontStyle = style;
    if(weight != -1)    m_FontWeight = weight;
    if(size != -1)      m_FontPtSize = size;
    if(style != -1)     m_FontStyle = style;
    if(weight != -1)    m_FontWeight = weight;
-   if(underline != -1) m_FontUnderline = underline;
+   if(underline != -1) m_FontUnderline = underline != 0;
 
    if(fg != NULL)     m_ColourFG = fg;
    if(bg != NULL)     m_ColourBG = bg;
 
    if(fg != NULL)     m_ColourFG = fg;
    if(bg != NULL)     m_ColourBG = bg;
    CoordType baseLine = m_FontPtSize;
    CoordType baseLineSkip = (BASELINESTRETCH * baseLine)/10;
 
    CoordType baseLine = m_FontPtSize;
    CoordType baseLineSkip = (BASELINESTRETCH * baseLine)/10;
 
+   // where to draw the cursor
+   wxPoint cursorPosition, cursorSize;
+   
    // we trace the objects' cursor positions so we can draw the cursor
    wxPoint cursor = wxPoint(0,0);
    // the cursor position inside the object
    // we trace the objects' cursor positions so we can draw the cursor
    wxPoint cursor = wxPoint(0,0);
    // the cursor position inside the object
 #endif
       dc.IsKindOf(CLASSINFO(wxPostScriptDC)))
    {
 #endif
       dc.IsKindOf(CLASSINFO(wxPostScriptDC)))
    {
-      VAR(wxThePrintSetupData);
+      WXL_VAR(wxThePrintSetupData);
       
       dc.GetSize(&pageWidth, &pageHeight);
       dc.StartDoc(_("Printing..."));
       
       dc.GetSize(&pageWidth, &pageHeight);
       dc.StartDoc(_("Printing..."));
    position.y = margins.right;
    position.x = margins.left;
    
    position.y = margins.right;
    position.x = margins.left;
    
-   VAR(findObject); VAR(findCoords.x); VAR(findCoords.y);
+   WXL_VAR(findObject); WXL_VAR(findCoords.x); WXL_VAR(findCoords.y);
    // if the cursorobject is a cmd, we need to find the first
    // printable object:
    while(cursorObject != end()
    // if the cursorobject is a cmd, we need to find the first
    // printable object:
    while(cursorObject != end()
             long descent = 0l; long width, height;
             tobj = (wxLayoutObjectText *)*i;
             String  str = tobj->GetText();
             long descent = 0l; long width, height;
             tobj = (wxLayoutObjectText *)*i;
             String  str = tobj->GetText();
-            VAR(m_CursorPosition.x); VAR(cursor.x);
+            WXL_VAR(m_CursorPosition.x); WXL_VAR(cursor.x);
             str = str.substr(0, cursorOffset);
             str = str.substr(0, cursorOffset);
             dc.GetTextExtent(Str(str), &width,&height, &descent);
             dc.GetTextExtent(Str(str), &width,&height, &descent);
-            VAR(height);
-            VAR(width); VAR(descent);
-            if(width < 1) width = 1;
-            dc.DrawLine(position.x+width,
-                        position.y+(baseLineSkip-height),
-                        position.x+width, position.y+baseLineSkip);
+            WXL_VAR(height);
+            WXL_VAR(width);
+            WXL_VAR(descent);
+            cursorPosition = wxPoint(position.x+width,
+                                      position.y+(baseLineSkip-height));
+            cursorSize = wxPoint(1, height);
+            //dc.DrawLine(position.x+width,
+            //            position.y+(baseLineSkip-height),
+            //            position.x+width, position.y+baseLineSkip);
          }
          else
          {
             if(type == WXLO_TYPE_LINEBREAK)
          }
          else
          {
             if(type == WXLO_TYPE_LINEBREAK)
-               dc.DrawLine(0, position.y+baseLineSkip, 0, position.y+2*baseLineSkip);
+               //dc.DrawLine(0, position.y+baseLineSkip, 0,               position.y+2*baseLineSkip);
+            {
+               cursorPosition = wxPoint(0, position.y);
+               cursorSize = wxPoint(1,baseLineSkip);
+            }
-               if(size.x == 0)
-               {
-                  if(size.y == 0)
-                     dc.DrawLine(position.x, position.y, position.x, position.y+baseLineSkip);
-                  else
-                     dc.DrawLine(position.x, position.y, position.x, position.y+size.y);
-               }
-               else
-                  dc.DrawRectangle(position.x, position.y, size.x, size.y);
+               cursorPosition = wxPoint(position.x, position.y);
+               cursorSize = wxPoint(size.x > 0 ? size.x : 1,size.y > 0 ? size.y : baseLineSkip);
+   // draw the cursor
+   if(m_Editable)
+   {
+      dc.DrawRectangle(cursorPosition.x, cursorPosition.y,
+                       cursorSize.x, cursorSize.y);
+   }
    m_MaxY = position.y;
    return foundObject;
 }
    m_MaxY = position.y;
    return foundObject;
 }
 // don't change this, I know how to optimise this and will do it real 
 // soon (KB)
 
 // don't change this, I know how to optimise this and will do it real 
 // soon (KB)
 
+/*
+ * FindObjectCursor:
+ * Finds the object belonging to a given cursor position cpos and
+ * returns an iterator to that object and stores the relative cursor
+ * position in offset.
+ *
+ * For linebreaks, the offset can be 0=before or 1=after.
+ *
+ * If the cpos coordinates don't exist, they are modified.
+ */
+
 wxLayoutObjectList::iterator 
 wxLayoutObjectList::iterator 
-wxLayoutList::FindObjectCursor(wxPoint const &cpos, CoordType *offset)
+wxLayoutList::FindObjectCursor(wxPoint *cpos, CoordType *offset)
-   wxPoint cursor = wxPoint(0,0);  // runs along the objects
+   wxPoint object = wxPoint(0,0);  // runs along the objects
    CoordType width;
    wxLayoutObjectList::iterator i;
 
 #ifdef WXLAYOUT_DEBUG
    CoordType width;
    wxLayoutObjectList::iterator i;
 
 #ifdef WXLAYOUT_DEBUG
-   cerr << "Looking for object at " << cpos.x << ',' << cpos.y <<
+   cerr << "Looking for object at " << cpos->x << ',' << cpos->y <<
-   for(i = begin(); i != end() && cursor.y <= cpos.y; i++)
+   for(i = begin(); i != end() && object.y <= cpos->y; i++)
-      width = 0;
-      if((*i)->GetType() == WXLO_TYPE_LINEBREAK)
+      width = (**i).CountPositions();
+      if(cpos->y == object.y) // a possible candidate
-         if(cpos.y == cursor.y && i != begin())
+         if((**i).GetType() ==WXLO_TYPE_LINEBREAK)
-            --i;
-            if(offset) *offset = i != end() ? (*i)->CountPositions() : 0;
+            if(cpos->x == object.x)
+            {
+               *offset = 0;
+               return i;
+            }
+            *offset=1;
+            cpos->x = object.x;
+            return i;
+         }
+         if(cpos->x >= object.x && cpos->x <= object.x+width) // overlap
+         {
+            if(offset) *offset = cpos->x-object.x;
+#ifdef WXLAYOUT_DEBUG
+            cerr << "   found object at " << object.x << ',' <<
+               object.y << ", type:" << _t[(*i)->GetType()] <<endl;
+#endif      
-         cursor.x = 0; cursor.y ++;
-      else
-         cursor.x += (width = (*i)->CountPositions());
-      if(cursor.y == cpos.y && (cursor.x > cpos.x ||
-                                ((*i)->GetType() != WXLO_TYPE_CMD && cursor.x == cpos.x))
-         ) // found it ?   
+      // no overlap, increment coordinates
+      object.x += width;
+      if((**i).GetType() == WXLO_TYPE_LINEBREAK)
-         if(offset)
-            *offset = cpos.x-(cursor.x-width);  // 0==cursor before
-         // the object
-#ifdef WXLAYOUT_DEBUG
-         cerr << "   found object at " << cursor.x-width << ',' <<
-            cursor.y << ", type:" << _t[(*i)->GetType()] <<endl;
-#endif   
-         return i;
+         object.x = 0;
+         object.y++;
       }
    }
 #ifdef WXLAYOUT_DEBUG
    cerr << "   not found" << endl;
 #endif
       }
    }
 #ifdef WXLAYOUT_DEBUG
    cerr << "   not found" << endl;
 #endif
-   return end(); // not found
+   // return last object, coordinates of that one:
+   i = tail();
+   if(i == end())
+      return i;
+   if((**i).GetType()==WXLO_TYPE_LINEBREAK)
+   {
+      if(offset)
+         *offset = (cpos.x > object.x) : 1 : 0;
+      return i;
+   }
+   cpos->x = object.x; // would be the coordinate of next object
+   cpos->y = object.y;
+   cpos->x += width; // last object's width
+   if(*offset)  *offset = cpos->x-object.x
+   return i; // not found
 }
 
 wxLayoutObjectList::iterator 
 }
 
 wxLayoutObjectList::iterator 
 {
    wxLayoutObjectList::iterator obj = end();
 
 {
    wxLayoutObjectList::iterator obj = end();
 
-   obj = FindObjectCursor(m_CursorPosition, offset);
+   obj = FindObjectCursor(&m_CursorPosition, offset);
    if(obj == end())  // not ideal yet
    {
       obj = tail();
    if(obj == end())  // not ideal yet
    {
       obj = tail();
 void
 wxLayoutList::Delete(CoordType count)
 {
 void
 wxLayoutList::Delete(CoordType count)
 {
    wxLayoutObjectList::iterator i;
       
    do
    {
       i  = FindCurrentObject(&offs);
    wxLayoutObjectList::iterator i;
       
    do
    {
       i  = FindCurrentObject(&offs);
+   startover: // ugly, but easiest way to do it
-         return;
-#ifdef WXLAYOUT_DEBUG
-      cerr << "trying to delete: " << _t[(*i)->GetType()] << endl;
-#endif
+         return; // we cannot delete anything more
+
+      /* Here we need to treat linebreaks differently.
+         If offs==0 we are before the linebreak, otherwise behind.  */
       if((*i)->GetType() == WXLO_TYPE_LINEBREAK)
       if((*i)->GetType() == WXLO_TYPE_LINEBREAK)
-         m_MaxLine--;
-      if((*i)->GetType() == WXLO_TYPE_TEXT)
+      {
+         if(offs == 0)
+         {
+            m_MaxLine--;
+            erase(i);
+            count--;
+            continue; // we're done
+         }
+         else // delete the object behind the linebreak
+         {
+            i++; // we increment and continue as normal
+            offs=0;
+            goto startover; 
+         }
+      }
+      else if((*i)->GetType() == WXLO_TYPE_TEXT)
       {
          wxLayoutObjectText *tobj = (wxLayoutObjectText *)*i;
       {
          wxLayoutObjectText *tobj = (wxLayoutObjectText *)*i;
-         len = tobj->CountPositions();
+         CoordType len = tobj->CountPositions();
          // If we find the end of a text object, this means that we
          // have to delete from the object following it.
          // If we find the end of a text object, this means that we
          // have to delete from the object following it.
-            if(i != end() && (*i)->GetType() == WXLO_TYPE_TEXT)
-            {
-               offs = 0;  // delete from begin of next string
-               tobj = (wxLayoutObjectText *)*i;
-               len = tobj->CountPositions();
-            }
-            else
-            {
-               erase(i);
-               return;
-            }
+            offs = 0;
+            goto startover;
-         if(len <= count) // delete this object
+         else if(len <= count) // delete this object
          {
             count -= len;
             erase(i);
          {
             count -= len;
             erase(i);
             tobj->GetText().erase(offs,len);
             return; // we are done
          }
       }
             tobj->GetText().erase(offs,len);
             return; // we are done
          }
       }
-      else // delete the object
+      else // all other objects: delete the object
-         len = (*i)->CountPositions();
+         CoordType len = (*i)->CountPositions();
          erase(i); // after this, i is the iterator for the following object
          erase(i); // after this, i is the iterator for the following object
-         if(count > len)
-            count -= len;
-         else
-            count = 0;
+         count = count > len ? count -= len : 0;
       }
    }
    while(count && i != end());      
       }
    }
    while(count && i != end());      
    CoordType offs;
    wxLayoutObjectList::iterator i = FindCurrentObject(&offs);
 
    CoordType offs;
    wxLayoutObjectList::iterator i = FindCurrentObject(&offs);
 
+   WXL_TRACE(Insert(obj));
 
    if(i == end())
       push_back(obj);
 
    if(i == end())
       push_back(obj);
-   else
-   {      
-      // do we have to split a text object?
-      if((*i)->GetType() == WXLO_TYPE_TEXT && offs != 0 && offs != (*i)->CountPositions())
-      {
-         wxLayoutObjectText *tobj = (wxLayoutObjectText *) *i;
+   else if(offs == 0)
+      insert(i,obj);
+   // do we have to split a text object?
+   else if((*i)->GetType() == WXLO_TYPE_TEXT && offs != (*i)->CountPositions())
+   {
+      wxLayoutObjectText *tobj = (wxLayoutObjectText *) *i;
-         cerr << "text: '" << tobj->GetText() << "'" << endl;
-         VAR(offs);
+      cerr << "text: '" << tobj->GetText() << "'" << endl;
+      WXL_VAR(offs);
-         String left = tobj->GetText().substr(0,offs); // get part before cursor
-         VAR(left);
-         tobj->GetText() = tobj->GetText().substr(offs,(*i)->CountPositions()-offs); // keeps the right half
-         VAR(tobj->GetText());
-         insert(i,obj);
-         insert(i,new wxLayoutObjectText(left)); // inserts before
-      }
+      String left = tobj->GetText().substr(0,offs); // get part before cursor
+      WXL_VAR(left);
+      tobj->GetText() = tobj->GetText().substr(offs,(*i)->CountPositions()-offs); // keeps the right half
+      WXL_VAR(tobj->GetText());
+      insert(i,obj);
+      insert(i,new wxLayoutObjectText(left)); // inserts before
+   }
+   else
+   {
+     // all other cases, append after object:
+      wxLayoutObjectList::iterator j = i; // we want to apend after this object
+      j++;
+      if(j != end())
+         insert(j, obj);
-      {
-         wxLayoutObjectList::iterator j = i; // we want to apend after this object
-         j++;
-         if(j != end())
-            insert(j, obj);
-         else
-            push_back(obj);
-      }  
    m_CursorPosition.x += obj->CountPositions();
    if(obj->GetType() == WXLO_TYPE_LINEBREAK)
       m_MaxLine++;
    m_CursorPosition.x += obj->CountPositions();
    if(obj->GetType() == WXLO_TYPE_LINEBREAK)
       m_MaxLine++;
 wxLayoutList::Insert(String const &text)
 {
    wxLayoutObjectText *tobj = NULL;
 wxLayoutList::Insert(String const &text)
 {
    wxLayoutObjectText *tobj = NULL;
+   WXL_TRACE(Insert(text));
 
    if(i != end() && (*i)->GetType() == WXLO_TYPE_TEXT)
    {  // insert into an existing text object:
 
    if(i != end() && (*i)->GetType() == WXLO_TYPE_TEXT)
    {  // insert into an existing text object:
-      TRACE(inserting into existing object);
+      WXL_TRACE(inserting into existing object);
       tobj = (wxLayoutObjectText *)*i ;
       wxASSERT(tobj);
       tobj->GetText().insert(offs,text);
       tobj = (wxLayoutObjectText *)*i ;
       wxASSERT(tobj);
       tobj->GetText().insert(offs,text);
    {
       wxLayoutObjectList::iterator j = i;
       j--;
    {
       wxLayoutObjectList::iterator j = i;
       j--;
-      TRACE(checking previous object);
+      WXL_TRACE(checking previous object);
       if(0 && j != end() && (*j)->GetType() == WXLO_TYPE_TEXT)
       {
          tobj = (wxLayoutObjectText *)*i;
       if(0 && j != end() && (*j)->GetType() == WXLO_TYPE_TEXT)
       {
          tobj = (wxLayoutObjectText *)*i;
       }
       else  // insert a new text object
       {
       }
       else  // insert a new text object
       {
-         TRACE(creating new object);
+         WXL_TRACE(creating new object);
          Insert(new wxLayoutObjectText(text));  //FIXME not too optimal, slow
          return;  // position gets incremented in Insert(obj)
       }
          Insert(new wxLayoutObjectText(text));  //FIXME not too optimal, slow
          return;  // position gets incremented in Insert(obj)
       }
 
 
 // skip the following defines if embedded in M application
 #ifdef   M_BASEDIR
 
 // skip the following defines if embedded in M application
 #ifdef   M_BASEDIR
 class wxLayoutList;
 class wxLayoutObjectBase;
 
 class wxLayoutList;
 class wxLayoutObjectBase;
 
-/// Define a list type of wxLayoutObjectBase pointers.
-KBLIST_DEFINE(wxLayoutObjectList, wxLayoutObjectBase);
+class wxDC;
+class wxColour;
+class wxFont;
 
 /** The base class defining the interface to each object which can be
     part of the layout. Each object needs to draw itself and calculate 
 
 /** The base class defining the interface to each object which can be
     part of the layout. Each object needs to draw itself and calculate 
+/// Define a list type of wxLayoutObjectBase pointers.
+KBLIST_DEFINE(wxLayoutObjectList, wxLayoutObjectBase);
+
+
 /// object for text block
 class wxLayoutObjectText : public wxLayoutObjectBase
 {
 /// object for text block
 class wxLayoutObjectText : public wxLayoutObjectBase
 {
                      bool draw = true);
    virtual wxPoint GetSize(CoordType *baseLine) const;
    wxLayoutObjectIcon(wxIcon *icon);
                      bool draw = true);
    virtual wxPoint GetSize(CoordType *baseLine) const;
    wxLayoutObjectIcon(wxIcon *icon);
 };
 
 /// for export to html:
 };
 
 /// for export to html:
    bool      m_Editable;
    /// find the object to the cursor position and returns the offset
    /// in there
    bool      m_Editable;
    /// find the object to the cursor position and returns the offset
    /// in there
-   wxLayoutObjectList::iterator FindObjectCursor(wxPoint const &cpos, CoordType *offset = NULL);
+   wxLayoutObjectList::iterator FindObjectCursor(wxPoint *cpos, CoordType *offset = NULL);
 
    : wxScrolledWindow(parent)
 {
    m_ScrollbarsSet = false;
    : wxScrolledWindow(parent)
 {
    m_ScrollbarsSet = false;
 }
 
 void
 wxLayoutWindow::OnMouse(wxMouseEvent& event)
 {
 }
 
 void
 wxLayoutWindow::OnMouse(wxMouseEvent& event)
 {
-   if(m_EventId == 0) // nothing to do
+   if(m_EventId == -1) // nothing to do
-   // this is unintuitive
-   wxClientDC dc(this);
-   PrepareDC( dc );
-
-   m_FindPos.x = dc.DeviceToLogicalX( event.GetX() );
-   m_FindPos.y = dc.DeviceToLogicalY( event.GetY() );
-
+   m_FindPos.x = event.GetX();
+   m_FindPos.y = event.GetY();
    m_FoundObject = NULL;
 
 #ifdef   WXLAYOUT_DEBUG
    m_FoundObject = NULL;
 
 #ifdef   WXLAYOUT_DEBUG
    Refresh();
    if(m_FoundObject)
    {
    Refresh();
    if(m_FoundObject)
    {
       {
          wxCommandEvent commandEvent(wxEVENT_TYPE_MENU_COMMAND, m_EventId);
          commandEvent.SetEventObject( this );
       {
          wxCommandEvent commandEvent(wxEVENT_TYPE_MENU_COMMAND, m_EventId);
          commandEvent.SetEventObject( this );
    wxPaintDC dc( this );  // only when used as OnPaint for OnDraw we
    PrepareDC( dc );       // can skip the first two lines
 
    wxPaintDC dc( this );  // only when used as OnPaint for OnDraw we
    PrepareDC( dc );       // can skip the first two lines
 
-   if(m_EventId) // look for keyclicks
+   if(m_EventId != -1) // look for keyclicks
       m_FoundObject = m_llist.Draw(dc,true,m_FindPos);
    else
       m_llist.Draw(dc);
       m_FoundObject = m_llist.Draw(dc,true,m_FindPos);
    else
       m_llist.Draw(dc);
 
 #   pragma interface "wxlwindow.h"
 #endif
 
 #   pragma interface "wxlwindow.h"
 #endif
 
+#ifndef USE_PCH
+#  include   <wx/wx.h>
+#endif
-#define   BROKEN_COMPILER
-
-#ifdef   BROKEN_COMPILER
-#   define   virtual
-#endif
-
 class wxLayoutWindow : public wxScrolledWindow
 {
 public:
 class wxLayoutWindow : public wxScrolledWindow
 {
 public:
          SetBackgroundColour( *GetLayoutList().GetDefaults()->GetBGColour());
       }
 
          SetBackgroundColour( *GetLayoutList().GetDefaults()->GetBGColour());
       }
 
-   //virtual void OnDraw(wxDC &dc);
+   // callbacks
+   // NB: these functions are used as event handlers and must not be virtual
+   //void OnDraw(wxDC &dc);
    void OnPaint(wxPaintEvent &WXUNUSED(event));
    void OnPaint(wxPaintEvent &WXUNUSED(event));
-   virtual void OnMouse(wxMouseEvent& event);
-   virtual void OnChar(wxKeyEvent& event);
+   void OnMouse(wxMouseEvent& event);
+   void OnChar(wxKeyEvent& event);
+
+#ifdef __WXMSW__
+   virtual long MSWGetDlgCode();
+#endif //MSW
+
    void UpdateScrollbars(void);
    void Print(void);
    void UpdateScrollbars(void);
    void Print(void);
-   void Erase(void)
-      { m_llist.Clear(); Clear(); }
+   void Erase(void) { m_llist.Clear(); Clear(); }
    void SetEventId(int id) { m_EventId = id; }
    void SetEventId(int id) { m_EventId = id; }
-   wxPoint const &GetClickPosition(void) const { return
-                                                    m_ClickPosition; }
-   virtual ~wxLayoutWindow() {} ;
+   wxPoint const &GetClickPosition(void) const { return m_ClickPosition; }
+   virtual ~wxLayoutWindow() {}
+
 private:
    /// for sending events
    wxWindow *m_Parent;
 private:
    /// for sending events
    wxWindow *m_Parent;
    wxPoint m_FindPos;
    wxLayoutObjectBase *m_FoundObject;
    wxPoint m_ClickPosition;
    wxPoint m_FindPos;
    wxLayoutObjectBase *m_FoundObject;
    wxPoint m_ClickPosition;
-#ifdef   BROKEN_COMPILER
-#undef   virtual
-#endif
-