blob: f59f3e550fc997ecdb6e608be2dc882a7d14a593 [file] [log] [blame]
Jim Cownie5e8470a2013-09-27 10:38:44 +00001/*
2 * kmp_environment.h -- Handle environment varoiables OS-independently.
Jim Cownie5e8470a2013-09-27 10:38:44 +00003 */
4
5
6//===----------------------------------------------------------------------===//
7//
8// The LLVM Compiler Infrastructure
9//
10// This file is dual licensed under the MIT and the University of Illinois Open
11// Source Licenses. See LICENSE.txt for details.
12//
13//===----------------------------------------------------------------------===//
14
15
16#ifndef KMP_ENVIRONMENT_H
17#define KMP_ENVIRONMENT_H
18
19#ifdef __cplusplus
20extern "C" {
21#endif
22
Jonathan Peyton30419822017-05-12 18:01:32 +000023// Return a copy of the value of environment variable or NULL if the variable
24// does not exist.
Jim Cownie5e8470a2013-09-27 10:38:44 +000025// *Note*: Returned pointed *must* be freed after use with __kmp_env_free().
Jonathan Peyton30419822017-05-12 18:01:32 +000026char *__kmp_env_get(char const *name);
27void __kmp_env_free(char const **value);
Jim Cownie5e8470a2013-09-27 10:38:44 +000028
29// Return 1 if the environment variable exists or 0 if does not exist.
Jonathan Peyton30419822017-05-12 18:01:32 +000030int __kmp_env_exists(char const *name);
Jim Cownie5e8470a2013-09-27 10:38:44 +000031
32// Set the environment variable.
Jonathan Peyton30419822017-05-12 18:01:32 +000033void __kmp_env_set(char const *name, char const *value, int overwrite);
Jim Cownie5e8470a2013-09-27 10:38:44 +000034
35// Unset (remove) environment variable.
Jonathan Peyton30419822017-05-12 18:01:32 +000036void __kmp_env_unset(char const *name);
Jim Cownie5e8470a2013-09-27 10:38:44 +000037
Jonathan Peyton30419822017-05-12 18:01:32 +000038// -----------------------------------------------------------------------------
Jim Cownie5e8470a2013-09-27 10:38:44 +000039// Working with environment blocks.
Jim Cownie5e8470a2013-09-27 10:38:44 +000040
Jonathan Peyton30419822017-05-12 18:01:32 +000041/* kmp_env_blk_t is read-only collection of environment variables (or
42 environment-like). Usage:
Jim Cownie5e8470a2013-09-27 10:38:44 +000043
Jonathan Peyton30419822017-05-12 18:01:32 +000044kmp_env_blk_t block;
45__kmp_env_blk_init( & block, NULL ); // Initialize block from process
46 // environment.
47// or
48__kmp_env_blk_init( & block, "KMP_WARNING=1|KMP_AFFINITY=none" ); // from string
49__kmp_env_blk_sort( & block ); // Optionally, sort list.
50for ( i = 0; i < block.count; ++ i ) {
51 // Process block.vars[ i ].name and block.vars[ i ].value...
52}; // for i
53__kmp_env_block_free( & block );
Jim Cownie5e8470a2013-09-27 10:38:44 +000054*/
55
56struct __kmp_env_var {
Jonathan Peyton30419822017-05-12 18:01:32 +000057 char const *name;
58 char const *value;
Jim Cownie5e8470a2013-09-27 10:38:44 +000059};
60typedef struct __kmp_env_var kmp_env_var_t;
61
62struct __kmp_env_blk {
Jonathan Peyton30419822017-05-12 18:01:32 +000063 char const *bulk;
64 kmp_env_var_t const *vars;
65 int count;
Jim Cownie5e8470a2013-09-27 10:38:44 +000066};
67typedef struct __kmp_env_blk kmp_env_blk_t;
68
Jonathan Peyton30419822017-05-12 18:01:32 +000069void __kmp_env_blk_init(kmp_env_blk_t *block, char const *bulk);
70void __kmp_env_blk_free(kmp_env_blk_t *block);
71void __kmp_env_blk_sort(kmp_env_blk_t *block);
72char const *__kmp_env_blk_var(kmp_env_blk_t *block, char const *name);
Jim Cownie5e8470a2013-09-27 10:38:44 +000073
74#ifdef __cplusplus
75}
76#endif
77
78#endif // KMP_ENVIRONMENT_H
79
80// end of file //