2011-09-27 17:18:56 +02:00
|
|
|
/* dotlock.h - dotfile locking declarations
|
|
|
|
* Copyright (C) 2000, 2001, 2006, 2011 Free Software Foundation, Inc.
|
2003-01-09 13:36:05 +01:00
|
|
|
*
|
2015-04-24 16:42:28 +02:00
|
|
|
* This file is part of GnuPG.
|
2003-01-09 13:36:05 +01:00
|
|
|
*
|
2017-02-24 13:48:28 +01:00
|
|
|
* GnuPG is free software; you can redistribute and/or modify this
|
|
|
|
* part of GnuPG under the terms of either
|
2011-09-30 12:52:11 +02:00
|
|
|
*
|
|
|
|
* - the GNU Lesser General Public License as published by the Free
|
|
|
|
* Software Foundation; either version 3 of the License, or (at
|
|
|
|
* your option) any later version.
|
|
|
|
*
|
|
|
|
* or
|
|
|
|
*
|
|
|
|
* - the GNU General Public License as published by the Free
|
|
|
|
* Software Foundation; either version 2 of the License, or (at
|
|
|
|
* your option) any later version.
|
|
|
|
*
|
|
|
|
* or both in parallel, as here.
|
2003-01-09 13:36:05 +01:00
|
|
|
*
|
2015-04-24 16:42:28 +02:00
|
|
|
* GnuPG is distributed in the hope that it will be useful, but
|
2006-10-02 13:54:35 +02:00
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2011-09-30 12:52:11 +02:00
|
|
|
* General Public License for more details.
|
2003-01-09 13:36:05 +01:00
|
|
|
*
|
2011-09-30 12:52:11 +02:00
|
|
|
* You should have received a copies of the GNU General Public License
|
|
|
|
* and the GNU Lesser General Public License along with this program;
|
2016-11-05 12:02:19 +01:00
|
|
|
* if not, see <https://www.gnu.org/licenses/>.
|
2011-10-24 11:38:17 +02:00
|
|
|
*
|
|
|
|
* ALTERNATIVELY, this file may be distributed under the terms of the
|
|
|
|
* following license, in which case the provisions of this license are
|
|
|
|
* required INSTEAD OF the GNU Lesser General License or the GNU
|
|
|
|
* General Public License. If you wish to allow use of your version of
|
|
|
|
* this file only under the terms of the GNU Lesser General License or
|
|
|
|
* the GNU General Public License, and not to allow others to use your
|
|
|
|
* version of this file under the terms of the following license,
|
|
|
|
* indicate your decision by deleting this paragraph and the license
|
|
|
|
* below.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, and the entire permission notice in its entirety,
|
|
|
|
* including the disclaimer of warranties.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote
|
|
|
|
* products derived from this software without specific prior
|
|
|
|
* written permission.
|
|
|
|
*
|
2012-06-05 19:29:22 +02:00
|
|
|
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
|
2011-10-24 11:38:17 +02:00
|
|
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
|
|
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
|
|
|
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
2003-01-09 13:36:05 +01:00
|
|
|
*/
|
|
|
|
|
2015-04-24 16:42:28 +02:00
|
|
|
#ifndef GNUPG_COMMON_DOTLOCK_H
|
|
|
|
#define GNUPG_COMMON_DOTLOCK_H
|
2003-01-09 13:36:05 +01:00
|
|
|
|
2011-09-27 17:18:56 +02:00
|
|
|
/* See dotlock.c for a description. */
|
|
|
|
|
2011-09-30 09:45:21 +02:00
|
|
|
#ifdef DOTLOCK_EXT_SYM_PREFIX
|
|
|
|
# ifndef _DOTLOCK_PREFIX
|
|
|
|
# define _DOTLOCK_PREFIX1(x,y) x ## y
|
|
|
|
# define _DOTLOCK_PREFIX2(x,y) _DOTLOCK_PREFIX1(x,y)
|
|
|
|
# define _DOTLOCK_PREFIX(x) _DOTLOCK_PREFIX2(DOTLOCK_EXT_SYM_PREFIX,x)
|
|
|
|
# endif /*_DOTLOCK_PREFIX*/
|
|
|
|
# define dotlock_disable _DOTLOCK_PREFIX(dotlock_disable)
|
|
|
|
# define dotlock_create _DOTLOCK_PREFIX(dotlock_create)
|
|
|
|
# define dotlock_set_fd _DOTLOCK_PREFIX(dotlock_set_fd)
|
|
|
|
# define dotlock_get_fd _DOTLOCK_PREFIX(dotlock_get_fd)
|
|
|
|
# define dotlock_destroy _DOTLOCK_PREFIX(dotlock_destroy)
|
|
|
|
# define dotlock_take _DOTLOCK_PREFIX(dotlock_take)
|
|
|
|
# define dotlock_release _DOTLOCK_PREFIX(dotlock_release)
|
|
|
|
# define dotlock_remove_lockfiles _DOTLOCK_PREFIX(dotlock_remove_lockfiles)
|
|
|
|
#endif /*DOTLOCK_EXT_SYM_PREFIX*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#if 0
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2003-01-09 13:36:05 +01:00
|
|
|
struct dotlock_handle;
|
2009-09-23 12:28:41 +02:00
|
|
|
typedef struct dotlock_handle *dotlock_t;
|
2003-01-09 13:36:05 +01:00
|
|
|
|
2023-12-13 10:08:12 +01:00
|
|
|
enum dotlock_reasons
|
|
|
|
{
|
|
|
|
DOTLOCK_CONFIG_TEST, /* Can't check system - function terminates. */
|
|
|
|
DOTLOCK_FILE_ERROR, /* General file error - function terminates. */
|
|
|
|
DOTLOCK_INV_FILE, /* Invalid file - function terminates. */
|
|
|
|
DOTLOCK_CONFLICT, /* Something is wrong - function terminates. */
|
|
|
|
DOTLOCK_NOT_LOCKED, /* Not locked - No action required. */
|
|
|
|
DOTLOCK_STALE_REMOVED, /* Stale lock file was removed - retrying. */
|
|
|
|
DOTLOCK_WAITING /* Waiting for the lock - may be terminated. */
|
|
|
|
};
|
|
|
|
|
2023-12-19 07:59:41 +01:00
|
|
|
/* Flags for dotlock_create. */
|
|
|
|
#define DOTLOCK_PREPARE_CREATE (1U << 5) /* Require dotlock_finish_create. */
|
|
|
|
#define DOTLOCK_LOCK_BY_PARENT (1U << 6) /* Used by dotlock util. */
|
|
|
|
#define DOTLOCK_LOCKED (1U << 7) /* Used by dotlock util. */
|
2023-12-13 10:08:12 +01:00
|
|
|
|
2011-09-23 14:43:58 +02:00
|
|
|
void dotlock_disable (void);
|
2011-09-28 15:41:58 +02:00
|
|
|
dotlock_t dotlock_create (const char *file_to_lock, unsigned int flags);
|
2023-12-13 10:08:12 +01:00
|
|
|
dotlock_t dotlock_finish_create (dotlock_t h, const char *file_to_lock);
|
2011-09-29 16:51:48 +02:00
|
|
|
void dotlock_set_fd (dotlock_t h, int fd);
|
|
|
|
int dotlock_get_fd (dotlock_t h);
|
2023-12-13 10:08:12 +01:00
|
|
|
void dotlock_set_info_cb (dotlock_t h,
|
|
|
|
int (*cb)(dotlock_t, void *,
|
|
|
|
enum dotlock_reasons reason,
|
|
|
|
const char *,...),
|
|
|
|
void *opaque);
|
2011-09-28 15:41:58 +02:00
|
|
|
void dotlock_destroy (dotlock_t h);
|
2011-09-23 14:43:58 +02:00
|
|
|
int dotlock_take (dotlock_t h, long timeout);
|
2023-12-13 10:08:12 +01:00
|
|
|
int dotlock_is_locked (dotlock_t h);
|
2011-09-23 14:43:58 +02:00
|
|
|
int dotlock_release (dotlock_t h);
|
2003-06-18 21:56:13 +02:00
|
|
|
void dotlock_remove_lockfiles (void);
|
2003-01-09 13:36:05 +01:00
|
|
|
|
2011-09-30 09:45:21 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2015-04-24 16:42:28 +02:00
|
|
|
#endif /*GNUPG_COMMON_DOTLOCK_H*/
|