How are C++ include guards typically named? I tend to see this a lot:
#ifndef FOO_H
#define FOO_H
// ...
#endif
However, I don't think that's very intuitive. Without seeing the file name it's difficult to tell what FOO_H
is there for and what its name refers to.
What's considered best practice?
I personally follow Boost's recommendation. It's perhaps one of the largest collection of C++ libraries of good quality around and they don't have problem.
It goes like:
<project>_<path_part1>_..._<path_partN>_<file>_<extension>_INCLUDED
// include/pet/project/file.hpp
#ifndef PET_PROJECT_FILE_HPP_INCLUDED
which is:
_[A-Z]
or containing __
is not)INCLUDED
you're spoiling for a fight)I've read about GUID but those look weird.
And obviously I'd rather than all compilers implement #pragma once
(or better, #pragma multiple
and "once" be the default behavior...)