Made is_palindrome work for C++03

This commit is contained in:
Marshall Clow
2016-08-17 13:49:16 -07:00
parent 18bcbba8f4
commit f1e9d3140c
2 changed files with 13 additions and 16 deletions

View File

@ -17,7 +17,6 @@
#include <iterator> #include <iterator>
#include <functional> #include <functional>
#include <type_traits>
#include <cstring> #include <cstring>
#include <boost/range/begin.hpp> #include <boost/range/begin.hpp>
@ -134,10 +133,8 @@ bool is_palindrome(const R& range, Predicate p)
/// Complexity: O(N). /// Complexity: O(N).
bool is_palindrome(const char* str) bool is_palindrome(const char* str)
{ {
if(str == nullptr) if(!str)
{ return true;
return true;
}
return is_palindrome(str, str + strlen(str)); return is_palindrome(str, str + strlen(str));
} }
@ -154,10 +151,8 @@ bool is_palindrome(const char* str)
template<typename Predicate> template<typename Predicate>
bool is_palindrome(const char* str, Predicate p) bool is_palindrome(const char* str, Predicate p)
{ {
if(str == nullptr) if(!str)
{ return true;
return true;
}
return is_palindrome(str, str + strlen(str), p); return is_palindrome(str, str + strlen(str), p);
} }

View File

@ -38,6 +38,8 @@ struct functorComparator
} }
}; };
#define Begin(arr) (arr)
#define End(arr) (arr+(sizeof(arr)/(sizeof(arr[0]))))
void test_is_palindrome() void test_is_palindrome()
{ {
@ -47,26 +49,26 @@ void test_is_palindrome()
const int oddPalindrome[] = {1,2,3,2,1}; const int oddPalindrome[] = {1,2,3,2,1};
const int evenPalindrome[] = {1,2,2,1}; const int evenPalindrome[] = {1,2,2,1};
int evenNonPalindrome[] = {1,4,8,8}; int evenNonPalindrome[] = {1,4,8,8};
const char* stringNullPtr = nullptr; const char* stringNullPtr = NULL;
// Test a default operator== // Test a default operator==
BOOST_CHECK ( ba::is_palindrome(empty)); BOOST_CHECK ( ba::is_palindrome(empty));
BOOST_CHECK ( ba::is_palindrome(singleElement)); BOOST_CHECK ( ba::is_palindrome(singleElement));
BOOST_CHECK (!ba::is_palindrome(std::begin(oddNonPalindrome), std::end(oddNonPalindrome))); BOOST_CHECK (!ba::is_palindrome(Begin(oddNonPalindrome), End(oddNonPalindrome)));
BOOST_CHECK ( ba::is_palindrome(std::begin(oddPalindrome), std::end(oddPalindrome))); BOOST_CHECK ( ba::is_palindrome(Begin(oddPalindrome), End(oddPalindrome)));
BOOST_CHECK ( ba::is_palindrome(std::begin(evenPalindrome), std::end(evenPalindrome))); BOOST_CHECK ( ba::is_palindrome(Begin(evenPalindrome), End(evenPalindrome)));
BOOST_CHECK (!ba::is_palindrome(std::begin(evenNonPalindrome), std::end(evenNonPalindrome))); BOOST_CHECK (!ba::is_palindrome(Begin(evenNonPalindrome), End(evenNonPalindrome)));
//Test the custom comparators //Test the custom comparators
BOOST_CHECK ( ba::is_palindrome(empty.begin(), empty.end(), functorComparator())); BOOST_CHECK ( ba::is_palindrome(empty.begin(), empty.end(), functorComparator()));
BOOST_CHECK (!ba::is_palindrome(std::begin(oddNonPalindrome), std::end(oddNonPalindrome), funcComparator<int>)); BOOST_CHECK (!ba::is_palindrome(Begin(oddNonPalindrome), End(oddNonPalindrome), funcComparator<int>));
BOOST_CHECK ( ba::is_palindrome(evenPalindrome, std::equal_to<int>())); BOOST_CHECK ( ba::is_palindrome(evenPalindrome, std::equal_to<int>()));
//Test C-strings like cases //Test C-strings like cases
BOOST_CHECK ( ba::is_palindrome(stringNullPtr)); BOOST_CHECK ( ba::is_palindrome(stringNullPtr));
BOOST_CHECK ( ba::is_palindrome("")); BOOST_CHECK ( ba::is_palindrome(""));
BOOST_CHECK ( ba::is_palindrome("a")); BOOST_CHECK ( ba::is_palindrome("a"));
BOOST_CHECK ( ba::is_palindrome("abacaba"), std::equal_to<char>()); BOOST_CHECK ( ba::is_palindrome("abacaba", std::equal_to<char>()));
BOOST_CHECK ( ba::is_palindrome("abba")); BOOST_CHECK ( ba::is_palindrome("abba"));
BOOST_CHECK (!ba::is_palindrome("acab")); BOOST_CHECK (!ba::is_palindrome("acab"));
} }