observer-ptr is a single-file header-only library with a variant of std::experimental::observer_ptr [1] for C++98 and later.
Contents
- Example usage
- In a nutshell
- License
- Dependencies
- Installation
- Building the tests
- Synopsis
- Other open source implementations
- Notes and references
- Appendix
#include "nonstd/observer_ptr.hpp"
using namespace nonstd;
void use( observer_ptr<int> p )
{
assert( *p == 42 );
}
int main()
{
int a = 42;
observer_ptr<int> p( &a );
use( p );
}
prompt>g++ -std=c++03 -Wall -I../include -o 01-basic.exe 01-basic.cpp && 01-basic.exe
observer-ptr is an implementation of the world’s dumbest smart pointer for C++98 and higher. It takes no ownership responsibility for the object it observes or watches and is intended as a near drop-in replacement for raw pointer types. As a vocabulary type it indicates intended use, easing code reading (Note 1).
Class template observer_ptr<>
has been proposed for inclusion into the C++ standard [1] and is part of Extensions for Library Fundamentals v2/v3 [2][3].
The observer-ptr of this project can be used with probably any clang, g++ or MSVC compiler. It has been tested with clang 3.4, g++ 5.2 and with VC6 (VS6, no comparison of observers), VC8 (VS2005), VC10 (VS2010), VC11 (VS2012), VC12 (VS2013), VC14 (VS2015).
observer-ptr is distributed under the Boost Software License.
observer-ptr has no other dependencies than the C++ standard library.
observer-ptr is a single-file header-only library. Put observer_ptr.h in the include folder directly into the project source tree or somewhere reachable from your project.
To build the tests you need:
- CMake, version 2.8.7 or later to be installed and in your PATH.
- A suitable compiler.
The lest test framework is included in the test folder.
The following steps assume that the observer-ptr source code has been cloned into a directory named c:\observer-ptr
.
-
Create a directory for the build outputs for a particular architecture.
Here we use c:\observer-ptr\build-win-x86-vc10.cd c:\observer-ptr md build-win-x86-vc10 cd build-win-x86-vc10
-
Configure CMake to use the compiler of your choice (run
cmake --help
for a list).cmake -G "Visual Studio 10 2010" ..
-
Build the test suite in the Debug configuration (alternatively use Release).
cmake --build . --config Debug
-
Run the test suite.
ctest -V -C Debug
All tests should pass, indicating your platform is supported and you are ready to use observer-ptr.
Contents
Documentation of std::experimental::observer_ptr
Configuration macros
Depending on the compiler and C++-standard used, nonstd::observer_ptr
behaves less or more like std::experimental::observer_ptr
. To get an idea of the capabilities of nonstd::observer_ptr
with your configuration, look at the output of the tests, issuing observer_ptr-main.t --pass @
. For std::experimental::observer_ptr
, see its documentation at cppreference [5].
-Dnsop_CPLUSPLUS=199711L
Define this macro to override the auto-detection of the supported C++ standard, or if your compiler does not set the __cplusplus
macro correctly.
At default, observer-ptr lite uses std::experimental::observer_ptr
if it is available and lets you use it via namespace nonstd
. You can however override this default and explicitly request to use std::experimental::observer_ptr
or observer-ptr lite's nonstd::observer_ptr
as nonstd::observer_ptr
via the following macros.
-Dnsop_CONFIG_SELECT_OBSERVER_PTR=nsop_OBSERVER_PTR_DEFAULT
Define this to nsop_OBSERVER_PTR_STD
to select std::experimental::observer_ptr
as nonstd::observer_ptr
. Define this to nsop_OBSERVER_PTR_NONSTD
to select nonstd::observer_ptr
as nonstd::observer_ptr
. Default is undefined, which has the same effect as defining to nsop_OBSERVER_PTR_DEFAULT
.
-Dnsop_CONFIG_ALLOW_IMPLICIT_CONVERSION_FROM_SMART_PTR=0
Allow implicit conversion from std::unique_ptr
and std::shared_ptr
. This is an extension to the proposal. Each of these implicit conversions can also be activated separately, see below. Default is 0.
-Dnsop_CONFIG_ALLOW_IMPLICIT_CONVERSION_FROM_UNIQUE_PTR=0
Allow implicit conversion from std::unique_ptr
. This is an extension to the proposal. Default is 0.
-Dnsop_CONFIG_ALLOW_IMPLICIT_CONVERSION_FROM_SHARED_PTR=0
Allow implicit conversion from std::shared_ptr
. This is an extension to the proposal. Default is 0.
-Dnsop_CONFIG_ALLOW_IMPLICIT_CONVERSION_TO_UNDERLYING_TYPE=0
The proposed observer_ptr
provides explicit conversions to bool
and to the underlying type. Explicit conversion is not available from pre-C++11 compilers. To prevent problems due to unexpected implicit conversions to bool
or to the underlying type, this library does not provide these implicit conversions at default. If you still want them, define this macro to 1. Without these implicit conversions enabled, a conversion to bool via the safe bool idiom is provided. Default is 0.
-Dnsop_CONFIG_CONFIRMS_COMPILATION_ERRORS=0
Define this macro to 1 to experience the by-design compile-time errors of the observer-ptr components in the test suite. Default is 0.
- Anthony Williams. object_ptr - a safer replacement for raw pointers (Boost License).
- Mário Feroldi. observer_ptr implementation in C++17 (Library Fundamentals TS v2) (MIT License).
- Joseph Thomson. observer and optional_ref for the Guideline Support Library (MIT License).
Note 1. This conclusion may be challenged if the coding style ensures that any raw pointer is a non-owning pointer [4].
[1] Walter E. Brown. N3840: A Proposal for the World’s Dumbest Smart Pointer, v4 (v1, v2, v3, v4 (PDF). 19 December 2012 - 7 November 2014.
[2] N4481: Tentative Working Draft, C++ Extensions for Library Fundamentals, Version 2, Section 4.2 Non-owning pointers. 12 April 2015.
[3] N4758: Working Draft, C++ Extensions for Library Fundamentals, Version 3, Section 5.2 Non-owning pointers. 13 November 2018.
[4] Bjarne Stroustrup. P1408: Abandon observer_ptr. 4 January 2018.
[5] ISO C++ Standard - Future Proposals. shared_ptr and unique_ptr should both implicitly convert to observer_ptr. 24 October 2018.
[6] Joseph Thomson. Pointers and the C++ Core Guidelines. 9 February 2017.
[7] C++ Core Guidelines. Issue 847: Pointers and the C++ Core Guidelines. 9 February 2017.
[8] Boost developers' mailing list. Is there any interest in non-owning pointer-like types? 1 February 2017.
[9] cppreference.com. std::experimental::observer_ptr.
The version of observer-ptr lite is available via tag [.version]
. The following tags are available for information on the compiler and on the C++ standard library used: [.compiler]
, [.stdc++]
, [.stdlanguage]
and [.stdlibrary]
.
Disallows to delete the observer_ptr unless implicit conversion allowed
Disallows construction from an observer_ptr of incompatible type
Disallows implicit conversion to bool unless implicit conversion allowed
Disallows implicit conversion to underlying type unless implicit conversion allowed
Disallows comparison to an observer_ptr with a different underlying type
Allows default construction
Allows construction from nullptr
Allows construction from a non-null pointer
Allows construction from an observer_ptr of compatible type
Allows implicit move-construction from a std::unique_ptr<> [smart-ptr][extension]
Allows implicit construction from a std::shared_ptr<> [smart-ptr][extension]
Allows to retrieve the pointer
Allows to retrieve the value pointed to
Allows to retrieve the member pointed to
Allows to test for a non-null pointer via conversion to bool
Allows to convert to the observed pointer [underlying-type][extension]
Allows to release to stop observing
Allows to reset to stop observing
Allows to reset to observe another pointer
Allows to swap two observers
Specialized: Allows to swap two observers
Specialized: Allows to make an observer
Specialized: Allows to compare if an observer is equal to another observer
Specialized: Allows to compare if an observer is equal to another observer with a related watched type
Specialized: Allows to compare if an observer is not equal to another observer
Specialized: Allows to compare if an observer is not equal to another observer with a related watched type
Specialized: Allows to compare if an observer is equal to nullptr
Specialized: Allows to compare if an observer is not equal to nullptr
Specialized: Allows to compare if an observer is less than another observer
Specialized: Allows to compare if an observer is less than another observer with a related watched type
Specialized: Allows to compare if an observer is less than or equal to another observer
Specialized: Allows to compare if an observer is less than or equal to another observer with a related watched type
Specialized: Allows to compare if an observer is greater than another observer
Specialized: Allows to compare if an observer is greater than another observer with a related watched type
Specialized: Allows to compare if an observer is greater than or equal to another observer
Specialized: Allows to compare if an observer is greater than or equal to another observer with a related watched type
Specialized: Allows to compute hash