2004-05-26 06:23:01 +04: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.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2015-06-24 06:59:57 +03:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2004-11-28 23:09:25 +03:00
|
|
|
* 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.
|
2018-09-12 00:59:37 +03:00
|
|
|
* Copyright (c) 2018 Cisco Systems, Inc. All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
* $COPYRIGHT$
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2004-11-22 04:38:40 +03:00
|
|
|
* Additional copyrights may follow
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2004-05-26 06:23:01 +04:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-05-27 20:26:36 +04:00
|
|
|
/** @file:
|
|
|
|
* Creates an operating system-acceptable path name.
|
|
|
|
*
|
2005-07-04 05:59:52 +04:00
|
|
|
* The opal_os_path() function takes a variable number of string arguments and
|
2004-05-27 20:26:36 +04:00
|
|
|
* concatenates them into a path name using the path separator character appropriate
|
|
|
|
* to the local operating system. NOTE: the string returned by this function has been
|
|
|
|
* malloc'd - thus, the user is responsible for free'ing the memory used by
|
|
|
|
* the string.
|
|
|
|
*
|
|
|
|
* CRITICAL NOTE: The input variable list MUST be terminated by a NULL value. Failure
|
|
|
|
* to do this will cause the program to suffer a catastrophic failure - usually a
|
|
|
|
* segmentation violation or bus error.
|
|
|
|
*
|
2005-03-14 23:57:21 +03:00
|
|
|
* The function calls orte_sys_info() to ensure that the path separator character
|
2004-05-27 20:26:36 +04:00
|
|
|
* has been identified. If that value cannot be identified for some reason,
|
|
|
|
* the function will return a NULL value. Likewise, specifying a path name that
|
|
|
|
* exceeds the maximum allowable path name length on the local system will result
|
|
|
|
* in the return of a NULL value.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*/
|
2004-05-26 06:23:01 +04:00
|
|
|
|
2006-08-23 03:25:13 +04:00
|
|
|
#ifndef OPAL_OS_PATH_H
|
|
|
|
#define OPAL_OS_PATH_H
|
|
|
|
|
2006-02-12 04:33:29 +03:00
|
|
|
#include "opal_config.h"
|
2005-07-04 05:59:52 +04:00
|
|
|
|
2004-05-26 06:23:01 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
2009-08-20 15:42:18 +04:00
|
|
|
BEGIN_C_DECLS
|
2005-07-04 05:59:52 +04:00
|
|
|
|
2015-06-24 06:59:57 +03:00
|
|
|
/**
|
2004-05-27 20:26:36 +04:00
|
|
|
* @param relative A boolean that specifies if the path name is to be constructed
|
|
|
|
* relative to the current directory or as an absolute path. If no path
|
|
|
|
* elements are included in the function call, then the function returns
|
2015-06-24 06:59:57 +03:00
|
|
|
* "." for a relative path name and "<path separator char>" -
|
2004-05-27 20:26:36 +04:00
|
|
|
* the top of the directory tree - for an absolute path name.
|
|
|
|
* @param elem1,elem2,... A variable number of (char *)path_elements
|
|
|
|
* can be provided to the function, terminated by a NULL value. These
|
|
|
|
* elements will be concatenated, each separated by the path separator
|
|
|
|
* character, into a path name and returned.
|
|
|
|
* @retval path_name A pointer to a fully qualified path name composed of the
|
|
|
|
* provided path elements, separated by the path separator character
|
|
|
|
* appropriate to the local operating system. The path_name string has been malloc'd
|
|
|
|
* and therefore the user is responsible for free'ing the field.
|
2018-09-12 00:59:37 +03:00
|
|
|
*
|
|
|
|
* Note that the "relative" argument is int instead of bool, because
|
|
|
|
* passing a parameter that undergoes default argument promotion to
|
|
|
|
* va_start() has undefined behavior (according to clang warnings on
|
|
|
|
* MacOS High Sierra).
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC char *opal_os_path(int relative, ...) __opal_attribute_malloc__ __opal_attribute_sentinel__ __opal_attribute_warn_unused_result__;
|
2005-07-04 05:59:52 +04:00
|
|
|
|
2006-08-23 03:25:13 +04:00
|
|
|
/**
|
|
|
|
* Convert the path to be OS friendly. On UNIX this function will
|
2013-02-28 21:31:47 +04:00
|
|
|
* be empty.
|
2006-08-23 03:25:13 +04:00
|
|
|
*/
|
|
|
|
#define opal_make_filename_os_friendly(PATH) (PATH)
|
|
|
|
|
2009-08-20 15:42:18 +04:00
|
|
|
END_C_DECLS
|
2006-08-23 03:25:13 +04:00
|
|
|
|
2005-07-04 05:59:52 +04:00
|
|
|
#endif /* OPAL_OS_PATH_H */
|