kdecore Library API Documentation

KSaveFile Class Reference

The KSaveFile class has been made to write out changes to an existing file atomically. More...

#include <ksavefile.h>

Collaboration diagram for KSaveFile:

Collaboration graph
[legend]
List of all members.

Public Member Functions

 KSaveFile (const QString &filename, int mode=0666)
 Creates a new KSaveFile with the given file name.

 ~KSaveFile ()
 The destructor closes the file.

int status () const
 Returns the status of the file based on errno.

QString name () const
 The name of the file as passed to the constructor.

int handle () const
 An integer file descriptor open for writing to the file.

FILE * fstream ()
 A FILE* stream open for writing to the file.

QFilefile ()
 A QFile* open for writing to the file.

QTextStreamtextStream ()
 A QTextStream* open for writing to the file.

QDataStreamdataStream ()
 A QDataStream* open for writing to the file.

void abort ()
 Aborts the write operation and removes any intermediate files This implies a close.

bool close ()
 Closes the file and makes the changes definitive.


Detailed Description

The KSaveFile class has been made to write out changes to an existing file atomically.

This means that EITHER: a) All changes have been written successfully to the file.

b) Some error occured, no changes have been written whatsoever and the old file is still in place.

Definition at line 41 of file ksavefile.h.


Constructor & Destructor Documentation

KSaveFile::KSaveFile const QString filename,
int  mode = 0666
 

Creates a new KSaveFile with the given file name.

Parameters:
filename the path of the file
mode the mode of the file (see chmod(1))

Definition at line 41 of file ksavefile.cpp.

References KTempFile::create(), QString::fromLatin1(), and KTempFile::setError().

KSaveFile::~KSaveFile  ) 
 

The destructor closes the file.

Definition at line 60 of file ksavefile.cpp.

References close().


Member Function Documentation

int KSaveFile::status  )  const [inline]
 

Returns the status of the file based on errno.

(see errno.h) 0 means OK.

You should check the status after object creation to check whether a file could be created in the first place.

You may check the status after closing the file to verify that the file has indeed been written correctly.

Returns:
the errno status, 0 means ok

Definition at line 67 of file ksavefile.h.

References KTempFile::status().

Referenced by KPalette::save(), and KConfigINIBackEnd::writeConfigFile().

QString KSaveFile::name  )  const
 

The name of the file as passed to the constructor.

Returns:
The name of the file, or QString::null if opening the file has failed

Definition at line 66 of file ksavefile.cpp.

int KSaveFile::handle  )  const [inline]
 

An integer file descriptor open for writing to the file.

Returns:
The file descriptor, or a negative number if opening the temporary file failed

Definition at line 82 of file ksavefile.h.

References KTempFile::handle().

Referenced by KConfigINIBackEnd::writeConfigFile().

FILE* KSaveFile::fstream  )  [inline]
 

A FILE* stream open for writing to the file.

Returns:
FILE* stream open for writing to the file, or 0 if opening the temporary file failed

Definition at line 90 of file ksavefile.h.

References KTempFile::fstream().

Referenced by KConfigINIBackEnd::writeConfigFile().

QFile* KSaveFile::file  )  [inline]
 

A QFile* open for writing to the file.

Returns:
A QFile open for writing to the file, or 0 if opening the temporary file failed.

Definition at line 98 of file ksavefile.h.

References KTempFile::file().

QTextStream* KSaveFile::textStream  )  [inline]
 

A QTextStream* open for writing to the file.

Returns:
A QTextStream that is open for writing to the file, or 0 if opening the temporary file failed

Definition at line 106 of file ksavefile.h.

References KTempFile::textStream().

Referenced by KPalette::save().

QDataStream* KSaveFile::dataStream  )  [inline]
 

A QDataStream* open for writing to the file.

Returns:
A QDataStream that is open for writing to the file, or 0 if opening the file failed

Definition at line 114 of file ksavefile.h.

References KTempFile::dataStream().

void KSaveFile::abort  ) 
 

Aborts the write operation and removes any intermediate files This implies a close.

Definition at line 72 of file ksavefile.cpp.

References KTempFile::close(), and KTempFile::unlink().

bool KSaveFile::close  ) 
 

Closes the file and makes the changes definitive.

Returns 'true' is successful, or 'false' if an error has occured. See status() for details about errors.

Returns:
true if successful, or false if an error has occured.

Definition at line 79 of file ksavefile.cpp.

References KTempFile::close(), QString::isEmpty(), KTempFile::name(), QDir::rename(), KTempFile::setError(), and KTempFile::unlink().

Referenced by KPalette::save(), KConfigINIBackEnd::writeConfigFile(), and ~KSaveFile().


The documentation for this class was generated from the following files:
KDE Logo
This file is part of the documentation for kdelibs Version 3.1.5.
Documentation copyright © 1996-2002 the KDE developers.
Generated on Wed Jan 28 12:51:01 2004 by doxygen 1.3.4 written by Dimitri van Heesch, © 1997-2001