2

我正在为文本编辑器创建一个不缩进算法。我设法获得了要操作的范围,但是当我想做 Gtk::TextBuffer::erase 时,它​​失败了:

void unindentSelection(const Glib::RefPtr<Gtk::TextBuffer> &buffer)
{
    Gtk::TextBuffer::iterator start, end;

    buffer->get_selection_bounds(start, end);

    auto selRange = boost::make_iterator_range(start, end);
    auto buffRange = boost::make_iterator_range(buffer->begin(), buffer->end());

    auto prevRangeRev = boost::make_iterator_range(buffRange.begin(), selRange.begin()) | boost::adaptors::reversed;
    auto prevRangeLineRev = boost::find<boost::return_begin_found>(prevRangeRev, '\n');
    auto prevRangeLine = prevRangeLineRev | boost::adaptors::reversed;

    auto afterRange = boost::make_iterator_range(selRange.end(), buffRange.end());
    auto afterRangeLine = boost::find<boost::return_begin_found>(afterRange, '\n');

    auto exSelRangeAux = boost::join(prevRangeLine, selRange);
    auto exSelRange = boost::join(exSelRangeAux, afterRangeLine);

    show_range(exSelRange);

    while (true)
    {
        auto spaceRange = boost::find_if<boost::return_begin_found>(exSelRange, findNonspaceNL);

        if (boost::distance(spaceRange))
        {
            buffer->erase(spaceRange.begin(), spaceRange.end());
        }
    }
}

TextEditor.cpp:501:31: 错误: 从 'boost::range_detail::join_iterator >, Gtk::TextIter, unsigned int, unsigned int, boost::iterators::bidirectional_traversal_tag>, Gtk::TextIter, unsigned 没有可行的转换int, unsigned int, boost::iterators::bidirectional_traversal_tag>' to 'const iterator' (aka 'const Gtk::TextIter') buffer->erase(spaceRange.begin(), afterRangeLine.end()); ^~~~~~~~~~~~~~~~~~ /usr/include/gtkmm-3.0/gtkmm/textiter.h:145:7:注意:候选构造函数(隐式复制构造函数)不可行:没有从 'boost::range_detail::join_iterator >、Gtk::TextIter、unsigned int、unsigned int、boost::iterators::bidirectional_traversal_tag>、Gtk::TextIter、unsigned int、unsigned int、boost::iterators 的已知转换: :bidirectional_traversal_tag>

有任何想法吗?

4

1 回答 1

1

我必须使用'boost::iterator_facade'创建一个迭代器类型,其中包含一个模板化的'Iterator it'(在我的例子中是Gtk::TextIter)。转发给“it”的迭代器的所有操作,除了 operator*(),它只是给出了普通的迭代器。所以擦除是这样完成的:

buffer->erase(*spaceRange.begin(), *spaceRange.end());

这种新类型的迭代器将非常有用的操作范围。不确定这是最好的解决方案,但有效。

于 2015-07-27T22:31:29.540 回答