2003-03-07 20:01:41 +01:00
|
|
|
/*
|
2008-08-13 09:30:23 +02:00
|
|
|
* fontconfig/doc/fcatomic.fncs
|
2003-03-07 20:01:41 +01:00
|
|
|
*
|
2004-12-07 02:14:46 +01:00
|
|
|
* Copyright © 2003 Keith Packard
|
2003-03-07 20:01:41 +01:00
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, distribute, and sell this software and its
|
|
|
|
* documentation for any purpose is hereby granted without fee, provided that
|
|
|
|
* the above copyright notice appear in all copies and that both that
|
|
|
|
* copyright notice and this permission notice appear in supporting
|
2010-11-10 22:45:42 +01:00
|
|
|
* documentation, and that the name of the author(s) not be used in
|
2003-03-07 20:01:41 +01:00
|
|
|
* advertising or publicity pertaining to distribution of the software without
|
2010-11-10 22:45:42 +01:00
|
|
|
* specific, written prior permission. The authors make no
|
2003-03-07 20:01:41 +01:00
|
|
|
* representations about the suitability of this software for any purpose. It
|
|
|
|
* is provided "as is" without express or implied warranty.
|
|
|
|
*
|
2009-03-12 21:00:08 +01:00
|
|
|
* THE AUTHOR(S) DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
2003-03-07 20:01:41 +01:00
|
|
|
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
2009-03-12 21:00:08 +01:00
|
|
|
* EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
2003-03-07 20:01:41 +01:00
|
|
|
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
|
|
|
|
* DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
|
|
|
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
|
|
* PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
@RET@ FcAtomic *
|
|
|
|
@FUNC@ FcAtomicCreate
|
|
|
|
@TYPE1@ const FcChar8 * @ARG1@ file
|
|
|
|
@PURPOSE@ create an FcAtomic object
|
|
|
|
@DESC@
|
|
|
|
Creates a data structure containing data needed to control access to <parameter>file</parameter>.
|
|
|
|
Writing is done to a separate file. Once that file is complete, the original
|
|
|
|
configuration file is atomically replaced so that reading process always see
|
|
|
|
a consistent and complete file without the need to lock for reading.
|
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ FcBool
|
|
|
|
@FUNC@ FcAtomicLock
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ lock a file
|
|
|
|
@DESC@
|
2007-11-03 21:05:25 +01:00
|
|
|
Attempts to lock the file referenced by <parameter>atomic</parameter>.
|
|
|
|
Returns FcFalse if the file is already locked, else returns FcTrue and
|
|
|
|
leaves the file locked.
|
2003-03-07 20:01:41 +01:00
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ FcChar8 *
|
|
|
|
@FUNC@ FcAtomicNewFile
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ return new temporary file name
|
|
|
|
@DESC@
|
|
|
|
Returns the filename for writing a new version of the file referenced
|
|
|
|
by <parameter>atomic</parameter>.
|
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ FcChar8 *
|
|
|
|
@FUNC@ FcAtomicOrigFile
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ return original file name
|
|
|
|
@DESC@
|
|
|
|
Returns the file refernced by <parameter>atomic</parameter>.
|
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ FcBool
|
|
|
|
@FUNC@ FcAtomicReplaceOrig
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ replace original with new
|
|
|
|
@DESC@
|
2007-11-13 23:58:39 +01:00
|
|
|
Replaces the original file referenced by <parameter>atomic</parameter> with
|
|
|
|
the new file. Returns FcFalse if the file cannot be replaced due to
|
|
|
|
permission issues in the filesystem. Otherwise returns FcTrue.
|
2003-03-07 20:01:41 +01:00
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ void
|
|
|
|
@FUNC@ FcAtomicDeleteNew
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ delete new file
|
|
|
|
@DESC@
|
|
|
|
Deletes the new file. Used in error recovery to back out changes.
|
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ void
|
|
|
|
@FUNC@ FcAtomicUnlock
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ unlock a file
|
|
|
|
@DESC@
|
|
|
|
Unlocks the file.
|
|
|
|
@@
|
|
|
|
|
|
|
|
@RET@ void
|
|
|
|
@FUNC@ FcAtomicDestroy
|
|
|
|
@TYPE1@ FcAtomic * @ARG1@ atomic
|
|
|
|
@PURPOSE@ destroy an FcAtomic object
|
|
|
|
@DESC@
|
|
|
|
Destroys <parameter>atomic</parameter>.
|
|
|
|
@@
|