summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2015-04-15 22:17:02 -0400
committerPietro Gagliardi <[email protected]>2015-04-15 22:17:02 -0400
commit922360f1120daa1581c8db9feb365929bce416eb (patch)
tree49c15b2c0a3cb3c11161e1ee4becc2826ad3b9c8
parentf6ef5212331229cfa17bb05a61d4ca566273ddff (diff)
Converted unix/entry.c and unix/label.c.
-rw-r--r--new/unix/entry.c36
-rw-r--r--new/unix/label.c38
2 files changed, 41 insertions, 33 deletions
diff --git a/new/unix/entry.c b/new/unix/entry.c
index 43caea3..a18b508 100644
--- a/new/unix/entry.c
+++ b/new/unix/entry.c
@@ -2,6 +2,7 @@
#include "uipriv_unix.h"
struct entry {
+ uiEntry e;
};
static void onDestroy(GtkWidget *widget, gpointer data)
@@ -11,31 +12,34 @@ static void onDestroy(GtkWidget *widget, gpointer data)
uiFree(e);
}
+#define ENTRY(e) GTK_ENTRY(uiControlHandle(uiControl(e)))
+
+static char *getText(uiEntry *e)
+{
+ return g_strdup(gtk_entry_get_text(ENTRY(e)));
+}
+
+static void uiEntrySetText(uiEntry *e, const char *text)
+{
+ gtk_entry_set_text(ENTRY(e), text);
+}
+
uiControl *uiNewEntry(void)
{
- uiControl *c;
struct entry *e;
GtkWidget *widget;
- c = uiUnixNewControl(GTK_TYPE_ENTRY,
+ e = uiNew(struct entry);
+
+ uiUnixNewControl(uiControl(e), GTK_TYPE_ENTRY,
FALSE, FALSE,
NULL);
- widget = GTK_WIDGET(uiControlHandle(c));
-
- e = uiNew(struct entry);
+ widget = GTK_WIDGET(ENTRY(e));
g_signal_connect(widget, "destroy", G_CALLBACK(onDestroy), e);
- c->data = e;
-
- return c;
-}
-char *uiEntryText(uiControl *c)
-{
- return g_strdup(gtk_entry_get_text(GTK_ENTRY(uiControlHandle(c))));
-}
+ uiEntry(e)->Text = getText;
+ uiEntry(e)->SetText = setText;
-void uiEntrySetText(uiControl *c, const char *text)
-{
- gtk_entry_set_text(GTK_ENTRY(uiControlHandle(c)), text);
+ return uiEntry(e);
}
diff --git a/new/unix/label.c b/new/unix/label.c
index 1f950d3..caf7d55 100644
--- a/new/unix/label.c
+++ b/new/unix/label.c
@@ -2,6 +2,7 @@
#include "uipriv_unix.h"
struct label {
+ uiLabel l;
};
static void onDestroy(GtkWidget *widget, gpointer data)
@@ -11,35 +12,38 @@ static void onDestroy(GtkWidget *widget, gpointer data)
uiFree(l);
}
+#define LABEL(l) GTK_LABEL(uiControlHandle(uiControl(l)))
+
+static char *getText(uiLabel *l)
+{
+ // TODO change g_strdup() to a wrapper function for export in ui_unix.h
+ return g_strdup(gtk_label_get_text(LABEL(l)));
+}
+
+static void setText(uiLabel *l, const char *text)
+{
+ gtk_label_set_text(LABEL(l), text);
+}
+
uiControl *uiNewLabel(const char *text)
{
- uiControl *c;
struct label *l;
GtkWidget *widget;
- c = uiUnixNewControl(GTK_TYPE_LABEL,
+ l = uiNew(struct label);
+
+ uiUnixNewControl(uiControl(l), GTK_TYPE_LABEL,
FALSE, FALSE,
"label", text,
"xalign", 0.0, // note: must be a float constant, otherwise the ... will turn it into an int and we get segfaults on some platforms (thanks ebassi in irc.gimp.net/#gtk+)
// TODO yalign 0?
NULL);
- widget = GTK_WIDGET(uiControlHandle(c));
-
- l = uiNew(struct label);
+ widget = GTK_WIDGET(LABEL(l));
g_signal_connect(widget, "destroy", G_CALLBACK(onDestroy), l);
- c->data = l;
- return c;
-}
+ uiLabel(l)->Text = getText;
+ uiLabel(l)->SetText = setText;
-char *uiLabelText(uiControl *c)
-{
- // TODO change g_strdup() to a wrapper function for export in ui_unix.h
- return g_strdup(gtk_label_get_text(GTK_LABEL(uiControlHandle(c))));
-}
-
-void uiLabelSetText(uiControl *c, const char *text)
-{
- gtk_label_set_text(GTK_LABEL(uiControlHandle(c)), text);
+ return uiLabel(l);
}