compare_array_less_impl.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /************************************************************************************
  2. * *
  3. * Copyright (c) 2014 - 2018 Axel Menzel <info@rttr.org> *
  4. * *
  5. * This file is part of RTTR (Run Time Type Reflection) *
  6. * License: MIT License *
  7. * *
  8. * Permission is hereby granted, free of charge, to any person obtaining *
  9. * a copy of this software and associated documentation files (the "Software"), *
  10. * to deal in the Software without restriction, including without limitation *
  11. * the rights to use, copy, modify, merge, publish, distribute, sublicense, *
  12. * and/or sell copies of the Software, and to permit persons to whom the *
  13. * Software is furnished to do so, subject to the following conditions: *
  14. * *
  15. * The above copyright notice and this permission notice shall be included in *
  16. * all copies or substantial portions of the Software. *
  17. * *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
  21. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, *
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE *
  24. * SOFTWARE. *
  25. * *
  26. *************************************************************************************/
  27. #ifndef RTTR_COMPARE_ARRAY_LESS_IMPL_H_
  28. #define RTTR_COMPARE_ARRAY_LESS_IMPL_H_
  29. #include "rttr/detail/base/core_prerequisites.h"
  30. #include "rttr/detail/misc/misc_type_traits.h"
  31. #include "rttr/detail/comparison/compare_less.h"
  32. #include <type_traits>
  33. #include <cstring>
  34. namespace rttr
  35. {
  36. namespace detail
  37. {
  38. /////////////////////////////////////////////////////////////////////////////////////////
  39. template<typename ElementType>
  40. struct compare_array_less_impl
  41. {
  42. int operator()(const ElementType &lhs, const ElementType &rhs)
  43. {
  44. int result = 0;
  45. compare_less_than(lhs, rhs, result);
  46. return result;
  47. }
  48. };
  49. /////////////////////////////////////////////////////////////////////////////////////////
  50. template<typename ElementType, std::size_t Count>
  51. struct compare_array_less_impl<ElementType[Count]>
  52. {
  53. int operator()(const ElementType (&lhs)[Count], const ElementType (&rhs)[Count])
  54. {
  55. int flag = 0;
  56. for(std::size_t i = 0; i < Count; ++i)
  57. {
  58. if ((flag = compare_array_less_impl<ElementType>()(lhs[i], rhs[i])) != 0)
  59. return flag;
  60. }
  61. return 0;
  62. }
  63. };
  64. /////////////////////////////////////////////////////////////////////////////////////////
  65. template<typename ElementType, std::size_t Count>
  66. RTTR_INLINE bool compare_array_less(const ElementType (&lhs)[Count], const ElementType (&rhs)[Count])
  67. {
  68. if (compare_array_less_impl<ElementType[Count]>()(lhs, rhs) == -1)
  69. return true;
  70. return false;
  71. }
  72. /////////////////////////////////////////////////////////////////////////////////////////
  73. } // end namespace detail
  74. } // end namespace rttr
  75. #endif // RTTR_COMPARE_ARRAY_LESS_IMPL_H_