Skip to content

Commit

Permalink
Merge pull request #42 from gabyx/master
Browse files Browse the repository at this point in the history
remove permissions, add move-assign/ctor
  • Loading branch information
graeme-hill authored Dec 20, 2018
2 parents f43d980 + 365aae5 commit 48daf4f
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 20 deletions.
7 changes: 2 additions & 5 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -74,9 +74,7 @@ install(TARGETS crossguid EXPORT crossguidTargets

# Install headers
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/"
DESTINATION ${CROSSGUID_INC_INSTALL_DIR}
FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ WORLD_READ
DIRECTORY_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
DESTINATION ${CROSSGUID_INC_INSTALL_DIR})

# Make cmake config files for all targets
install(EXPORT crossguidTargets
Expand All @@ -85,8 +83,7 @@ install(EXPORT crossguidTargets

# Install readme and license
install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/LICENSE" "${CMAKE_CURRENT_SOURCE_DIR}/README.md"
DESTINATION ${CROSSGUID_ADDITIONAL_FILES_INSTALL_DIR}
PERMISSIONS OWNER_READ GROUP_READ WORLD_READ)
DESTINATION ${CROSSGUID_ADDITIONAL_FILES_INSTALL_DIR})

if (CROSSGUID_TESTS)
add_executable(crossguid-test test/TestMain.cpp test/Test.cpp)
Expand Down
10 changes: 7 additions & 3 deletions include/crossguid/guid.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -53,8 +53,12 @@ class Guid
Guid(const unsigned char *bytes);
Guid(const std::string &fromString);
Guid();
Guid(const Guid &other);
Guid &operator=(const Guid &other);

Guid(const Guid &other) = default;
Guid &operator=(const Guid &other) = default;
Guid(Guid &&other) = default;
Guid &operator=(Guid &&other) = default;

bool operator==(const Guid &other) const;
bool operator!=(const Guid &other) const;

Expand Down Expand Up @@ -105,7 +109,7 @@ namespace std
// Template specialization for std::swap<Guid>() --
// See guid.cpp for the function definition
template <>
void swap(xg::Guid &guid0, xg::Guid &guid1);
void swap(xg::Guid &guid0, xg::Guid &guid1) noexcept;

// Specialization for std::hash<Guid> -- this implementation
// uses std::hash<std::string> on the stringification of the guid
Expand Down
13 changes: 1 addition & 12 deletions src/guid.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -245,23 +245,12 @@ Guid::Guid(const std::string &fromString)
Guid::Guid() : _bytes{ {0} }
{ }

// copy constructor
Guid::Guid(const Guid &other) : _bytes(other._bytes)
{ }

// set all bytes to zero
void Guid::zeroify()
{
std::fill(_bytes.begin(), _bytes.end(), static_cast<unsigned char>(0));
}

// overload assignment operator
Guid &Guid::operator=(const Guid &other)
{
Guid(other).swap(*this);
return *this;
}

// overload equality operator
bool Guid::operator==(const Guid &other) const
{
Expand Down Expand Up @@ -408,7 +397,7 @@ END_XG_NAMESPACE
namespace std
{
template <>
void swap(xg::Guid &lhs, xg::Guid &rhs)
void swap(xg::Guid &lhs, xg::Guid &rhs) noexcept
{
lhs.swap(rhs);
}
Expand Down

0 comments on commit 48daf4f

Please sign in to comment.