1 // Scintilla source code edit control 
   2 // PlatWX.cxx - implementation of platform facilities on wxWindows 
   3 // Copyright 1998-1999 by Neil Hodgson <neilh@scintilla.org> 
   4 //                        Robin Dunn <robin@aldunn.com> 
   5 // The License.txt file describes the conditions under which this software may be distributed. 
  10 #include <wx/encconv.h> 
  11 #include <wx/listctrl.h> 
  12 #include <wx/mstream.h> 
  14 #include <wx/imaglist.h> 
  18 #include "wx/stc/stc.h" 
  26 Point 
Point::FromLong(long lpoint
) { 
  27     return Point(lpoint 
& 0xFFFF, lpoint 
>> 16); 
  30 wxRect 
wxRectFromPRectangle(PRectangle prc
) { 
  31     wxRect 
rc(prc
.left
, prc
.top
, 
  32               prc
.right
-prc
.left
, prc
.bottom
-prc
.top
); 
  36 PRectangle 
PRectangleFromwxRect(wxRect rc
) { 
  37     return PRectangle(rc
.GetLeft(), rc
.GetTop(), 
  38                       rc
.GetRight()+1, rc
.GetBottom()+1); 
  41 wxColour 
wxColourFromCA(const ColourAllocated
& ca
) { 
  42     ColourDesired 
cd(ca
.AsLong()); 
  43     return wxColour(cd
.GetRed(), cd
.GetGreen(), cd
.GetBlue()); 
  46 //---------------------------------------------------------------------- 
  50     allowRealization 
= false; 
  57 void Palette::Release() { 
  61 // This method either adds a colour to the list of wanted colours (want==true) 
  62 // or retrieves the allocated colour back to the ColourPair. 
  63 // This is one method to make it easier to keep the code for wanting and retrieving in sync. 
  64 void Palette::WantFind(ColourPair 
&cp
, bool want
) { 
  66         for (int i
=0; i 
< used
; i
++) { 
  67             if (entries
[i
].desired 
== cp
.desired
) 
  71         if (used 
< numEntries
) { 
  72             entries
[used
].desired 
= cp
.desired
; 
  73             entries
[used
].allocated
.Set(cp
.desired
.AsLong()); 
  77         for (int i
=0; i 
< used
; i
++) { 
  78             if (entries
[i
].desired 
== cp
.desired
) { 
  79                 cp
.allocated 
= entries
[i
].allocated
; 
  83         cp
.allocated
.Set(cp
.desired
.AsLong()); 
  87 void Palette::Allocate(Window 
&) { 
  88     if (allowRealization
) { 
  93 //---------------------------------------------------------------------- 
 103 void Font::Create(const char *faceName
, int characterSet
, int size
, bool bold
, bool italic
) { 
 104     wxFontEncoding encoding
; 
 108     switch (characterSet
) { 
 110         case wxSTC_CHARSET_ANSI
: 
 111         case wxSTC_CHARSET_DEFAULT
: 
 112             encoding 
= wxFONTENCODING_DEFAULT
; 
 115         case wxSTC_CHARSET_BALTIC
: 
 116             encoding 
= wxFONTENCODING_ISO8859_13
; 
 119         case wxSTC_CHARSET_CHINESEBIG5
: 
 120             encoding 
= wxFONTENCODING_CP950
; 
 123         case wxSTC_CHARSET_EASTEUROPE
: 
 124             encoding 
= wxFONTENCODING_ISO8859_2
; 
 127         case wxSTC_CHARSET_GB2312
: 
 128             encoding 
= wxFONTENCODING_CP936
; 
 131         case wxSTC_CHARSET_GREEK
: 
 132             encoding 
= wxFONTENCODING_ISO8859_7
; 
 135         case wxSTC_CHARSET_HANGUL
: 
 136             encoding 
= wxFONTENCODING_CP949
; 
 139         case wxSTC_CHARSET_MAC
: 
 140             encoding 
= wxFONTENCODING_DEFAULT
; 
 143         case wxSTC_CHARSET_OEM
: 
 144             encoding 
= wxFONTENCODING_DEFAULT
; 
 147         case wxSTC_CHARSET_RUSSIAN
: 
 148             encoding 
= wxFONTENCODING_KOI8
; 
 151         case wxSTC_CHARSET_SHIFTJIS
: 
 152             encoding 
= wxFONTENCODING_CP932
; 
 155         case wxSTC_CHARSET_SYMBOL
: 
 156             encoding 
= wxFONTENCODING_DEFAULT
; 
 159         case wxSTC_CHARSET_TURKISH
: 
 160             encoding 
= wxFONTENCODING_ISO8859_9
; 
 163         case wxSTC_CHARSET_JOHAB
: 
 164             encoding 
= wxFONTENCODING_DEFAULT
; 
 167         case wxSTC_CHARSET_HEBREW
: 
 168             encoding 
= wxFONTENCODING_ISO8859_8
; 
 171         case wxSTC_CHARSET_ARABIC
: 
 172             encoding 
= wxFONTENCODING_ISO8859_6
; 
 175         case wxSTC_CHARSET_VIETNAMESE
: 
 176             encoding 
= wxFONTENCODING_DEFAULT
; 
 179         case wxSTC_CHARSET_THAI
: 
 180             encoding 
= wxFONTENCODING_ISO8859_11
; 
 184     wxFontEncodingArray ea 
= wxEncodingConverter::GetPlatformEquivalents(encoding
); 
 188     id 
= new wxFont(size
, 
 190                     italic 
? wxITALIC 
:  wxNORMAL
, 
 191                     bold 
? wxBOLD 
: wxNORMAL
, 
 198 void Font::Release() { 
 204 //---------------------------------------------------------------------- 
 206 class SurfaceImpl 
: public Surface 
{ 
 219     virtual void Init(WindowID wid
); 
 220     virtual void Init(SurfaceID sid
, WindowID wid
); 
 221     virtual void InitPixMap(int width
, int height
, Surface 
*surface_
, WindowID wid
); 
 223     virtual void Release(); 
 224     virtual bool Initialised(); 
 225     virtual void PenColour(ColourAllocated fore
); 
 226     virtual int LogPixelsY(); 
 227     virtual int DeviceHeightFont(int points
); 
 228     virtual void MoveTo(int x_
, int y_
); 
 229     virtual void LineTo(int x_
, int y_
); 
 230     virtual void Polygon(Point 
*pts
, int npts
, ColourAllocated fore
, ColourAllocated back
); 
 231     virtual void RectangleDraw(PRectangle rc
, ColourAllocated fore
, ColourAllocated back
); 
 232     virtual void FillRectangle(PRectangle rc
, ColourAllocated back
); 
 233     virtual void FillRectangle(PRectangle rc
, Surface 
&surfacePattern
); 
 234     virtual void RoundedRectangle(PRectangle rc
, ColourAllocated fore
, ColourAllocated back
); 
 235     virtual void Ellipse(PRectangle rc
, ColourAllocated fore
, ColourAllocated back
); 
 236     virtual void Copy(PRectangle rc
, Point from
, Surface 
&surfaceSource
); 
 238     virtual void DrawTextNoClip(PRectangle rc
, Font 
&font_
, int ybase
, const char *s
, int len
, ColourAllocated fore
, ColourAllocated back
); 
 239     virtual void DrawTextClipped(PRectangle rc
, Font 
&font_
, int ybase
, const char *s
, int len
, ColourAllocated fore
, ColourAllocated back
); 
 240     virtual void DrawTextTransparent(PRectangle rc
, Font 
&font_
, int ybase
, const char *s
, int len
, ColourAllocated fore
); 
 241     virtual void MeasureWidths(Font 
&font_
, const char *s
, int len
, int *positions
); 
 242     virtual int WidthText(Font 
&font_
, const char *s
, int len
); 
 243     virtual int WidthChar(Font 
&font_
, char ch
); 
 244     virtual int Ascent(Font 
&font_
); 
 245     virtual int Descent(Font 
&font_
); 
 246     virtual int InternalLeading(Font 
&font_
); 
 247     virtual int ExternalLeading(Font 
&font_
); 
 248     virtual int Height(Font 
&font_
); 
 249     virtual int AverageCharWidth(Font 
&font_
); 
 251     virtual int SetPalette(Palette 
*pal
, bool inBackGround
); 
 252     virtual void SetClip(PRectangle rc
); 
 253     virtual void FlushCachedState(); 
 255     virtual void SetUnicodeMode(bool unicodeMode_
); 
 256     virtual void SetDBCSMode(int codePage
); 
 258     void BrushColour(ColourAllocated back
); 
 259     void SetFont(Font 
&font_
); 
 264 SurfaceImpl::SurfaceImpl() : 
 265     hdc(0), hdcOwned(0), bitmap(0), 
 266     x(0), y(0), unicodeMode(0) 
 269 SurfaceImpl::~SurfaceImpl() { 
 273 void SurfaceImpl::Init(WindowID wid
) { 
 276     hdc 
= new wxMemoryDC(); 
 279     // On Mac and GTK the DC is not really valid until it has a bitmap 
 280     // selected into it.  So instead of just creating the DC with no bitmap, 
 281     // go ahead and give it one. 
 282     InitPixMap(1,1,NULL
,wid
); 
 286 void SurfaceImpl::Init(SurfaceID hdc_
, WindowID
) { 
 291 void SurfaceImpl::InitPixMap(int width
, int height
, Surface 
*surface_
, WindowID
) { 
 293     hdc 
= new wxMemoryDC(); 
 295     if (width 
< 1) width 
= 1; 
 296     if (height 
< 1) height 
= 1; 
 297     bitmap 
= new wxBitmap(width
, height
); 
 298     ((wxMemoryDC
*)hdc
)->SelectObject(*bitmap
); 
 302 void SurfaceImpl::Release() { 
 304         ((wxMemoryDC
*)hdc
)->SelectObject(wxNullBitmap
); 
 316 bool SurfaceImpl::Initialised() { 
 321 void SurfaceImpl::PenColour(ColourAllocated fore
) { 
 322     hdc
->SetPen(wxPen(wxColourFromCA(fore
), 1, wxSOLID
)); 
 325 void SurfaceImpl::BrushColour(ColourAllocated back
) { 
 326     hdc
->SetBrush(wxBrush(wxColourFromCA(back
), wxSOLID
)); 
 329 void SurfaceImpl::SetFont(Font 
&font_
) { 
 331       hdc
->SetFont(*((wxFont
*)font_
.GetID())); 
 335 int SurfaceImpl::LogPixelsY() { 
 336     return hdc
->GetPPI().y
; 
 339 int SurfaceImpl::DeviceHeightFont(int points
) { 
 343 void SurfaceImpl::MoveTo(int x_
, int y_
) { 
 348 void SurfaceImpl::LineTo(int x_
, int y_
) { 
 349     hdc
->DrawLine(x
,y
, x_
,y_
); 
 354 void SurfaceImpl::Polygon(Point 
*pts
, int npts
, ColourAllocated fore
, ColourAllocated back
) { 
 357     hdc
->DrawPolygon(npts
, (wxPoint
*)pts
); 
 360 void SurfaceImpl::RectangleDraw(PRectangle rc
, ColourAllocated fore
, ColourAllocated back
) { 
 363     hdc
->DrawRectangle(wxRectFromPRectangle(rc
)); 
 366 void SurfaceImpl::FillRectangle(PRectangle rc
, ColourAllocated back
) { 
 368     hdc
->SetPen(*wxTRANSPARENT_PEN
); 
 369     hdc
->DrawRectangle(wxRectFromPRectangle(rc
)); 
 372 void SurfaceImpl::FillRectangle(PRectangle rc
, Surface 
&surfacePattern
) { 
 374     if (((SurfaceImpl
&)surfacePattern
).bitmap
) 
 375         br 
= wxBrush(*((SurfaceImpl
&)surfacePattern
).bitmap
); 
 376     else    // Something is wrong so display in red 
 377         br 
= wxBrush(*wxRED
, wxSOLID
); 
 378     hdc
->SetPen(*wxTRANSPARENT_PEN
); 
 380     hdc
->DrawRectangle(wxRectFromPRectangle(rc
)); 
 383 void SurfaceImpl::RoundedRectangle(PRectangle rc
, ColourAllocated fore
, ColourAllocated back
) { 
 386     hdc
->DrawRoundedRectangle(wxRectFromPRectangle(rc
), 4); 
 389 void SurfaceImpl::Ellipse(PRectangle rc
, ColourAllocated fore
, ColourAllocated back
) { 
 392     hdc
->DrawEllipse(wxRectFromPRectangle(rc
)); 
 395 void SurfaceImpl::Copy(PRectangle rc
, Point from
, Surface 
&surfaceSource
) { 
 396     wxRect r 
= wxRectFromPRectangle(rc
); 
 397     hdc
->Blit(r
.x
, r
.y
, r
.width
, r
.height
, 
 398               ((SurfaceImpl
&)surfaceSource
).hdc
, 
 399               from
.x
, from
.y
, wxCOPY
); 
 402 void SurfaceImpl::DrawTextNoClip(PRectangle rc
, Font 
&font
, int ybase
, 
 403                                  const char *s
, int len
, 
 404                                  ColourAllocated fore
, ColourAllocated back
) { 
 406     hdc
->SetTextForeground(wxColourFromCA(fore
)); 
 407     hdc
->SetTextBackground(wxColourFromCA(back
)); 
 408     //FillRectangle(rc, back); 
 410     // ybase is where the baseline should be, but wxWin uses the upper left 
 411     // corner, so I need to calculate the real position for the text... 
 412     hdc
->DrawText(stc2wx(s
, len
), rc
.left
, ybase 
- font
.ascent
); 
 415 void SurfaceImpl::DrawTextClipped(PRectangle rc
, Font 
&font
, int ybase
, 
 416                                   const char *s
, int len
, 
 417                                   ColourAllocated fore
, ColourAllocated back
) { 
 419     hdc
->SetTextForeground(wxColourFromCA(fore
)); 
 420     hdc
->SetTextBackground(wxColourFromCA(back
)); 
 421     //FillRectangle(rc, back); 
 422     hdc
->SetClippingRegion(wxRectFromPRectangle(rc
)); 
 424     // see comments above 
 425     hdc
->DrawText(stc2wx(s
, len
), rc
.left
, ybase 
- font
.ascent
); 
 429 void SurfaceImpl::DrawTextTransparent(PRectangle rc
, Font 
&font
, int ybase
, 
 430                                       const char *s
, int len
, 
 431                                       ColourAllocated fore
) { 
 434     hdc
->SetTextForeground(wxColourFromCA(fore
)); 
 435     hdc
->SetBackgroundMode(wxTRANSPARENT
); 
 437     // ybase is where the baseline should be, but wxWin uses the upper left 
 438     // corner, so I need to calculate the real position for the text... 
 439     hdc
->DrawText(stc2wx(s
, len
), rc
.left
, ybase 
- font
.ascent
); 
 441     hdc
->SetBackgroundMode(wxSOLID
); 
 445 void SurfaceImpl::MeasureWidths(Font 
&font
, const char *s
, int len
, int *positions
) { 
 447     wxString str 
= stc2wx(s
, len
); 
 451     // Calculate the position of each character based on the widths of 
 452     // the previous characters 
 453     int* tpos 
= new int[len
]; 
 456     for (i
=0; i
<str
.Length(); i
++) { 
 458         hdc
->GetTextExtent(str
[i
], &w
, &h
); 
 460         tpos
[i
] = totalWidth
; 
 463     // Instead of a running total, remeasure from the begining of the 
 464     // text for each character's position.  This is because with AA fonts 
 465     // on OS X widths can be fractions of pixels wide when more than one 
 466     // are drawn together, so the sum of all character widths is not necessarily 
 467     // (and probably not) the same as the whole string width. 
 468     int* tpos 
= new int[len
]; 
 470     for (i
=0; i
<str
.Length(); i
++) { 
 472         hdc
->GetTextExtent(str
.Left(i
+1), &w
, &h
); 
 479     // Map the widths for UCS-2 characters back to the UTF-8 input string 
 480     // NOTE:  I don't think this is right for when sizeof(wxChar) > 2, ie wxGTK2 
 481     // so figure it out and fix it! 
 485         unsigned char uch 
= (unsigned char)s
[i
]; 
 486         positions
[i
++] = tpos
[ui
]; 
 488             if (uch 
< (0x80 + 0x40 + 0x20)) { 
 489                 positions
[i
++] = tpos
[ui
]; 
 491                 positions
[i
++] = tpos
[ui
]; 
 492                 positions
[i
++] = tpos
[ui
]; 
 499     // If not unicode then just use the widths we have 
 500     memcpy(positions
, tpos
, len 
* sizeof(*tpos
)); 
 507 int SurfaceImpl::WidthText(Font 
&font
, const char *s
, int len
) { 
 512     hdc
->GetTextExtent(stc2wx(s
, len
), &w
, &h
); 
 517 int SurfaceImpl::WidthChar(Font 
&font
, char ch
) { 
 521     char s
[2] = { ch
, 0 }; 
 523     hdc
->GetTextExtent(stc2wx(s
, 1), &w
, &h
); 
 527 #define EXTENT_TEST wxT(" `~!@#$%^&*()-_=+\\|[]{};:\"\'<,>.?/1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ") 
 529 int SurfaceImpl::Ascent(Font 
&font
) { 
 532     hdc
->GetTextExtent(EXTENT_TEST
, &w
, &h
, &d
, &e
); 
 537 int SurfaceImpl::Descent(Font 
&font
) { 
 540     hdc
->GetTextExtent(EXTENT_TEST
, &w
, &h
, &d
, &e
); 
 544 int SurfaceImpl::InternalLeading(Font 
&font
) { 
 548 int SurfaceImpl::ExternalLeading(Font 
&font
) { 
 551     hdc
->GetTextExtent(EXTENT_TEST
, &w
, &h
, &d
, &e
); 
 555 int SurfaceImpl::Height(Font 
&font
) { 
 557     return hdc
->GetCharHeight(); 
 560 int SurfaceImpl::AverageCharWidth(Font 
&font
) { 
 562     return hdc
->GetCharWidth(); 
 565 int SurfaceImpl::SetPalette(Palette 
*pal
, bool inBackGround
) { 
 569 void SurfaceImpl::SetClip(PRectangle rc
) { 
 570     hdc
->SetClippingRegion(wxRectFromPRectangle(rc
)); 
 573 void SurfaceImpl::FlushCachedState() { 
 576 void SurfaceImpl::SetUnicodeMode(bool unicodeMode_
) { 
 577     unicodeMode
=unicodeMode_
; 
 580 void SurfaceImpl::SetDBCSMode(int codePage
) { 
 581     // dbcsMode = codePage == SC_CP_DBCS; 
 585 Surface 
*Surface::Allocate() { 
 586     return new SurfaceImpl
; 
 590 //---------------------------------------------------------------------- 
 593 inline wxWindow
* GETWIN(WindowID id
) { return (wxWindow
*)id
; } 
 598 void Window::Destroy() { 
 601         GETWIN(id
)->Destroy(); 
 606 bool Window::HasFocus() { 
 607     return wxWindow::FindFocus() == GETWIN(id
); 
 610 PRectangle 
Window::GetPosition() { 
 611     if (! id
) return PRectangle(); 
 612     wxRect 
rc(GETWIN(id
)->GetPosition(), GETWIN(id
)->GetSize()); 
 613     return PRectangleFromwxRect(rc
); 
 616 void Window::SetPosition(PRectangle rc
) { 
 617     wxRect r 
= wxRectFromPRectangle(rc
); 
 618     GETWIN(id
)->SetSize(r
); 
 621 void Window::SetPositionRelative(PRectangle rc
, Window
) { 
 622     SetPosition(rc
);  // ???? 
 625 PRectangle 
Window::GetClientPosition() { 
 626     if (! id
) return PRectangle(); 
 627     wxSize sz 
= GETWIN(id
)->GetClientSize(); 
 628     return  PRectangle(0, 0, sz
.x
, sz
.y
); 
 631 void Window::Show(bool show
) { 
 632     GETWIN(id
)->Show(show
); 
 635 void Window::InvalidateAll() { 
 636     GETWIN(id
)->Refresh(false); 
 640 void Window::InvalidateRectangle(PRectangle rc
) { 
 641     wxRect r 
= wxRectFromPRectangle(rc
); 
 642     GETWIN(id
)->Refresh(false, &r
); 
 646 void Window::SetFont(Font 
&font
) { 
 647     GETWIN(id
)->SetFont(*((wxFont
*)font
.GetID())); 
 650 void Window::SetCursor(Cursor curs
) { 
 655         cursorId 
= wxCURSOR_IBEAM
; 
 658         cursorId 
= wxCURSOR_ARROW
; 
 661         cursorId 
= wxCURSOR_ARROW
; // ** no up arrow...  wxCURSOR_UPARROW; 
 664         cursorId 
= wxCURSOR_WAIT
; 
 667         cursorId 
= wxCURSOR_SIZEWE
; 
 670         cursorId 
= wxCURSOR_SIZENS
; 
 672     case cursorReverseArrow
: 
 673         cursorId 
= wxCURSOR_RIGHT_ARROW
; 
 676         cursorId 
= wxCURSOR_HAND
; 
 678         cursorId 
= wxCURSOR_ARROW
; 
 682        wxCursor wc 
= wxStockCursor(cursorId
) ; 
 684        wxCursor wc 
= wxCursor(cursorId
) ; 
 686        GETWIN(id
)->SetCursor(wc
); 
 690 void Window::SetTitle(const char *s
) { 
 691     GETWIN(id
)->SetTitle(stc2wx(s
)); 
 695 //---------------------------------------------------------------------- 
 696 // Helper classes for ListBox 
 699 // This is a simple subclass of wxLIstView that just resets focus to the 
 700 // parent when it gets it. 
 701 class wxSTCListBox 
: public wxListView 
{ 
 703     wxSTCListBox(wxWindow
* parent
, wxWindowID id
, 
 704                  const wxPoint
& pos
, const wxSize
& size
, 
 706         : wxListView(parent
, id
, pos
, size
, style
) 
 709     void OnFocus(wxFocusEvent
& event
) { 
 710         GetParent()->SetFocus(); 
 715     DECLARE_EVENT_TABLE() 
 718 BEGIN_EVENT_TABLE(wxSTCListBox
, wxListView
) 
 719     EVT_SET_FOCUS( wxSTCListBox::OnFocus
) 
 725 // A window to place the wxSTCListBox upon 
 726 class wxSTCListBoxWin 
: public wxWindow 
{ 
 729     CallBackAction      doubleClickAction
; 
 730     void*               doubleClickActionData
; 
 732     wxSTCListBoxWin(wxWindow
* parent
, wxWindowID id
) : 
 733         wxWindow(parent
, id
, wxDefaultPosition
, wxSize(0,0), wxNO_BORDER 
) 
 736         SetBackgroundColour(*wxBLACK
); 
 737         lv 
= new wxSTCListBox(this, id
, wxDefaultPosition
, wxDefaultSize
, 
 738                               wxLC_REPORT 
| wxLC_SINGLE_SEL 
| wxLC_NO_HEADER 
| wxNO_BORDER
); 
 739         lv
->SetCursor(wxCursor(wxCURSOR_ARROW
)); 
 740         lv
->InsertColumn(0, wxEmptyString
); 
 741         lv
->InsertColumn(1, wxEmptyString
); 
 746         wxImageList
* il 
= lv
->GetImageList(wxIMAGE_LIST_SMALL
); 
 749             il
->GetSize(0, w
, h
); 
 756     void SetDoubleClickAction(CallBackAction action
, void *data
) { 
 757         doubleClickAction 
= action
; 
 758         doubleClickActionData 
= data
; 
 762     void OnFocus(wxFocusEvent
& event
) { 
 763         GetParent()->SetFocus(); 
 767     void OnSize(wxSizeEvent
& event
) { 
 768         // resize the child, leaving a 1 pixel border 
 769         wxSize sz 
= GetClientSize(); 
 770         lv
->SetSize(1, 1, sz
.x
-2, sz
.y
-2); 
 771         // reset the column widths 
 772         lv
->SetColumnWidth(0, IconWidth()+4); 
 773         lv
->SetColumnWidth(1, sz
.x 
- 2 - lv
->GetColumnWidth(0) - 
 774                            wxSystemSettings::GetMetric(wxSYS_VSCROLL_X
)); 
 778     void OnActivate(wxListEvent
& event
) { 
 779         doubleClickAction(doubleClickActionData
); 
 782     wxListView
* GetLB() { return lv
; } 
 785     DECLARE_EVENT_TABLE() 
 789 BEGIN_EVENT_TABLE(wxSTCListBoxWin
, wxWindow
) 
 790     EVT_SET_FOCUS          (    wxSTCListBoxWin::OnFocus
) 
 791     EVT_SIZE               (    wxSTCListBoxWin::OnSize
) 
 792     EVT_LIST_ITEM_ACTIVATED(-1, wxSTCListBoxWin::OnActivate
) 
 797 inline wxSTCListBoxWin
* GETLBW(WindowID win
) { 
 798     return ((wxSTCListBoxWin
*)win
); 
 801 inline wxListView
* GETLB(WindowID win
) { 
 802     return GETLBW(win
)->GetLB(); 
 805 //---------------------------------------------------------------------- 
 807 class ListBoxImpl 
: public ListBox 
{ 
 811     int                 desiredVisibleRows
; 
 814     wxImageList
*        imgList
; 
 815     wxArrayInt
*         imgTypeMap
; 
 821     virtual void SetFont(Font 
&font
); 
 822     virtual void Create(Window 
&parent
, int ctrlID
, int lineHeight_
, bool unicodeMode_
); 
 823     virtual void SetAverageCharWidth(int width
); 
 824     virtual void SetVisibleRows(int rows
); 
 825     virtual PRectangle 
GetDesiredRect(); 
 826     virtual int CaretFromEdge(); 
 827     virtual void Clear(); 
 828     virtual void Append(char *s
, int type 
= -1); 
 829     virtual int Length(); 
 830     virtual void Select(int n
); 
 831     virtual int GetSelection(); 
 832     virtual int Find(const char *prefix
); 
 833     virtual void GetValue(int n
, char *value
, int len
); 
 835     virtual void RegisterImage(int type
, const char *xpm_data
); 
 836     virtual void ClearRegisteredImages(); 
 837     virtual void SetDoubleClickAction(CallBackAction
, void *); 
 842 ListBoxImpl::ListBoxImpl() 
 843     : lineHeight(10), unicodeMode(false), 
 844       desiredVisibleRows(5), aveCharWidth(8), maxStrWidth(0), 
 845       imgList(NULL
), imgTypeMap(NULL
) 
 849 ListBoxImpl::~ListBoxImpl() { 
 861 void ListBoxImpl::SetFont(Font 
&font
) { 
 862     GETLB(id
)->SetFont(*((wxFont
*)font
.GetID())); 
 866 void ListBoxImpl::Create(Window 
&parent
, int ctrlID
, int lineHeight_
, bool unicodeMode_
) { 
 867     lineHeight 
=  lineHeight_
; 
 868     unicodeMode 
= unicodeMode_
; 
 870     id 
= new wxSTCListBoxWin(GETWIN(parent
.GetID()), ctrlID
); 
 872         GETLB(id
)->SetImageList(imgList
, wxIMAGE_LIST_SMALL
); 
 876 void ListBoxImpl::SetAverageCharWidth(int width
) { 
 877     aveCharWidth 
= width
; 
 881 void ListBoxImpl::SetVisibleRows(int rows
) { 
 882     desiredVisibleRows 
= rows
; 
 886 PRectangle 
ListBoxImpl::GetDesiredRect() { 
 887     // wxListCtrl doesn't have a DoGetBestSize, so instead we kept track of 
 888     // the max size in Append and calculate it here... 
 889     int maxw 
= maxStrWidth
; 
 892     // give it a default if there are no lines, and/or add a bit more 
 893     if (maxw 
== 0) maxw 
= 100; 
 894     maxw 
+= aveCharWidth 
* 3 + 
 895             GETLBW(id
)->IconWidth() + wxSystemSettings::GetMetric(wxSYS_VSCROLL_X
); 
 899     // estimate a desired height 
 900     int count 
= GETLB(id
)->GetItemCount(); 
 903         GETLB(id
)->GetItemRect(0, rect
); 
 904         maxh 
= count 
* rect
.GetHeight(); 
 905         if (maxh 
> 140)  // TODO:  Use desiredVisibleRows?? 
 908         // Try to make the size an exact multiple of some number of lines 
 909         int lines 
= maxh 
/ rect
.GetHeight(); 
 910         maxh 
= (lines 
+ 1) * rect
.GetHeight() + 2; 
 924 int ListBoxImpl::CaretFromEdge() { 
 925     return 4 + GETLBW(id
)->IconWidth(); 
 929 void ListBoxImpl::Clear() { 
 930     GETLB(id
)->DeleteAllItems(); 
 934 void ListBoxImpl::Append(char *s
, int type
) { 
 935     wxString text 
= stc2wx(s
); 
 936     long count  
= GETLB(id
)->GetItemCount(); 
 937     long itemID  
= GETLB(id
)->InsertItem(count
, wxEmptyString
); 
 938     GETLB(id
)->SetItem(itemID
, 1, text
); 
 940     GETLB(id
)->GetTextExtent(text
, &itemWidth
, NULL
); 
 941     maxStrWidth 
= wxMax(maxStrWidth
, itemWidth
); 
 943         wxCHECK_RET(imgTypeMap
, wxT("Unexpected NULL imgTypeMap")); 
 944         long idx 
= imgTypeMap
->Item(type
); 
 945         GETLB(id
)->SetItemImage(itemID
, idx
, idx
); 
 950 int ListBoxImpl::Length() { 
 951     return GETLB(id
)->GetItemCount(); 
 955 void ListBoxImpl::Select(int n
) { 
 962     GETLB(id
)->Select(n
, select
); 
 966 int ListBoxImpl::GetSelection() { 
 967     return GETLB(id
)->GetFirstSelected(); 
 971 int ListBoxImpl::Find(const char *prefix
) { 
 977 void ListBoxImpl::GetValue(int n
, char *value
, int len
) { 
 981     item
.SetMask(wxLIST_MASK_TEXT
); 
 982     GETLB(id
)->GetItem(item
); 
 983     strncpy(value
, wx2stc(item
.GetText()), len
); 
 987 void ListBoxImpl::Sort() { 
 991 void ListBoxImpl::RegisterImage(int type
, const char *xpm_data
) { 
 992     wxMemoryInputStream 
stream(xpm_data
, strlen(xpm_data
)+1); 
 993     wxBitmap 
bmp(wxImage(stream
, wxBITMAP_TYPE_XPM
)); 
 996         // assumes all images are the same size 
 997         imgList 
= new wxImageList(bmp
.GetWidth(), bmp
.GetHeight(), TRUE
); 
 998         imgTypeMap 
= new wxArrayInt
; 
1001     int idx 
= imgList
->Add(bmp
); 
1003     // do we need to extend the mapping array? 
1004     wxArrayInt
& itm 
= *imgTypeMap
; 
1005     if ( itm
.GetCount() < (size_t)type
+1) 
1006         itm
.Add(-1, type 
- itm
.GetCount() + 1); 
1008     // Add an item that maps type to the image index 
1012 void ListBoxImpl::ClearRegisteredImages() { 
1022         GETLB(id
)->SetImageList(NULL
, wxIMAGE_LIST_SMALL
); 
1026 void ListBoxImpl::SetDoubleClickAction(CallBackAction action
, void *data
) { 
1027     GETLBW(id
)->SetDoubleClickAction(action
, data
); 
1032 ListBox::ListBox() { 
1035 ListBox::~ListBox() { 
1038 ListBox 
*ListBox::Allocate() { 
1039     return new ListBoxImpl(); 
1042 //---------------------------------------------------------------------- 
1044 Menu::Menu() : id(0) { 
1047 void Menu::CreatePopUp() { 
1052 void Menu::Destroy() { 
1058 void Menu::Show(Point pt
, Window 
&w
) { 
1059     GETWIN(w
.GetID())->PopupMenu((wxMenu
*)id
, pt
.x 
- 4, pt
.y
); 
1063 //---------------------------------------------------------------------- 
1065 ColourDesired 
Platform::Chrome() { 
1067     c 
= wxSystemSettings::GetColour(wxSYS_COLOUR_3DFACE
); 
1068     return ColourDesired(c
.Red(), c
.Green(), c
.Blue()); 
1071 ColourDesired 
Platform::ChromeHighlight() { 
1073     c 
= wxSystemSettings::GetColour(wxSYS_COLOUR_3DHIGHLIGHT
); 
1074     return ColourDesired(c
.Red(), c
.Green(), c
.Blue()); 
1077 const char *Platform::DefaultFont() { 
1078     static char buf
[128]; 
1079     strcpy(buf
, wxNORMAL_FONT
->GetFaceName().mbc_str()); 
1083 int Platform::DefaultFontSize() { 
1084     return wxNORMAL_FONT
->GetPointSize(); 
1087 unsigned int Platform::DoubleClickTime() { 
1088     return 500;   // **** ::GetDoubleClickTime(); 
1091 bool Platform::MouseButtonBounce() { 
1094 void Platform::DebugDisplay(const char *s
) { 
1095     wxLogDebug(stc2wx(s
)); 
1098 bool Platform::IsKeyDown(int key
) { 
1099     return false;  // I don't think we'll need this. 
1102 long Platform::SendScintilla(WindowID w
, 
1104                              unsigned long wParam
, 
1107     wxStyledTextCtrl
* stc 
= (wxStyledTextCtrl
*)w
; 
1108     return stc
->SendMsg(msg
, wParam
, lParam
); 
1111 long Platform::SendScintillaPointer(WindowID w
, 
1113                                     unsigned long wParam
, 
1116     wxStyledTextCtrl
* stc 
= (wxStyledTextCtrl
*)w
; 
1117     return stc
->SendMsg(msg
, wParam
, (long)lParam
); 
1121 // These are utility functions not really tied to a platform 
1123 int Platform::Minimum(int a
, int b
) { 
1130 int Platform::Maximum(int a
, int b
) { 
1139 void Platform::DebugPrintf(const char *format
, ...) { 
1143     va_start(pArguments
, format
); 
1144     vsprintf(buffer
,format
,pArguments
); 
1146     Platform::DebugDisplay(buffer
); 
1151 static bool assertionPopUps 
= true; 
1153 bool Platform::ShowAssertionPopUps(bool assertionPopUps_
) { 
1154         bool ret 
= assertionPopUps
; 
1155         assertionPopUps 
= assertionPopUps_
; 
1159 void Platform::Assert(const char *c
, const char *file
, int line
) { 
1161         sprintf(buffer
, "Assertion [%s] failed at %s %d", c
, file
, line
); 
1162         if (assertionPopUps
) { 
1164             wxMessageBox(stc2wx(buffer
), 
1165                          wxT("Assertion failure"), 
1166                          wxICON_HAND 
| wxOK
); 
1167 //              if (idButton == IDRETRY) { 
1169 //              } else if (idButton == IDIGNORE) { 
1175                 strcat(buffer
, "\r\n"); 
1176                 Platform::DebugDisplay(buffer
); 
1182 int Platform::Clamp(int val
, int minVal
, int maxVal
) { 
1191 bool Platform::IsDBCSLeadByte(int codePage
, char ch
) { 
1195 int Platform::DBCSCharLength(int codePage
, const char *s
) { 
1199 int Platform::DBCSCharMaxLength() { 
1204 //---------------------------------------------------------------------- 
1206 ElapsedTime::ElapsedTime() { 
1210 double ElapsedTime::Duration(bool reset
) { 
1211     double result 
= wxGetElapsedTime(reset
); 
1217 //----------------------------------------------------------------------