std::source_location::file_name
From cppreference.com
< cpp | utility | source location
constexpr const char* file_name() const noexcept; |
(since C++20) | |
Returns the name of the current source file represented by this object, represented as a null-terminated byte string.
Parameters
(none)
Return value
The name of the current source file represented by this object, represented as a null-terminated byte string.
Example
Run this code
#if __has_include(<source_location>) #include <source_location> using std::source_location; #elif __has_include(<experimental/source_location>) #include <experimental/source_location> using std::experimental::source_location; #else #error "<source_location> not found" #endif #include <iostream> inline void print_this_file_name( const source_location& location = source_location::current()) { // Name of file that contains the call site of this function. std::cout << "File: " << location.file_name() << '\n'; } auto main() -> int { print_this_file_name(); }
Possible output:
File: main.cpp
See also
return the line number represented by this object (public member function) | |
return the column number represented by this object (public member function) | |
return the name of the function represented by this object, if any (public member function) | |
(C++23) |
gets the name of the source file that lexically contains the expression or statement whose evaluation is represented by the stacktrace_entry (public member function of std::stacktrace_entry ) |