/* $OpenLDAP$ */ /* * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ /* * Copyright (c) 1996 Regents of the University of Michigan. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that this notice is preserved and that due credit is given * to the University of Michigan at Ann Arbor. The name of the University * may not be used to endorse or promote products derived from this * software without specific prior written permission. This software * is provided ``as is'' without express or implied warranty. */ /* * lock.c - routines to open and apply an advisory lock to a file */ #include "portable.h" #include #include #include #include #include #include #ifdef HAVE_SYS_FILE_H #include #endif #include "slurp.h" FILE * lock_fopen( const char *fname, const char *type, FILE **lfp ) { FILE *fp; char buf[MAXPATHLEN]; /* open the lock file */ strcpy( buf, fname ); strcat( buf, ".lock" ); if ( (*lfp = fopen( buf, "w" )) == NULL ) { #ifdef NEW_LOGGING LDAP_LOG (( "lock", LDAP_LEVEL_ERR, "lock_fopen: " "Error: could not open \"%s\"\n", buf )); #else Debug( LDAP_DEBUG_ANY, "Error: could not open \"%s\"\n", buf, 0, 0 ); #endif return( NULL ); } /* acquire the lock */ ldap_lockf( fileno(*lfp) ); /* open the log file */ if ( (fp = fopen( fname, type )) == NULL ) { #ifdef NEW_LOGGING LDAP_LOG (( "lock", LDAP_LEVEL_ERR, "lock_fopen: " "Error: could not open \"%s\"\n", fname )); #else Debug( LDAP_DEBUG_ANY, "Error: could not open \"%s\"\n", fname, 0, 0 ); #endif ldap_unlockf( fileno(*lfp) ); fclose( *lfp ); *lfp = NULL; return( NULL ); } return( fp ); } int lock_fclose( FILE *fp, FILE *lfp ) { /* unlock */ ldap_unlockf( fileno(lfp) ); fclose( lfp ); return( fclose( fp ) ); } /* * Apply an advisory lock on a file. Just calls lock_fopen() */ int acquire_lock( const char *file, FILE **rfp, FILE **lfp ) { if (( *rfp = lock_fopen( file, "r+", lfp )) == NULL ) { #ifdef NEW_LOGGING LDAP_LOG (( "lock", LDAP_LEVEL_ERR, "acquire_lock: " "Error: acquire_lock(%ld): Could not acquire lock on \"%s\"\n", (long) getpid(), file )); #else Debug( LDAP_DEBUG_ANY, "Error: acquire_lock(%ld): Could not acquire lock on \"%s\"\n", (long) getpid(), file, 0); #endif return( -1 ); } return( 0 ); } /* * Relinquish a lock on a file. Calls lock_fclose() and also removes the * lock file. */ int relinquish_lock( const char *file, FILE *rfp, FILE *lfp ) { if ( lock_fclose( rfp, lfp ) == EOF ) { #ifdef NEW_LOGGING LDAP_LOG (( "lock", LDAP_LEVEL_ERR, "relinguish_lock: " "Error: relinquish_lock (%ld): Error closing \"%s\"\n", (long) getpid(), file )); #else Debug( LDAP_DEBUG_ANY, "Error: relinquish_lock (%ld): Error closing \"%s\"\n", (long) getpid(), file, 0 ); #endif return( -1 ); } return( 0 ); }