123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- /*
- * CDE - Common Desktop Environment
- *
- * Copyright (c) 1993-2012, The Open Group. All rights reserved.
- *
- * These libraries and programs are free software; you can
- * redistribute them and/or modify them under the terms of the GNU
- * Lesser General Public License as published by the Free Software
- * Foundation; either version 2 of the License, or (at your option)
- * any later version.
- *
- * These libraries and programs are distributed in the hope that
- * they will be useful, but WITHOUT ANY WARRANTY; without even the
- * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- * PURPOSE. See the GNU Lesser General Public License for more
- * details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with these libraries and programs; if not, write
- * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
- * Floor, Boston, MA 02110-1301 USA
- */
- /* $TOG: fsrtns.h /main/6 1998/10/26 12:42:04 mgreess $ */
- /************************************<+>*************************************
- ****************************************************************************
- *
- * FILE: fsrtns.h
- *
- *
- * DESCRIPTION: Header files used in dosync.c,fsrtns.c,main_dtcopy.c
- *
- * (c) Copyright 1993, 1994, 1995 Hewlett-Packard Company
- * (c) Copyright 1993, 1994, 1995 International Business Machines Corp.
- * (c) Copyright 1993, 1994, 1995 Sun Microsystems, Inc.
- * (c) Copyright 1993, 1994, 1995 Novell, Inc.
- *
- ****************************************************************************
- ************************************<+>*************************************/
- #ifndef _fsrtns_h
- #define _fsrtns_h
- /*
- * General comments:
- *
- * The file systems routines below support renaming, moving, copying,
- * and deleting single files as well as directories. The operations
- * check return codes on close, so they are safe to use with AFS.
- *
- * If the operation failed, the the reason for the failure (errno value)
- * is returned in *rcP.
- *
- * The rename, move and copy routines all take a parameter 'replace'
- * that determines what happens if the target file/directory already
- * exists: if 'replace' is zero, the routines return an ENOENT error;
- * if 'replace' is non-zero the routines will replace any existing
- * files/directories.
- *
- * The copy and move operations preserve the modified timestamps and
- * file permissions of the source. If the calling program is running
- * as root, file ownership is also preserved.
- */
- /*
- * fsRename:
- * Renames or moves source to target.
- * Source and target must be on the same file system.
- */
- extern void fsRename(char *source, char *target, int replace, int *rcP);
- /*
- * fsMove:
- * Like fsRename, but also works if source and target are on different
- * file systems by copying source to target and then deleting source.
- */
- extern void fsMove(char *source, char *target, int replace, int *rcP);
- /*
- * fsCopy:
- * Copies source to target.
- */
- extern void fsCopy(char *source, char *target, int replace, int *rcP);
- /*
- * fsCopyLink:
- * Like fsCopy, but copies symbolic links as links, i.e.,creates a link
- * that points to the same place as the source link. Applies in the case
- * where source itself is a symbolic link, as well as the case where
- * source is a directory that contains symbolic links.
- */
- extern void fsCopyLink(char *source, char *target, int replace, int *rcP);
- /*
- * fsErase:
- * Deletes a file or directory.
- */
- extern void fsErase(char *name, int *rcP, int force);
- /*
- * fsEmpty:
- * Deletes all files/directries in the named directory.
- *
- */
- extern void fsEmpty(char *name, int *rcP);
- /*
- * Callback functions:
- *
- * progressCallback:
- * called each time a new file or directory is being processed
- *
- * errorCallback:
- * called when a file operation fails
- *
- * periodicCallback:
- * called periodically
- *
- * Each callback function should return zero if the file operation
- * is supposed to continue. To abort the operation, return a non-zero
- * value from one of the callback functions.
- */
- extern int (*progressCallback)(char *fname);
- extern int (*errorCallback)(char *fname, int errnum);
- extern int (*periodicCallback)(void);
- #endif /* _fsrtns_h */
|