summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Howard2013-09-08 18:57:20 +0000
committerSimon Howard2013-09-08 18:57:20 +0000
commite10af52152ba793d983497cd86d7ccc10d32a13d (patch)
tree966ea411ab7408a9ab3015d3a6a974ba782bbceb
parent50289818e9d59848c363aa3922133fee9c119c22 (diff)
downloadchocolate-doom-e10af52152ba793d983497cd86d7ccc10d32a13d.tar.gz
chocolate-doom-e10af52152ba793d983497cd86d7ccc10d32a13d.tar.bz2
chocolate-doom-e10af52152ba793d983497cd86d7ccc10d32a13d.zip
Fix file select widget to emit "changed" signal properly. Reset variable
value to empty string rather than NULL if cancel is pressed in dialog (thanks Alexandre Xavier). Subversion-branch: /trunk/chocolate-doom Subversion-revision: 2638
-rw-r--r--textscreen/txt_fileselect.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/textscreen/txt_fileselect.c b/textscreen/txt_fileselect.c
index 6e492734..52b0dc1c 100644
--- a/textscreen/txt_fileselect.c
+++ b/textscreen/txt_fileselect.c
@@ -591,6 +591,16 @@ static int DoSelectFile(txt_fileselect_t *fileselect)
{
path = TXT_SelectFile(fileselect->prompt,
fileselect->extensions);
+
+ // Update inputbox variable.
+ // If cancel was pressed (ie. NULL was returned by TXT_SelectFile)
+ // then reset to empty string, not NULL).
+
+ if (path == NULL)
+ {
+ path = strdup("");
+ }
+
var = fileselect->inputbox->value;
free(*var);
*var = path;
@@ -658,6 +668,16 @@ txt_widget_class_t txt_fileselect_class =
TXT_FileSelectFocused,
};
+// If the (inner) inputbox widget is changed, emit a change to the
+// outer (fileselect) widget.
+
+static void InputBoxChanged(TXT_UNCAST_ARG(widget), TXT_UNCAST_ARG(fileselect))
+{
+ TXT_CAST_ARG(txt_fileselect_t, fileselect);
+
+ TXT_EmitSignal(&fileselect->widget, "changed");
+}
+
txt_fileselect_t *TXT_NewFileSelector(char **variable, int size,
char *prompt, char **extensions)
{
@@ -671,6 +691,9 @@ txt_fileselect_t *TXT_NewFileSelector(char **variable, int size,
fileselect->prompt = prompt;
fileselect->extensions = extensions;
+ TXT_SignalConnect(fileselect->inputbox, "changed",
+ InputBoxChanged, fileselect);
+
return fileselect;
}