Улучшенная компиляция диапазона нескольких массивов - PullRequest
5 голосов
/ 07 июля 2011

Диапазон может использоваться для нарезки многомерного массива Boost (multi_array). Согласно документации существует несколько способов определения диапазона, однако не все из них будут компилироваться. Я использую GCC 4.5.2 в Ubuntu 11.04.

#include <boost/multi_array.hpp>

int main() {
    typedef boost::multi_array_types::index_range range;
    range a_range;   

    // indices i where 3 <= i

    // Does compile
    a_range = range().start(3);

    // Does not compile
    a_range = 3 <= range();
    a_range = 2 < range();

    return 0;
}

Вывод компилятора:

ma.cpp: In function ‘int main()’:
ma.cpp:9:26: error: no match for ‘operator<=’ in ‘3 <= boost::detail::multi_array::index_range<long int, long unsigned int>()’
ma.cpp:10:25: error: no match for ‘operator<’ in ‘2 < boost::detail::multi_array::index_range<long int, long unsigned int>()’

Есть идеи, как мне это скомпилировать или чего не хватает?

1 Ответ

5 голосов
/ 07 июля 2011

Вызванные здесь operator< и operator<= являются шаблонами; следовательно, значение, предоставляемое указанным операторам для аргумента Index, должно быть точно такого же типа, что и параметр шаблона Index передаваемого диапазона.

Тип boost::multi_array_types::index_range::index в конечном итоге сводится к typedef для std::ptrdiff_t; учитывая, что вы предоставляете int литералов, явно для вашей платформы / конфигурации, std::ptrdiff_t является typedef для некоторого типа, отличного от int (согласно вашим сообщениям об ошибках это long).

Переносимое исправление заключается в приведении ваших литералов к нужному типу:

#include <boost/multi_array.hpp>

int main()
{
    typedef boost::multi_array_types::index_range range;
    typedef range::index index;

    range a_range;
    a_range = index(3) <= range();
    a_range = index(2) < range();

    index i(1);
    a_range = i <= range();
}
...