2004-01-09 11:03:27 +03:00
|
|
|
/*
|
2005-11-05 22:57:48 +03:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2007-07-01 21:59:46 +04:00
|
|
|
* Copyright (c) 2004-2007 The University of Tennessee and The University
|
2005-11-05 22:57:48 +03:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2004-11-28 23:09:25 +03:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2012-10-10 00:48:04 +04:00
|
|
|
* Copyright (c) 2012 Los Alamos National Security, LLC.
|
|
|
|
* All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-01-09 11:03:27 +03:00
|
|
|
* $HEADER$
|
2005-02-09 20:13:54 +03:00
|
|
|
*
|
|
|
|
* @file
|
2004-01-09 11:03:27 +03:00
|
|
|
*/
|
|
|
|
|
2005-07-04 05:59:52 +04:00
|
|
|
#ifndef OPAL_PATH_H
|
|
|
|
#define OPAL_PATH_H
|
2004-01-09 11:03:27 +03:00
|
|
|
|
2006-02-12 04:33:29 +03:00
|
|
|
#include "opal_config.h"
|
2005-02-09 20:13:54 +03:00
|
|
|
|
2012-10-10 00:48:04 +04:00
|
|
|
#include "opal/constants.h"
|
|
|
|
|
2009-07-13 23:40:31 +04:00
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
|
2007-07-01 21:53:19 +04:00
|
|
|
BEGIN_C_DECLS
|
2004-01-12 05:07:42 +03:00
|
|
|
|
2007-07-01 21:53:19 +04:00
|
|
|
/**
|
|
|
|
* Locates a file with certain permissions
|
|
|
|
*
|
|
|
|
* @param fname File name
|
|
|
|
* @param pathv Array of search directories
|
|
|
|
* @param mode Permissions which must be satisfied (see access(2))
|
|
|
|
* @param envv Pointer to string containing environment
|
|
|
|
*
|
|
|
|
* @retval Full pathname of located file Success
|
|
|
|
* @retval NULL Failure
|
|
|
|
*
|
|
|
|
* Environment variables can appear in the form $variable at the
|
|
|
|
* start of a prefix path and will be replaced by the environment
|
|
|
|
* value if it is defined; otherwise the whole prefix is ignored.
|
|
|
|
* Environment variables must be followed by a path delimiter or
|
|
|
|
* end-of-string.
|
|
|
|
*
|
|
|
|
* The caller is responsible for freeing the returned string.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC char *opal_path_find(char *fname, char **pathv, int mode,
|
2009-05-14 04:20:07 +04:00
|
|
|
char **envv) __opal_attribute_malloc__ __opal_attribute_warn_unused_result__;
|
2005-02-09 20:13:54 +03:00
|
|
|
|
2007-07-01 21:53:19 +04:00
|
|
|
/**
|
|
|
|
* Locates a file with certain permissions from a list of search
|
|
|
|
* paths
|
|
|
|
*
|
|
|
|
* @param fname File name
|
|
|
|
* @param mode Target permissions which must be satisfied (see access(2))
|
|
|
|
* @param envv Pointer to environment list
|
|
|
|
* @param wrkdir Working directory
|
|
|
|
*
|
|
|
|
* @retval Full pathname of located file Success
|
|
|
|
* @retval NULL Failure
|
|
|
|
*
|
|
|
|
* Locates a file with certain permissions from the list of paths
|
|
|
|
* given by the $PATH environment variable. Replaces "." in the
|
|
|
|
* path with the working dir.
|
|
|
|
*
|
|
|
|
* The caller is responsible for freeing the returned string.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC char *opal_path_findv(char *fname, int mode,
|
2009-05-14 04:20:07 +04:00
|
|
|
char **envv, char *wrkdir) __opal_attribute_malloc__ __opal_attribute_warn_unused_result__;
|
2007-07-01 21:53:19 +04:00
|
|
|
/**
|
|
|
|
* Detect if the requested path is absolute or relative.
|
|
|
|
*
|
|
|
|
* @param path File name
|
|
|
|
*
|
|
|
|
* @retval true if the path is absolute
|
|
|
|
* @retval false otherwise
|
|
|
|
*
|
|
|
|
* Detect if a path is absolute or relative. Handle Windows
|
|
|
|
* with special care as an absolute path on Windows starts
|
|
|
|
* with [A-Za-z]: or \\ instead of the usual / on UNIX.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC bool opal_path_is_absolute( const char *path );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find the absolute path for an executable and return it.
|
|
|
|
*
|
|
|
|
* @param app_name Executable name
|
|
|
|
*
|
|
|
|
* @retval The absolute path if the application can be reached,
|
|
|
|
* @retval NULL otherwise.
|
|
|
|
*
|
|
|
|
* Try to figure out the absolute path based on the application name
|
|
|
|
* (usually argv[0]). If the path is already absolute return a copy, if
|
|
|
|
* it start with . look into the current directory, if not dig into
|
|
|
|
* the $PATH.
|
|
|
|
* In case of error or if executable was not found (as an example if
|
|
|
|
* the application did a cwd between the start and this call), the
|
|
|
|
* function will return NULL. Otherwise, an newly allocated string
|
|
|
|
* will be returned.
|
|
|
|
*/
|
2009-05-14 04:20:07 +04:00
|
|
|
OPAL_DECLSPEC char* opal_find_absolute_path( char* app_name ) __opal_attribute_warn_unused_result__;
|
2004-01-09 11:03:27 +03:00
|
|
|
|
2007-07-01 21:53:19 +04:00
|
|
|
/**
|
|
|
|
* Forms a complete pathname and checks it for existance and
|
|
|
|
* permissions
|
|
|
|
*
|
|
|
|
* @param fname File name
|
|
|
|
* @param path Path prefix, if NULL then fname is an absolute path
|
|
|
|
* @param mode Target permissions which must be satisfied (see access(2))
|
|
|
|
*
|
|
|
|
* @retval NULL Failure
|
|
|
|
* @retval Full pathname of the located file on Success
|
2009-05-14 04:20:07 +04:00
|
|
|
*
|
|
|
|
* The caller is responsible for freeing the returned string.
|
2007-07-01 21:53:19 +04:00
|
|
|
*/
|
2009-05-14 04:20:07 +04:00
|
|
|
OPAL_DECLSPEC char *opal_path_access(char *fname, char *path, int mode) __opal_attribute_malloc__ __opal_attribute_warn_unused_result__;
|
2007-03-01 16:39:20 +03:00
|
|
|
|
2010-02-11 02:18:29 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Figure out, whether fname is on network file system
|
|
|
|
*
|
|
|
|
* Try to figure out, whether the file name specified through fname is
|
|
|
|
* on any network file system (currently NFS, Lustre and Panasas).
|
|
|
|
*
|
|
|
|
* If the file is not created, the parent directory is checked.
|
|
|
|
* This allows checking for NFS prior to opening the file.
|
|
|
|
*
|
|
|
|
* @param[in] fname File name to check
|
|
|
|
*
|
|
|
|
* @retval true If fname is on NFS, Lustre or Panasas
|
|
|
|
* @retval false otherwise
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC bool opal_path_nfs(char *fname) __opal_attribute_warn_unused_result__;
|
|
|
|
|
2012-10-10 00:48:04 +04:00
|
|
|
/**
|
|
|
|
* @brief Returns the disk usage of path.
|
|
|
|
*
|
|
|
|
* @param[in] path Path to check
|
|
|
|
* @out_avail[out] Amount of free space available on path (if successful)
|
|
|
|
*
|
|
|
|
* @retval OPAL_SUCCESS If the operation was successful
|
|
|
|
* @retval OPAL_ERROR otherwise
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_path_df(const char *path,
|
2012-10-11 20:11:23 +04:00
|
|
|
uint64_t *out_avail)__opal_attribute_warn_unused_result__;
|
2012-10-10 00:48:04 +04:00
|
|
|
|
2007-07-01 21:53:19 +04:00
|
|
|
END_C_DECLS
|
2005-07-04 05:59:52 +04:00
|
|
|
#endif /* OPAL_PATH_H */
|