xtd 0.2.0
Loading...
Searching...
No Matches
environment.hpp
Go to the documentation of this file.
1
4#pragma once
7#include "io/directory.hpp"
8#include "io/path.hpp"
11#include "as.hpp"
13#include "compiler.hpp"
14#include "core_export.hpp"
15#include "cpp_language.hpp"
16#include "enum.hpp"
18#include "event.hpp"
19#include "exit_status.hpp"
20#include "guid.hpp"
21#include "operating_system.hpp"
22#include "platform_id.hpp"
23#include "processor.hpp"
26#include "static.hpp"
27#include "target_id.hpp"
28#include "target_type.hpp"
29#include "toolkit.hpp"
30#include "string.hpp"
31#include "version.hpp"
32#define __XTD_CORE_INTERNAL__
37#undef __XTD_CORE_INTERNAL__
38#include <map>
39#include <cstdlib>
40#include <vector>
41
43// The following constant is defined in the file xtd_command.cmake.
44// If the target project is not built with cmake, the following constant must be defined by the build tool like this if the cmake_install_prefix is not modified; otherwise the cmake_install_prefix value:
45// | Constant | Windows Value | macOS | linux |
46// | ----------------- | ---------------------------- |--------------|--------------|
47// | __XTD_ROOT_PATH__ | "C:\Program Files (x86)\xtd" | "/usr/local" | "/usr/local" |
48// Remarks : If __XTD_ROOT_PATH__ is empty the environment variable XTD_ROOT_PATH is used. And if the environment variable XTD_ROOT_PATH is empty too the directory componant of __FILE__ macro is used.
49
50#if !defined(__XTD_ROOT_PATH__)
51# define __XTD_ROOT_PATH__ ""
52#endif
54
56namespace xtd {
68 class signal_catcher;
69 public:
145 enum class special_folder {
147 desktop = 0,
149 programs = 2,
151 my_documents = 5,
153 personal = 5,
155 favorites = 6,
157 startup = 7,
159 recent = 8,
161 send_to = 9,
163 start_menu = 11,
165 my_music = 13,
167 my_videos = 14,
169 desktop_directory = 16,
171 my_computer = 17,
173 network_shortcuts = 19,
175 fonts = 20,
177 templates = 21,
179 common_start_menu = 22,
181 common_programs = 23,
183 common_startup = 24,
185 common_desktop_directory = 25,
187 application_data = 26,
189 printer_shortcuts = 27,
191 local_application_data = 28,
193 internet_cache = 32,
195 cookies = 33,
197 history = 34,
199 common_application_data = 35,
201 windows = 36,
203 system = 37,
205 program_files = 38,
207 my_pictures = 39,
209 user_profile = 40,
211 system_x86 = 41,
213 program_files_x86 = 42,
215 common_program_files = 43,
217 common_program_files_x86 = 44,
219 common_templates = 45,
221 common_documents = 46,
223 common_admin_tools = 47,
225 admin_tools = 48,
227 common_music = 53,
229 common_pictures = 54,
231 common_videos = 55,
233 resources = 56,
235 localized_resources = 57,
237 common_oem_links = 58,
239 cd_burning = 59,
241 home = 64,
243 application_resources = 999,
245 xtd_install = 1000,
247 xtd_locale = 1001,
249 xtd_reference_guide = 1002,
251 xtd_themes = 1003,
253 xtd_include = 1004,
255 xtd_libraries = 1005,
257 xtd_resources = 1006,
259 xtd_console_include = 1007,
261 xtd_console_libraries = 1008,
263 xtd_drawing_include = 1009,
265 xtd_drawing_libraries = 1010,
267 xtd_drawing_resources = 1011,
269 xtd_forms_include = 1012,
271 xtd_forms_libraries = 1013,
273 xtd_forms_resources = 1014,
275 xtd_tunit_include = 1015,
277 xtd_tunit_libraries = 1016,
278 };
279
284 none = 0,
286 do_not_verify = 16384,
288 create = 32768
289 };
290
292 class xtd_library final : public xtd::object {
293 public:
295 xtd_library() = default;
296 xtd_library(const xtd_library&) = default;
297 xtd_library& operator =(const xtd_library&) = default;
299
301
305 const xtd::string& include_path() const noexcept;
306
309 const xtd::string& library_path() const noexcept;
310
313 const xtd::string& name() const noexcept;
314
317 const xtd::string& resources_path() const noexcept;
318
321 const xtd::version& version() const noexcept;
323
325
327 xtd::string to_string() const noexcept override;
329
330 private:
331 friend class environment;
332 xtd_library(const xtd::string& name, const xtd::version& version, const xtd::string& include_path, const xtd::string& library_path, const xtd::string& resources_path);
333 xtd::string name_;
334 xtd::version version_;
335 xtd::string include_path_;
336 xtd::string library_path_;
337 xtd::string resources_path_;
338 };
339
342
344
351 static xtd::string command_line() noexcept;
352
355 static xtd::compiler compiler_version() noexcept {
356 static auto compiler_id = __compiler_id;
357 static auto version = __compiler_version;
358 static auto build_type = __build_type;
359 static xtd::compiler compiler {compiler_id, version, build_type, sizeof(size_t) == 8};
360 return compiler;
361 }
362
365 static xtd::cpp_language cpp_version() noexcept {
366 static auto cpp_language = __cpp_language;
367 return cpp_language;
368 }
369
375
382 static void current_directory(const xtd::string& directory_name);
383
387
390 static intptr current_thread_id() noexcept;
391
397 static int32 exit_code() noexcept;
403 static void exit_code(int32 value) noexcept;
404
408 static bool has_shutdown_started();
409
412 static bool is_64_bit_operating_system() noexcept;
413
416 static bool is_64_bit_process() noexcept;
417
421 static std::locale locale() noexcept;
422
426 static xtd::string machine_name();
427
430 static xtd::string new_line() noexcept;
431
435 template <typename char_t, class traits_t>
436 static std::basic_ostream<char_t, traits_t>& new_line(std::basic_ostream<char_t, traits_t>& os) {
437 for (auto c : new_line())
438 os.put(os.widen(c));
439 return os;
440 }
441
445
448 static uint32 processor_count();
449
452 static xtd::processor processor_information();
453
456 static xtd::string stack_trace();
457
461 static xtd::string system_directory();
462
465 static size_t system_page_size();
466
469 static xtd::target_type target_type() noexcept {
470 return xtd::target_type(as<xtd::target_id>(__XTD_CURRENT_TARGET_ID__));
471 }
472
475 static std::chrono::milliseconds tick_count();
476
480
481
484 static bool user_administrator();
485
489
495 static bool user_interactive();
496
500
503 static xtd::version version() noexcept;
504
511 static int64 working_set();
512
515 static const xtd_library_collection& xtd_libraries() noexcept;
517
519
527
532
534
537 static void abort();
538
541 [[noreturn]] static void exit();
545 [[noreturn]] static void exit(int32 exit_code);
548 [[noreturn]] static void exit(xtd::exit_status exit_status);
549
554 static xtd::string expand_environment_variables(const xtd::string& name);
555
571 static xtd::argument_collection get_command_line_args();
572
579 static xtd::string get_environment_variable(const xtd::string& variable);
580
589 static xtd::string get_environment_variable(const xtd::string& variable, environment_variable_target target);
590
594 static std::map<std::string, std::string>& get_environment_variables();
595
602 static std::map<std::string, std::string>& get_environment_variables(environment_variable_target target);
603
608 static xtd::string get_folder_path(environment::special_folder folder) {return get_folder_path_(folder, environment::special_folder_option::none);}
609
615 static xtd::string get_folder_path(environment::special_folder folder, environment::special_folder_option option) {return get_folder_path_(folder, option);}
616
620
623 [[noreturn]] static void quick_exit() noexcept;
627 [[noreturn]] static void quick_exit(int32 exit_code) noexcept;
630 [[noreturn]] static void quick_exit(xtd::exit_status exit_status) noexcept;
631
634 static void raise(xtd::signal signal);
635
642 static void set_environment_variable(const xtd::string& variable, const xtd::string& value);
643
652 static void set_environment_variable(const xtd::string& variable, const xtd::string& value, environment_variable_target target);
654
656 static void __signal_catcher_check__();
658
659 private:
660 static void on_cancel_signal(signal_cancel_event_args& e);
661 static void on_program_exit(const program_exit_event_args& e);
662
663 static xtd::string get_folder_path_(environment::special_folder folder, environment::special_folder_option option, bool is_gui_application = target_type().is_guid_application());
664 inline static const string xtd_root_path() {return xtd::io::path::get_full_path(string::is_empty(__XTD_ROOT_PATH__) ? (string::is_empty(get_environment_variable("XTD_ROOT_PATH")) ? io::path::get_full_path(io::path::combine(io::path::get_directory_name(__FILE__), "..", "..")) : get_environment_variable("XTD_ROOT_PATH")) : __XTD_ROOT_PATH__);}
665 static signal_catcher signal_catcher_;
666 };
667}
668
671 explicit operator auto() const noexcept {return xtd::enum_collection<xtd::environment::special_folder> {{xtd::environment::special_folder::desktop, "desktop"}, {xtd::environment::special_folder::programs, "programs"}, {xtd::environment::special_folder::my_documents, "my_documents"}, {xtd::environment::special_folder::favorites, "favorites"}, {xtd::environment::special_folder::startup, "startup"}, {xtd::environment::special_folder::recent, "recent"}, {xtd::environment::special_folder::send_to, "send_to"}, {xtd::environment::special_folder::start_menu, "start_menu"}, {xtd::environment::special_folder::my_music, "my_music"}, {xtd::environment::special_folder::my_videos, "my_videos"}, {xtd::environment::special_folder::desktop_directory, "desktop_directory"}, {xtd::environment::special_folder::my_computer, "my_computer"}, {xtd::environment::special_folder::network_shortcuts, "network_shortcuts"}, {xtd::environment::special_folder::fonts, "fonts"}, {xtd::environment::special_folder::templates, "templates"}, {xtd::environment::special_folder::common_start_menu, "common_start_menu"}, {xtd::environment::special_folder::common_programs, "common_programs"}, {xtd::environment::special_folder::common_startup, "common_startup"}, {xtd::environment::special_folder::common_desktop_directory, "common_desktop_directory"}, {xtd::environment::special_folder::application_data, "application_data"}, {xtd::environment::special_folder::printer_shortcuts, "printer_shortcuts"}, {xtd::environment::special_folder::local_application_data, "local_application_data"}, {xtd::environment::special_folder::internet_cache, "internet_cache"}, {xtd::environment::special_folder::cookies, "cookies"}, {xtd::environment::special_folder::history, "history"}, {xtd::environment::special_folder::common_application_data, "common_application_data"}, {xtd::environment::special_folder::windows, "windows"}, {xtd::environment::special_folder::system, "system"}, {xtd::environment::special_folder::program_files, "program_files"}, {xtd::environment::special_folder::my_pictures, "my_pictures"}, {xtd::environment::special_folder::user_profile, "user_profile"}, {xtd::environment::special_folder::system_x86, "system_x86"}, {xtd::environment::special_folder::program_files_x86, "program_files_x86"}, {xtd::environment::special_folder::common_program_files, "common_program_files"}, {xtd::environment::special_folder::common_program_files_x86, "common_program_files_x86"}, {xtd::environment::special_folder::common_templates, "common_templates"}, {xtd::environment::special_folder::common_documents, "common_documents"}, {xtd::environment::special_folder::common_admin_tools, "common_admin_tools"}, {xtd::environment::special_folder::admin_tools, "admin_tools"}, {xtd::environment::special_folder::common_music, "common_music"}, {xtd::environment::special_folder::common_pictures, "common_pictures"}, {xtd::environment::special_folder::common_videos, "common_videos"}, {xtd::environment::special_folder::resources, "resources"}, {xtd::environment::special_folder::localized_resources, "localized_resources"}, {xtd::environment::special_folder::common_oem_links, "common_oem_links"}, {xtd::environment::special_folder::cd_burning, "cd_burning"}, {xtd::environment::special_folder::home, "home"}, {xtd::environment::special_folder::application_resources, "application_resources"}, {xtd::environment::special_folder::xtd_install, "xtd_install"}, {xtd::environment::special_folder::xtd_locale, "xtd_locale"}, {xtd::environment::special_folder::xtd_reference_guide, "xtd_reference_guide"}, {xtd::environment::special_folder::xtd_themes, "xtd_themes"}, {xtd::environment::special_folder::xtd_include, "xtd_include"}, {xtd::environment::special_folder::xtd_libraries, "xtd_libraries"}, {xtd::environment::special_folder::xtd_resources, "xtd_resources"}, {xtd::environment::special_folder::xtd_console_include, "xtd_console_include"}, {xtd::environment::special_folder::xtd_console_libraries, "xtd_console_libraries"}, {xtd::environment::special_folder::xtd_drawing_include, "xtd_drawing_include"}, {xtd::environment::special_folder::xtd_drawing_libraries, "xtd_drawing_libraries"}, {xtd::environment::special_folder::xtd_drawing_resources, "xtd_drawing_resources"}, {xtd::environment::special_folder::xtd_forms_include, "xtd_forms_include"}, {xtd::environment::special_folder::xtd_forms_libraries, "xtd_forms_libraries"}, {xtd::environment::special_folder::xtd_forms_resources, "xtd_forms_resources"}, {xtd::environment::special_folder::xtd_tunit_include, "xtd_tunit_include"}, {xtd::environment::special_folder::xtd_tunit_libraries, "xtd_tunit_libraries"}};}
672};
673
676};
Contains __build_type definition.
Contains __compiler_id definition.
Contains __compiler_version definition.
Contains __cpp_language definition.
Contains xtd::argument_collection alias.
Contains xtd::argument_exception exception.
Contains xtd::as method.
Contains availability versions.
Represents text as a sequence of character units.
Definition basic_string.hpp:79
Represents a strongly typed list of objects that can be accessed by index. Provides methods to search...
Definition list.hpp:71
Represents information about c++ libraries, such as the version and standard identifier....
Definition compiler.hpp:27
Represents information about c++ libraries, such as the version and language identifier....
Definition cpp_language.hpp:26
Represents a xtd library that contains name, version and paths.
Definition environment.hpp:292
const xtd::string & include_path() const noexcept
Gets The inlcude path of the library.
The environment class.
Definition environment.hpp:67
static std::chrono::milliseconds tick_count()
Gets the number of milliseconds elapsed since the system started.
special_folder
Specifies enumerated constants used to retrieve directory paths to system special folders.
Definition environment.hpp:145
@ common_startup
The file system directory that contains the programs that appear in the Startup folder for all users....
@ xtd_locale
The xtd locale folder.
@ printer_shortcuts
The file system directory that contains the link objects that can exist in the Printers virtual folde...
@ windows
The Windows directory or SYSROOT. This corresponds to the windir% or SYSTEMROOT% environment variable...
@ home
The file system directory that contains home folder.
@ xtd_drawing_libraries
The xtd::drawing libraries folder.
@ local_application_data
The directory that serves as a common repository for application-specific data that is used by the cu...
@ my_computer
The My Computer folder. The MyComputer constant always yields the empty string ("") because no path i...
@ user_profile
The user's profile folder. Applications should not create files or folders at this level; they should...
@ xtd_console_libraries
The xtd::console libraries folder.
@ common_application_data
The directory that serves as a common repository for application-specific data that is used by all us...
@ xtd_forms_resources
The xtd::forms resources folder.
@ xtd_forms_libraries
The xtd::forms libraries folder.
@ xtd_reference_guide
The xtd reference guide folder.
@ localized_resources
The file system directory that contains localized resource data.
@ common_program_files
The directory for components that are shared across applications.To get the x86 common program files ...
@ program_files
The program files directory.On a non-x86 system, passing ProgramFiles to the GetFolderPath method ret...
@ history
The directory that serves as a common repository for Internet history items.
@ xtd_console_include
The xtd::console include folder.
@ xtd_resources
The xtd resources folder.
@ common_videos
The file system directory that serves as a repository for video files common to all users.
@ common_admin_tools
The file system directory that contains administrative tools for all users of the computer.
@ programs
The directory that contains the user's program groups.
@ system
The System directory.
@ resources
The file system directory that contains resource data.
@ cookies
The directory that serves as a common repository for Internet cookies.
@ admin_tools
The file system directory that is used to store administrative tools for an individual user....
@ xtd_tunit_libraries
The xtd::tunit libraries folder.
@ common_desktop_directory
The file system directory that contains files and folders that appear on the desktop for all users....
@ common_start_menu
The file system directory that contains the programs and folders that appear on the Start menu for al...
@ xtd_drawing_include
The xtd::drawing include folder.
@ common_pictures
The file system directory that serves as a repository for image files common to all users.
@ my_music
The My Music folder.
@ desktop_directory
The directory used to physically store file objects on the desktop. Do not confuse this directory wit...
@ common_programs
A folder for components that are shared across applications. This special folder is valid only for Wi...
@ xtd_tunit_include
The xtd::tunit include folder.
@ xtd_include
The xtd inlude folder.
@ recent
The directory that contains the user's most recently used documents.
@ common_music
The file system directory that serves as a repository for music files common to all users.
@ my_pictures
The My Pictures folder.
@ fonts
A virtual folder that contains fonts.
@ xtd_install
The installation folder of xtd.
@ system_x86
The Windows System folder.
@ start_menu
The directory that contains the Start menu items.
@ my_documents
The My Documents folder. This member is equivalent to Personal.
@ xtd_forms_include
The xtd::forms include folder.
@ common_program_files_x86
The Program Files folder.
@ favorites
The directory that serves as a common repository for the user's favorite items.
@ desktop
The logical Desktop rather than the physical file system location.
@ network_shortcuts
A file system directory that contains the link objects that may exist in the My Network Places virtua...
@ internet_cache
The directory that serves as a common repository for temporary Internet files.
@ common_templates
The file system directory that contains the templates that are available to all users....
@ application_resources
The application resources folder.
@ send_to
The directory that contains the Send To menu items.
@ xtd_drawing_resources
The xtd::drawing resources folder.
@ application_data
The directory that serves as a common repository for application-specific data for the current roamin...
@ program_files_x86
The Program Files folder On an x86 system, passing the ProgramFilesX86 member to the Environment....
@ cd_burning
The file system directory that acts as a staging area for files waiting to be written to a CD.
@ startup
The directory that corresponds to the user's Startup program group. The system starts these programs ...
@ xtd_themes
The xtd themes folder.
@ common_oem_links
This value is recognized in Windows Vista for backward compatibility, but the special folder itself i...
@ my_videos
The file system directory that serves as a repository for videos that belong to a user.
@ common_documents
The file system directory that contains documents that are common to all users. This special folder i...
@ xtd_libraries
The xtd libraries folder.
@ templates
The directory that serves as a common repository for document templates.
static bool user_administrator()
Gets a value indicating whether the current user is an administrator.
static void current_directory(const xtd::string &directory_name)
Sets the fully qualified path of the current working directory.
static xtd::cpp_language cpp_version() noexcept
Gets an xtd::cpp_language object that contains the current c++ standard identifier and version number...
Definition environment.hpp:365
static int32 current_managed_thread_id() noexcept
Gets a unique identifier for the current managed thread.
static xtd::operating_system os_version() noexcept
Gets an xtd::operating_system object that contains the current platform identifier and version number...
static xtd::string get_folder_path(environment::special_folder folder, environment::special_folder_option option)
Gets the path to the system special folder that is identified by the specified enumeration,...
Definition environment.hpp:615
static void quick_exit() noexcept
Terminates this process and returns an exit code to the operating system without completely cleaning ...
static xtd::string user_name()
Gets the user name of the person who is currently logged on to the operating system.
special_folder_option
Specifies options to use for getting the path to a special folder.
Definition environment.hpp:282
@ none
The path to the folder is verified. If the folder exists, the path is returned. If the folder does no...
@ create
The path to the folder is created if it does not already exist.
@ do_not_verify
The path to the folder is returned without verifying whether the path exists. If the folder is locate...
static xtd::version version() noexcept
Gets a version consisting of the major, minor, build, and revision numbers of the xtd framework.
std::vector< xtd_library > xtd_library_collection
Represents a xtd libraries collection.
Definition environment.hpp:341
static xtd::string user_domain_name()
Gets the network domain name associated with the current user.
static xtd::collections::specialized::string_collection get_logical_drives()
Returns an array of string containing the names of the logical drives on the current computer.
static xtd::string current_directory()
Gets the fully qualified path of the current working directory.
static bool user_interactive()
Gets a value indicating whether the current process is running in user interactive mode.
static xtd::toolkit toolkit_version()
Gets the current toolkit version.
Represents an event.
Definition event.hpp:21
static xtd::string get_full_path(const xtd::string &path)
Returns the absolute path for the specified path string.
Supports all classes in the xtd class hierarchy and provides low-level services to derived classes....
Definition object.hpp:42
Represents information about an operating system, such as the version and platform identifier....
Definition operating_system.hpp:25
Represents information about a processor, such as the architecture. This class cannot be inherited.
Definition processor.hpp:19
Provides data for the environment program exit event. This class cannot be inherited.
Definition program_exit_event_args.hpp:16
Provides data for the environment signal event. This class cannot be inherited.
Definition signal_cancel_event_args.hpp:18
Defines the xtd::startup object that can be used in the main method to safely call the application's ...
Definition startup.hpp:23
Represents information about target type, such as the target identifier. This class cannot be inherit...
Definition target_type.hpp:17
Represents a toolkit.
Definition toolkit.hpp:19
Represents the version number of an assembly, operating system, or the xtd. This class cannot be inhe...
Definition version.hpp:114
Contains xtd::compiler class.
Contains core_export_ keyword.
Contains xtd::cpp_language class.
Contains enum_ and enum_ut_ keywords.
Contains xtd::event event.
Contains xtd::exit_status enum class.
xtd::delegate< void(const program_exit_event_args &)> program_exit_event_handler
Represents the method that will handle the program exit events of a xtd::environment.
Definition program_exit_event_handler.hpp:17
xtd::delegate< void(signal_cancel_event_args &)> signal_cancel_event_handler
Represents the method that will handle the signal events of a xtd::environment.
Definition signal_cancel_event_handler.hpp:17
#define static_
This keyword is use to represent a static object. A static object can't be instantiated (constructors...
Definition static.hpp:37
#define core_export_
Define shared library export.
Definition core_export.hpp:13
int32_t int32
Represents a 32-bit signed integer.
Definition int32.hpp:23
int64_t int64
Represents a 64-bit signed integer.
Definition int64.hpp:23
uint32_t uint32
Represents a 32-bit unsigned integer.
Definition uint32.hpp:23
intmax_t intptr
Represent a pointer or a handle.
Definition intptr.hpp:23
signal
Specifies signals that can interrupt the current process.
Definition signal.hpp:18
exit_status
Specifies exit status for the xtd::environment::exit method.
Definition exit_status.hpp:18
environment_variable_target
Specifies the location where an environment variable is stored or retrieved in a set or get operation...
Definition environment_variable_target.hpp:15
build_type
Identifies the build type.
Definition build_type.hpp:20
std::vector< xtd::collections::generic::key_value_pair< enum_t, xtd::string > > enum_collection
Represents a pair of an enum_t value and a string of an enum of type enum_t.
Definition enum_collection.hpp:22
compiler_id
Identifies the compiler, supported by an assembly.
Definition compiler_id.hpp:20
@ none
No modifier key.
@ home
The HOME key.
@ c
The C key.
The xtd namespace contains all fundamental classes to access Hardware, Os, System,...
Definition xtd_about_box.hpp:10
Contains xtd::operating_system class.
Contains xtd::platform_id enum class.
Contains xtd::processor class.
Contains xtd::program_exit_event_handler event handler.
Contains xtd::signal_cancel_event_handler event handler.
Contains xtd::static_object class.
Contains xtd::string alias.
Contains xtd::collections::specialized::string_collection typedef.
Provides the registration struct for enumerations.
Definition enum_register.hpp:38
Contains xtd::target_id enum class.
Contains xtd::target_type class.
Contains xtd::version class.
Contains xtd::diagnostics::stack_trace class.
Contains xtd::environment_variable_target enum class.
Contains xtd::guid class.
Contains xtd::io::directory class.
Contains xtd::io::path class.
Contains xtd::forms::native::toolkit API.