seems to be sort-of working!

This commit is contained in:
John Cupitt 2016-08-16 18:33:48 +01:00
parent eb49347abb
commit feca00958c
5 changed files with 77 additions and 40 deletions

View File

@ -236,7 +236,9 @@ fi
if test x"$vips_os_darwin" = x"yes"; then if test x"$vips_os_darwin" = x"yes"; then
profile_dir="/Library/ColorSync/Profiles" profile_dir="/Library/ColorSync/Profiles"
elif test x"$vips_os_win32" = x"yes"; then elif test x"$vips_os_win32" = x"yes"; then
profile_dir="C:\\Windows\\System32\\spool\\drivers\\color" # need double escapes since this will get pasted into a #define in a C
# header
profile_dir="C:\\\\Windows\\\\System32\\\\spool\\\\drivers\\\\color"
else else
profile_dir="/usr/share/color/icc" profile_dir="/usr/share/color/icc"
fi fi

View File

@ -222,6 +222,9 @@ int vips_filename_suffix_match( const char *path, const char *suffixes[] );
gint64 vips_file_length( int fd ); gint64 vips_file_length( int fd );
int vips__write( int fd, const void *buf, size_t count ); int vips__write( int fd, const void *buf, size_t count );
int vips__open( const char *filename, int flags, ... );
FILE *vips__fopen( const char *filename, const char *mode );
FILE *vips__file_open_read( const char *filename, FILE *vips__file_open_read( const char *filename,
const char *fallback_dir, gboolean text_mode ); const char *fallback_dir, gboolean text_mode );
FILE *vips__file_open_write( const char *filename, FILE *vips__file_open_write( const char *filename,

View File

@ -365,7 +365,7 @@ vips_tracked_open( const char *pathname, int flags, ... )
mode = va_arg( ap, int ); mode = va_arg( ap, int );
va_end( ap ); va_end( ap );
if( (fd = open( pathname, flags, mode )) == -1 ) if( (fd = vips__open( pathname, flags, mode )) == -1 )
return( -1 ); return( -1 );
vips_tracked_init(); vips_tracked_init();

View File

@ -543,6 +543,74 @@ vips__write( int fd, const void *buf, size_t count )
return( 0 ); return( 0 );
} }
/* open() with a utf8 filename.
*/
int
vips__open( const char *filename, int flags, ... )
{
int fd;
mode_t mode;
va_list ap;
va_start( ap, flags );
mode = va_arg( ap, int );
va_end( ap );
#ifdef OS_WIN32
GError *error = NULL;
wchar_t *path16;
if( !(path16 = (wchar_t *)
g_utf8_to_utf16( filename, -1, NULL, NULL, &error )) ) {
vips_g_error( &error );
return( -1 );
}
fd = _wopen( path16, flags, mode );
g_free( path16 );
#else /*!OS_WIN32*/
fd = open( filename, flags, mode );
#endif
return( fd );
}
/* fopen() with utf8 filename and mode.
*/
FILE *
vips__fopen( const char *filename, const char *mode )
{
FILE *fp;
#ifdef OS_WIN32
GError *error = NULL;
wchar_t *path16, *mode16;
if( !(path16 = (wchar_t *)
g_utf8_to_utf16( filename, -1, NULL, NULL, &error )) ) {
vips_g_error( &error );
return( NULL );
}
if( !(mode16 = (wchar_t *)
g_utf8_to_utf16( mode, -1, NULL, NULL, &error )) ) {
g_free( path16 );
vips_g_error( &error );
return( NULL );
}
fp = _wfopen( path16, mode16 );
g_free( path16 );
g_free( mode16 );
#else /*!OS_WIN32*/
fp = fopen( filename, mode );
#endif
return( fp );
}
/* Does a filename contain a directory separator? /* Does a filename contain a directory separator?
*/ */
static gboolean static gboolean
@ -558,41 +626,6 @@ filename_hasdir( const char *filename )
return( hasdir ); return( hasdir );
} }
/* fopen() with utf8 filename and mode.
*/
static FILE *
vips__fopen( const char *filename, const char *mode )
{
FILE *fp;
#ifdef OS_WIN32
GError *error = NULL;
wchar_t *path16, *mode16;
if( !(path16 = (wchar_t *)
g_utf8_to_utf16( filename, -1, NULL, NULL, &error )) ) {
vips_g_error( error );
return( NULL );
}
if( !(mode16 = (wchar_t *)
g_utf8_to_utf16( mode, -1, NULL, NULL, &error )) ) {
g_free( path16 );
vips_g_error( error );
return( NULL );
}
fp = _wfopen( path16, mode16 );
g_free( path16 );
g_free( mode16 );
#else /*!OS_WIN32*/
fp = fopen( filename, mode );
#endif
return( fp );
}
/* Open a file. We take an optional fallback dir as well and will try opening /* Open a file. We take an optional fallback dir as well and will try opening
* there if opening directly fails. * there if opening directly fails.
* *
@ -796,7 +829,7 @@ vips__get_bytes( const char *filename, unsigned char buf[], int len )
* so no hasty messages. And the file might be truncated, so no error * so no hasty messages. And the file might be truncated, so no error
* on read either. * on read either.
*/ */
if( (fd = open( name, MODE_READONLY )) == -1 ) if( (fd = vips__open( name, MODE_READONLY )) == -1 )
return( 0 ); return( 0 );
if( read( fd, buf, len ) != len ) { if( read( fd, buf, len ) != len ) {
close( fd ); close( fd );
@ -1070,7 +1103,7 @@ vips_existsf( const char *name, ... )
path = g_strdup_vprintf( name, ap ); path = g_strdup_vprintf( name, ap );
va_end( ap ); va_end( ap );
result = access( path, R_OK ); result = g_access( path, R_OK );
g_free( path ); g_free( path );

View File

@ -684,7 +684,6 @@ main( int argc, char **argv )
* the args. * the args.
*/ */
#ifdef HAVE_G_WIN32_GET_COMMAND_LINE #ifdef HAVE_G_WIN32_GET_COMMAND_LINE
printf( "using g_win32_get_command_line()\n" );
argv = g_win32_get_command_line(); argv = g_win32_get_command_line();
#endif /*HAVE_G_WIN32_GET_COMMAND_LINE*/ #endif /*HAVE_G_WIN32_GET_COMMAND_LINE*/