SetValidator( validator );
- bool bMultiLine = (style & wxTE_MULTILINE) != 0;
- if ( bMultiLine )
+ bool multi_line = (style & wxTE_MULTILINE) != 0;
+ if ( multi_line )
{
// a multi-line edit control: create a vertical scrollbar by default and
// horizontal if requested
// ... and put into the upper left hand corner of the table
m_widget = gtk_table_new(bHasHScrollbar ? 2 : 1, 2, FALSE);
- gtk_table_attach(GTK_TABLE(m_widget), m_text, 0, 1, 0, 1,
- GTK_FILL | GTK_EXPAND,
- GTK_FILL | GTK_EXPAND | GTK_SHRINK,
- 0, 0);
+ gtk_table_attach( GTK_TABLE(m_widget), m_text, 0, 1, 0, 1,
+ (GtkAttachOptions)(GTK_FILL | GTK_EXPAND | GTK_SHRINK),
+ (GtkAttachOptions)(GTK_FILL | GTK_EXPAND | GTK_SHRINK),
+ 0, 0);
// put the horizontal scrollbar in the lower left hand corner
if (bHasHScrollbar)
{
GtkWidget *hscrollbar = gtk_hscrollbar_new(GTK_TEXT(m_text)->hadj);
gtk_table_attach(GTK_TABLE(m_widget), hscrollbar, 0, 1, 1, 2,
- GTK_EXPAND | GTK_FILL,
+ (GtkAttachOptions)(GTK_EXPAND | GTK_FILL),
GTK_FILL,
0, 0);
gtk_widget_show(hscrollbar);
GtkWidget *vscrollbar = gtk_vscrollbar_new(GTK_TEXT(m_text)->vadj);
gtk_table_attach(GTK_TABLE(m_widget), vscrollbar, 1, 2, 0, 1,
GTK_FILL,
- GTK_EXPAND | GTK_FILL | GTK_SHRINK,
+ (GtkAttachOptions)(GTK_EXPAND | GTK_FILL | GTK_SHRINK),
0, 0);
gtk_widget_show( vscrollbar );
}
if (newSize.y == -1) newSize.y = 26;
SetSize( newSize.x, newSize.y );
+ m_parent->AddChild( this );
+
+ (m_parent->m_insertCallback)( m_parent, this );
+
PostCreation();
- if (bMultiLine)
+ if (multi_line)
{
gtk_widget_realize(m_text);
gtk_widget_show(m_text);
{
gint tmp = 0;
gtk_editable_insert_text( GTK_EDITABLE(m_text), value, value.Length(), &tmp );
+ SetInsertionPointEnd();
}
- if (style & wxTE_READONLY)
+ if (style & wxTE_PASSWORD)
{
+ if (!multi_line)
+ gtk_entry_set_visibility( GTK_ENTRY(m_text), FALSE );
+ }
+
+ if (style & wxTE_READONLY)
+ {
+ if (!multi_line)
+ gtk_entry_set_editable( GTK_ENTRY(m_text), FALSE );
}
else
{
- if (bMultiLine)
+ if (multi_line)
gtk_text_set_editable( GTK_TEXT(m_text), 1 );
}
wxFAIL_MSG( "wxTextCtrl::OnDropFiles not implemented" );
}
-long wxTextCtrl::PositionToXY( long WXUNUSED(pos), long *WXUNUSED(x), long *WXUNUSED(y) ) const
+long wxTextCtrl::PositionToXY(long pos, long *x, long *y ) const
{
- wxFAIL_MSG( "wxTextCtrl::XYToPosition not implemented" );
+ if (!(m_windowStyle & wxTE_MULTILINE))
+ return 0;
+ gint len = gtk_text_get_length( GTK_TEXT(m_text) );
+ char *text = gtk_editable_get_chars( GTK_EDITABLE(m_text), 0, len );
+ if(!text)
+ return 0;
+ if( pos >= len)
+ return pos=len-1;
- return 0;
+ *x=1; // Col 1
+ *y=1; // Line 1
+ for (int i = 0; i < pos; i++ )
+ {
+ if (text[i] == '\n')
+ {
+ (*y)++;
+ *x=1;
+ }
+ else
+ (*x)++;
+ }
+ g_free( text );
+ return 1;
}
-long wxTextCtrl::XYToPosition( long WXUNUSED(x), long WXUNUSED(y) ) const
+long wxTextCtrl::XYToPosition(long x, long y ) const
{
- wxFAIL_MSG( "wxTextCtrl::XYToPosition not implemented" );
+ if (!(m_windowStyle & wxTE_MULTILINE))
+ return 0;
+ long pos=0;
- return 0;
+ for(int i=1;i<y;i++)
+ pos +=GetLineLength(i);
+ pos +=x-1; // Pos start with 0
+ return pos;
}
int wxTextCtrl::GetLineLength(long lineNo) const
pos = gtk_text_get_length( GTK_TEXT(m_text) );
else
pos = GTK_ENTRY(m_text)->text_length;
- SetInsertionPoint( pos-1 );
+ SetInsertionPoint((pos-1)>0 ? (pos-1):0);
}
void wxTextCtrl::SetEditable( bool editable )