summaryrefslogtreecommitdiff
path: root/gtk
diff options
context:
space:
mode:
authorManish Singh <yosh@src.gnome.org>1998-01-03 08:35:21 +0000
committerManish Singh <yosh@src.gnome.org>1998-01-03 08:35:21 +0000
commit25995faa6cf0291ac801cb3ebdc47cd8a3fe4881 (patch)
treeb10964b6bbcaa19eb6733516fada15f758558435 /gtk
parent621e1dd4c23c9d6ab2d46e595a00c6cd6af34749 (diff)
downloadgtk+-25995faa6cf0291ac801cb3ebdc47cd8a3fe4881.tar.gz
Added Gordon Matzigkeit's patch for fixed length gtk entry fields
-Yosh
Diffstat (limited to 'gtk')
-rw-r--r--gtk/gtkentry.c19
-rw-r--r--gtk/gtkentry.h2
2 files changed, 21 insertions, 0 deletions
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c
index 42ffc7194d..1e9684b39b 100644
--- a/gtk/gtkentry.c
+++ b/gtk/gtkentry.c
@@ -320,6 +320,7 @@ gtk_entry_init (GtkEntry *entry)
entry->text = NULL;
entry->text_size = 0;
entry->text_length = 0;
+ entry->text_max_length = 0;
entry->current_pos = 0;
entry->selection_start_pos = 0;
entry->selection_end_pos = 0;
@@ -374,6 +375,15 @@ gtk_entry_new ()
return GTK_WIDGET (gtk_type_new (gtk_entry_get_type ()));
}
+GtkWidget*
+gtk_entry_new_with_max_length (guint16 max)
+{
+ GtkEntry *entry;
+ entry = gtk_type_new (gtk_entry_get_type ());
+ entry->text_max_length = max;
+ return GTK_WIDGET (entry);
+}
+
void
gtk_entry_set_text (GtkEntry *entry,
const gchar *text)
@@ -1651,6 +1661,15 @@ gtk_real_entry_insert_text (GtkEntry *entry,
g_return_if_fail (entry != NULL);
g_return_if_fail (GTK_IS_ENTRY (entry));
+ /* Make sure we do not exceed the maximum size of the entry. */
+ if (entry->text_max_length != 0 &&
+ new_text_length + entry->text_length > entry->text_max_length)
+ new_text_length = entry->text_max_length - entry->text_length;
+
+ /* Don't insert anything, if there was nothing to insert. */
+ if (new_text_length == 0)
+ return;
+
start_pos = *position;
end_pos = start_pos + new_text_length;
last_pos = new_text_length + entry->text_length;
diff --git a/gtk/gtkentry.h b/gtk/gtkentry.h
index c4395fba35..a1f6c77d45 100644
--- a/gtk/gtkentry.h
+++ b/gtk/gtkentry.h
@@ -45,6 +45,7 @@ struct _GtkEntry
guint16 text_size;
guint16 text_length;
+ guint16 text_max_length;
gint16 current_pos;
gint16 selection_start_pos;
gint16 selection_end_pos;
@@ -76,6 +77,7 @@ struct _GtkEntryClass
guint gtk_entry_get_type (void);
GtkWidget* gtk_entry_new (void);
+GtkWidget* gtk_entry_new_with_max_length (guint16 max);
void gtk_entry_set_text (GtkEntry *entry,
const gchar *text);
void gtk_entry_append_text (GtkEntry *entry,