Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

C++11-ify NonCopyable #12571

Merged
merged 1 commit into from
Mar 12, 2020
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 9 additions & 11 deletions platform/NonCopyable.h
Original file line number Diff line number Diff line change
Expand Up @@ -91,18 +91,16 @@ namespace mbed {
* in the base declaration.
*
* To solve that problem, the copy constructor and assignment operator have to
* be declared (but don't need to be defined) in the private section of the
* Connection class:
* be defined as deleted:
*
* @code
* struct Connection {
* private:
* Connection(const Connection&);
* Connection& operator=(const Connection&);
* Connection(const Connection &) = delete;
* Connection &operator=(const Connection &) = delete;
* }
* @endcode
*
* Although manually declaring private copy constructor and assignment functions
* Although manually defining deleted copy constructor and assignment functions
* works, it is not ideal. These declarations are usually easy to forget,
* not immediately visible, and may be obscure to uninformed programmers.
*
Expand Down Expand Up @@ -211,18 +209,18 @@ class NonCopyable {
}

#else
private:
public:
/**
* Declare copy constructor as private. Any attempt to copy construct
* Define copy constructor as deleted. Any attempt to copy construct
* a NonCopyable will fail at compile time.
*/
NonCopyable(const NonCopyable &);
NonCopyable(const NonCopyable &) = delete;

/**
* Declare copy assignment operator as private. Any attempt to copy assign
* Define copy assignment operator as deleted. Any attempt to copy assign
* a NonCopyable will fail at compile time.
*/
NonCopyable &operator=(const NonCopyable &);
NonCopyable &operator=(const NonCopyable &) = delete;
#endif
#endif
};
Expand Down