glocalfile: fix error code when opening a directory on win32

g_file_read() was returning G_IO_ERROR_IS_DIRECTORY when you tried to
open a directory on unix, but G_IO_ERROR_PERMISSION_DENIED on win32.
Fix that, and add a test to tests/file.c

Pointed out on IRC by Paweł Forysiuk.

https://bugzilla.gnome.org/show_bug.cgi?id=669330
This commit is contained in:
Dan Winship 2012-02-03 11:45:51 -05:00
parent a067df5d72
commit ca5ed93fde
2 changed files with 19 additions and 0 deletions

View File

@ -1314,6 +1314,20 @@ g_local_file_read (GFile *file,
{ {
int errsv = errno; int errsv = errno;
#ifdef G_OS_WIN32
if (errsv == EACCES)
{
ret = _stati64 (local->filename, &buf);
if (ret == 0 && S_ISDIR (buf.st_mode))
{
g_set_error_literal (error, G_IO_ERROR,
G_IO_ERROR_IS_DIRECTORY,
_("Can't open directory"));
return NULL;
}
}
#endif
g_set_error (error, G_IO_ERROR, g_set_error (error, G_IO_ERROR,
g_io_error_from_errno (errsv), g_io_error_from_errno (errsv),
_("Error opening file: %s"), _("Error opening file: %s"),

View File

@ -78,6 +78,7 @@ test_type (void)
{ {
GFile *file; GFile *file;
GFileType type; GFileType type;
GError *error = NULL;
file = g_file_new_for_path (SRCDIR "/file.c"); file = g_file_new_for_path (SRCDIR "/file.c");
type = g_file_query_file_type (file, 0, NULL); type = g_file_query_file_type (file, 0, NULL);
@ -87,6 +88,10 @@ test_type (void)
file = g_file_new_for_path (SRCDIR "/schema-tests"); file = g_file_new_for_path (SRCDIR "/schema-tests");
type = g_file_query_file_type (file, 0, NULL); type = g_file_query_file_type (file, 0, NULL);
g_assert_cmpint (type, ==, G_FILE_TYPE_DIRECTORY); g_assert_cmpint (type, ==, G_FILE_TYPE_DIRECTORY);
g_file_read (file, NULL, &error);
g_assert_error (error, G_IO_ERROR, G_IO_ERROR_IS_DIRECTORY);
g_error_free (error);
g_object_unref (file); g_object_unref (file);
} }