blob: 474aa3495555da15568ff05cbfe854df0c40f134 [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
Jim Cownie5e8470a2013-09-27 10:38:44 +00005//===----------------------------------------------------------------------===//
6//
7// The LLVM Compiler Infrastructure
8//
9// This file is dual licensed under the MIT and the University of Illinois Open
10// Source Licenses. See LICENSE.txt for details.
11//
12//===----------------------------------------------------------------------===//
13
Jim Cownie5e8470a2013-09-27 10:38:44 +000014#ifndef KMP_ENVIRONMENT_H
15#define KMP_ENVIRONMENT_H
16
17#ifdef __cplusplus
18extern "C" {
19#endif
20
Jonathan Peyton30419822017-05-12 18:01:32 +000021// Return a copy of the value of environment variable or NULL if the variable
22// does not exist.
Jim Cownie5e8470a2013-09-27 10:38:44 +000023// *Note*: Returned pointed *must* be freed after use with __kmp_env_free().
Jonathan Peyton30419822017-05-12 18:01:32 +000024char *__kmp_env_get(char const *name);
25void __kmp_env_free(char const **value);
Jim Cownie5e8470a2013-09-27 10:38:44 +000026
27// Return 1 if the environment variable exists or 0 if does not exist.
Jonathan Peyton30419822017-05-12 18:01:32 +000028int __kmp_env_exists(char const *name);
Jim Cownie5e8470a2013-09-27 10:38:44 +000029
30// Set the environment variable.
Jonathan Peyton30419822017-05-12 18:01:32 +000031void __kmp_env_set(char const *name, char const *value, int overwrite);
Jim Cownie5e8470a2013-09-27 10:38:44 +000032
33// Unset (remove) environment variable.
Jonathan Peyton30419822017-05-12 18:01:32 +000034void __kmp_env_unset(char const *name);
Jim Cownie5e8470a2013-09-27 10:38:44 +000035
Jonathan Peyton30419822017-05-12 18:01:32 +000036// -----------------------------------------------------------------------------
Jim Cownie5e8470a2013-09-27 10:38:44 +000037// Working with environment blocks.
Jim Cownie5e8470a2013-09-27 10:38:44 +000038
Jonathan Peyton30419822017-05-12 18:01:32 +000039/* kmp_env_blk_t is read-only collection of environment variables (or
40 environment-like). Usage:
Jim Cownie5e8470a2013-09-27 10:38:44 +000041
Jonathan Peyton30419822017-05-12 18:01:32 +000042kmp_env_blk_t block;
43__kmp_env_blk_init( & block, NULL ); // Initialize block from process
44 // environment.
45// or
46__kmp_env_blk_init( & block, "KMP_WARNING=1|KMP_AFFINITY=none" ); // from string
47__kmp_env_blk_sort( & block ); // Optionally, sort list.
48for ( i = 0; i < block.count; ++ i ) {
49 // Process block.vars[ i ].name and block.vars[ i ].value...
Jonathan Peytonbd3a7632017-09-27 20:36:27 +000050}
Jonathan Peyton30419822017-05-12 18:01:32 +000051__kmp_env_block_free( & block );
Jim Cownie5e8470a2013-09-27 10:38:44 +000052*/
53
54struct __kmp_env_var {
Jonas Hahnfeldaeb40ad2017-11-09 15:52:25 +000055 char *name;
56 char *value;
Jim Cownie5e8470a2013-09-27 10:38:44 +000057};
58typedef struct __kmp_env_var kmp_env_var_t;
59
60struct __kmp_env_blk {
Jonas Hahnfeldaeb40ad2017-11-09 15:52:25 +000061 char *bulk;
62 kmp_env_var_t *vars;
Jonathan Peyton30419822017-05-12 18:01:32 +000063 int count;
Jim Cownie5e8470a2013-09-27 10:38:44 +000064};
65typedef struct __kmp_env_blk kmp_env_blk_t;
66
Jonathan Peyton30419822017-05-12 18:01:32 +000067void __kmp_env_blk_init(kmp_env_blk_t *block, char const *bulk);
68void __kmp_env_blk_free(kmp_env_blk_t *block);
69void __kmp_env_blk_sort(kmp_env_blk_t *block);
70char const *__kmp_env_blk_var(kmp_env_blk_t *block, char const *name);
Jim Cownie5e8470a2013-09-27 10:38:44 +000071
72#ifdef __cplusplus
73}
74#endif
75
76#endif // KMP_ENVIRONMENT_H
77
78// end of file //