aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--embed/mozilla/FilePicker.cpp55
-rw-r--r--embed/mozilla/FilePicker.h2
3 files changed, 32 insertions, 31 deletions
diff --git a/ChangeLog b/ChangeLog
index 5ec33fe75..96e5c5028 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -2,6 +2,12 @@
* embed/mozilla/FilePicker.cpp:
+ Fix setting default filename in the !modeSave case.
+
+2004-06-07 Christian Persch <chpe@cvs.gnome.org>
+
+ * embed/mozilla/FilePicker.cpp:
+
Don't allow ::SetDefaultString unless we're in modeSave.
2004-06-07 Ross Burton <ross@burtonini.com>
diff --git a/embed/mozilla/FilePicker.cpp b/embed/mozilla/FilePicker.cpp
index 816eadee5..c129a29d3 100644
--- a/embed/mozilla/FilePicker.cpp
+++ b/embed/mozilla/FilePicker.cpp
@@ -1,6 +1,6 @@
/*
* Copyright (C) 2001 Philip Langdale
- * Copyright (C) 2003 Christian Persch
+ * Copyright (C) 2003, 2004 Christian Persch
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -241,25 +241,11 @@ NS_IMETHODIMP GFilePicker::GetDefaultString(PRUnichar **aDefaultString)
LOG ("GFilePicker::GetDefaultString")
- char *filename, *converted;
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (mDialog));
- if (filename != NULL)
- {
- converted = g_filename_to_utf8(filename, -1, NULL, NULL, NULL);
-
- nsEmbedString defaultString;
#if MOZILLA_CHECK_VERSION4 (1, 8, MOZILLA_ALPHA, 1)
- NS_CStringToUTF16 (nsEmbedCString(converted),
- NS_CSTRING_ENCODING_UTF8, aDefaultString);
+ aDefaultString = mDefaultString;
#else
- NS_CStringToUTF16 (nsEmbedCString(converted),
- NS_CSTRING_ENCODING_UTF8, defaultString);
- *aDefaultString = NS_StringCloneData (defaultString);
+ *aDefaultString = NS_StringCloneData (mDefaultString);
#endif
-
- g_free (filename);
- g_free (converted);
- }
return NS_OK;
}
@@ -272,25 +258,18 @@ NS_IMETHODIMP GFilePicker::SetDefaultString(const PRUnichar *aDefaultString)
{
NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
- if (mMode != nsIFilePicker::modeSave) return NS_ERROR_FAILURE;
+ mDefaultString.Assign (aDefaultString);
-#if MOZILLA_CHECK_VERSION4 (1, 8, MOZILLA_ALPHA, 1)
- if (aDefaultString.Length())
-#else
- if (aDefaultString)
-#endif
+ if (mMode == nsIFilePicker::modeSave)
{
nsEmbedCString defaultString;
-#if MOZILLA_CHECK_VERSION4 (1, 8, MOZILLA_ALPHA, 1)
- NS_UTF16ToCString (aDefaultString, NS_CSTRING_ENCODING_UTF8,
+ NS_UTF16ToCString (mDefaultString, NS_CSTRING_ENCODING_UTF8,
defaultString);
-#else
- NS_UTF16ToCString (nsEmbedString(aDefaultString),
- NS_CSTRING_ENCODING_UTF8, defaultString);
-#endif
LOG ("GFilePicker::SetDefaultString %s", defaultString.get())
+ if (!defaultString.Length()) return NS_ERROR_FAILURE;
+
/* set_current_name takes UTF-8, not a filename */
gtk_file_chooser_set_current_name
(GTK_FILE_CHOOSER (mDialog), defaultString.get());
@@ -367,8 +346,22 @@ NS_IMETHODIMP GFilePicker::SetDisplayDirectory(nsILocalFile *aDisplayDirectory)
LOG ("GFilePicker::SetDisplayDirectory to %s", dir.get())
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (mDialog),
- dir.get());
+ if (mDefaultString.Length() && mMode != nsIFilePicker::modeSave)
+ {
+ nsEmbedCString defaultString;
+ NS_UTF16ToCString (mDefaultString, NS_CSTRING_ENCODING_NATIVE_FILESYSTEM,
+ defaultString);
+
+ char *filename = g_build_filename (dir.get(), defaultString.get(), NULL);
+ LOG ("Setting filename to %s", filename);
+ gtk_file_chooser_set_filename (GTK_FILE_CHOOSER (mDialog), filename);
+ g_free (filename);
+ }
+ else
+ {
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (mDialog),
+ dir.get());
+ }
return NS_OK;
}
diff --git a/embed/mozilla/FilePicker.h b/embed/mozilla/FilePicker.h
index cf6a7f68f..a0578a860 100644
--- a/embed/mozilla/FilePicker.h
+++ b/embed/mozilla/FilePicker.h
@@ -24,6 +24,7 @@
#include <nsIFilePicker.h>
#include <nsISupports.h>
+#include <nsEmbedString.h>
#include "ephy-file-chooser.h"
@@ -54,6 +55,7 @@ public:
private:
EphyFileChooser *mDialog;
PRInt16 mMode;
+ nsEmbedString mDefaultString;
};
#endif