X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=gio%2Fglocalfileoutputstream.c;h=b8fd45c3564da31dbc5fee63d97b381bcdcf3168;hb=13e15733f38a40c6ef6a1baede91cce81c86ebaa;hp=ccee49d7972064c6bdb87fcbbee190e522c3fdf3;hpb=9f1a0b57cdca9eb2f9d8a8ecd414369df739fb8d;p=platform%2Fupstream%2Fglib.git diff --git a/gio/glocalfileoutputstream.c b/gio/glocalfileoutputstream.c index ccee49d..b8fd45c 100644 --- a/gio/glocalfileoutputstream.c +++ b/gio/glocalfileoutputstream.c @@ -13,9 +13,7 @@ * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General - * Public License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place, Suite 330, - * Boston, MA 02111-1307, USA. + * Public License along with this library; if not, see . * * Author: Alexander Larsson */ @@ -25,9 +23,6 @@ #include #include #include -#ifdef HAVE_UNISTD_H -#include -#endif #include #include @@ -41,6 +36,7 @@ #include "glocalfileinfo.h" #ifdef G_OS_UNIX +#include #include "gfiledescriptorbased.h" #endif @@ -58,6 +54,15 @@ #define O_BINARY 0 #endif +struct _GLocalFileOutputStreamPrivate { + char *tmp_filename; + char *original_filename; + char *backup_filename; + char *etag; + guint sync_on_close : 1; + guint do_close : 1; + int fd; +}; #ifdef G_OS_UNIX static void g_file_descriptor_based_iface_init (GFileDescriptorBasedIface *iface); @@ -66,11 +71,12 @@ static void g_file_descriptor_based_iface_init (GFileDescriptorBasedIfac #define g_local_file_output_stream_get_type _g_local_file_output_stream_get_type #ifdef G_OS_UNIX G_DEFINE_TYPE_WITH_CODE (GLocalFileOutputStream, g_local_file_output_stream, G_TYPE_FILE_OUTPUT_STREAM, + G_ADD_PRIVATE (GLocalFileOutputStream) G_IMPLEMENT_INTERFACE (G_TYPE_FILE_DESCRIPTOR_BASED, - g_file_descriptor_based_iface_init) - ); + g_file_descriptor_based_iface_init)) #else -G_DEFINE_TYPE_WITH_CODE (GLocalFileOutputStream, g_local_file_output_stream, G_TYPE_FILE_OUTPUT_STREAM,); +G_DEFINE_TYPE_WITH_CODE (GLocalFileOutputStream, g_local_file_output_stream, G_TYPE_FILE_OUTPUT_STREAM, + G_ADD_PRIVATE (GLocalFileOutputStream)) #endif @@ -80,16 +86,6 @@ G_DEFINE_TYPE_WITH_CODE (GLocalFileOutputStream, g_local_file_output_stream, G_T #define BACKUP_EXTENSION "~" -struct _GLocalFileOutputStreamPrivate { - char *tmp_filename; - char *original_filename; - char *backup_filename; - char *etag; - guint sync_on_close : 1; - guint do_close : 1; - int fd; -}; - static gssize g_local_file_output_stream_write (GOutputStream *stream, const void *buffer, gsize count, @@ -134,16 +130,13 @@ g_local_file_output_stream_finalize (GObject *object) G_OBJECT_CLASS (g_local_file_output_stream_parent_class)->finalize (object); } - static void g_local_file_output_stream_class_init (GLocalFileOutputStreamClass *klass) { GObjectClass *gobject_class = G_OBJECT_CLASS (klass); GOutputStreamClass *stream_class = G_OUTPUT_STREAM_CLASS (klass); GFileOutputStreamClass *file_stream_class = G_FILE_OUTPUT_STREAM_CLASS (klass); - - g_type_class_add_private (klass, sizeof (GLocalFileOutputStreamPrivate)); - + gobject_class->finalize = g_local_file_output_stream_finalize; stream_class->write_fn = g_local_file_output_stream_write; @@ -168,9 +161,7 @@ g_file_descriptor_based_iface_init (GFileDescriptorBasedIface *iface) static void g_local_file_output_stream_init (GLocalFileOutputStream *stream) { - stream->priv = G_TYPE_INSTANCE_GET_PRIVATE (stream, - G_TYPE_LOCAL_FILE_OUTPUT_STREAM, - GLocalFileOutputStreamPrivate); + stream->priv = g_local_file_output_stream_get_instance_private (stream); stream->priv->do_close = TRUE; } @@ -270,7 +261,7 @@ _g_local_file_output_stream_really_close (GLocalFileOutputStream *file, if (g_cancellable_set_error_if_cancelled (cancellable, error)) goto err_out; -#ifdef HAVE_LINK +#ifdef G_OS_UNIX /* create original -> backup link, the original is then renamed over */ if (g_unlink (file->priv->backup_filename) != 0 && errno != ENOENT)