Reimplemented GTK+ uiEntry.

This commit is contained in:
Pietro Gagliardi 2015-06-30 11:26:54 -04:00
parent 8361b4d41a
commit a79368e26b
2 changed files with 20 additions and 96 deletions

View File

@ -8,10 +8,18 @@ struct entry {
GtkEditable *editable; GtkEditable *editable;
void (*onChanged)(uiEntry *, void *); void (*onChanged)(uiEntry *, void *);
void *onChangedData; void *onChangedData;
gulong onChangedSignal;
}; };
uiDefineControlType(uiEntry, uiTypeEntry, struct entry) uiDefineControlType(uiEntry, uiTypeEntry, struct entry)
static void onChanged(GtkEditable *editable, gpointer data)
{
struct entry *e = (struct entry *) data;
(*(e->onChanged))(uiEntry(e), e->onChangedData);
}
static uintptr_t entryHandle(uiControl *c) static uintptr_t entryHandle(uiControl *c)
{ {
struct entry *e = (struct entry *) c; struct entry *e = (struct entry *) c;
@ -28,14 +36,17 @@ static char *entryText(uiEntry *ee)
{ {
struct entry *e = (struct entry *) ee; struct entry *e = (struct entry *) ee;
return PUT_CODE_HERE; return uiUnixStrdupText(gtk_entry_get_text(e->entry));
} }
static void entrySetText(uiEntry *ee, const char *text) static void entrySetText(uiEntry *ee, const char *text)
{ {
struct entry *e = (struct entry *) ee; struct entry *e = (struct entry *) ee;
PUT_CODE_HERE; // we need to inhibit sending of ::changed because this WILL send a ::changed otherwise
g_signal_handler_block(e->editable, e->onChangedSignal);
gtk_entry_set_text(e->entry, text);
g_signal_handler_unblock(e->editable, e->onChangedSignal);
// don't queue the control for resize; entry sizes are independent of their contents // don't queue the control for resize; entry sizes are independent of their contents
} }
@ -51,14 +62,18 @@ static int entryReadOnly(uiEntry *ee)
{ {
struct entry *e = (struct entry *) ee; struct entry *e = (struct entry *) ee;
return PUT_CODE_HERE; return gtk_editable_get_editable(e->editable) == FALSE;
} }
static void entrySetReadOnly(uiEntry *ee, int readonly) static void entrySetReadOnly(uiEntry *ee, int readonly)
{ {
struct entry *e = (struct entry *) ee; struct entry *e = (struct entry *) ee;
gboolean editable;
PUT_CODE_HERE; editable = TRUE;
if (readonly)
editable = FALSE;
gtk_editable_set_editable(e->editable, editable);
} }
uiEntry *uiNewEntry(void) uiEntry *uiNewEntry(void)
@ -72,6 +87,7 @@ uiEntry *uiNewEntry(void)
e->editable = GTK_EDITABLE(e->widget); e->editable = GTK_EDITABLE(e->widget);
uiUnixMakeSingleWidgetControl(uiControl(e), e->widget); uiUnixMakeSingleWidgetControl(uiControl(e), e->widget);
e->onChangedSignal = g_signal_connect(e->widget, "changed", G_CALLBACK(onChanged), e);
e->onChanged = defaultOnChanged; e->onChanged = defaultOnChanged;
uiControl(e)->Handle = entryHandle; uiControl(e)->Handle = entryHandle;

View File

@ -1,92 +0,0 @@
// 8 april 2015
#include "uipriv_unix.h"
struct entry {
uiEntry e;
GtkWidget *widget;
GtkEntry *entry;
GtkEditable *editable;
void (*onChanged)(uiEntry *, void *);
void *onChangedData;
gulong onChangedSignal;
};
static void onChanged(GtkEditable *editable, gpointer data)
{
struct entry *e = (struct entry *) data;
(*(e->onChanged))(uiEntry(e), e->onChangedData);
}
static void defaultOnChanged(uiEntry *e, void *data)
{
// do nothing
}
static void onDestroy(void *data)
{
struct entry *e = (struct entry *) data;
uiFree(e);
}
static char *entryText(uiEntry *ee)
{
struct entry *e = (struct entry *) ee;
return uiUnixStrdupText(gtk_entry_get_text(e->entry));
}
static void entrySetText(uiEntry *ee, const char *text)
{
struct entry *e = (struct entry *) ee;
// we need to inhibit sending of ::changed because this WILL send a ::changed otherwise
g_signal_handler_block(e->editable, e->onChangedSignal);
gtk_entry_set_text(e->entry, text);
g_signal_handler_unblock(e->editable, e->onChangedSignal);
}
static void entryOnChanged(uiEntry *ee, void (*f)(uiEntry *, void *), void *data)
{
struct entry *e = (struct entry *) ee;
e->onChanged = f;
e->onChangedData = data;
}
static int entryReadOnly(uiEntry *ee)
{
struct entry *e = (struct entry *) ee;
return gtk_editable_get_editable(e->editable) == FALSE;
}
static void entrySetReadOnly(uiEntry *ee, int readonly)
{
struct entry *e = (struct entry *) ee;
gboolean editable;
editable = TRUE;
if (readonly)
editable = FALSE;
gtk_editable_set_editable(e->editable, editable);
}
uiEntry *uiNewEntry(void)
{
struct entry *e;
e = uiNew(struct entry);
e->onChangedSignal = g_signal_connect(e->widget, "changed", G_CALLBACK(onChanged), e);
e->onChanged = defaultOnChanged;
uiEntry(e)->Text = entryText;
uiEntry(e)->SetText = entrySetText;
uiEntry(e)->OnChanged = entryOnChanged;
uiEntry(e)->ReadOnly = entryReadOnly;
uiEntry(e)->SetReadOnly = entrySetReadOnly;
return uiEntry(e);
}