У меня есть код вроде этого
std::ifstream file(filename, std::ios_base::in);
if(file.good())
{
file.imbue(std::locale(std::locale(), new delimeter_tokens()));
for(auto& entry : std::istream_iterator<std::string>(file))
{
std::cout << entry << std::endl;
}
}
file.close();
где std::istream_iterator<std::string>
begin()
и end()
определяются следующим образом:
template<class T>
std::istream_iterator<T> begin(std::istream_iterator<T>& stream)
{
return stream;
}
template<class T>
std::istream_iterator<T> end(std::istream_iterator<T>& stream)
{
return std::istream_iterator<T>();
}
что и есть Mark Nelson в д-р Добб здесь. Увы, код не скомпилируется на моей Visual Studio 2012 с сообщениями об ошибках
ошибка C3312: не найдено вызываемой функции "begin" для типа 'std:: istream_iterator < _Ty > '
и
ошибка C3312: не найдена функция 'end' для вызываемого типа 'std:: istream_iterator < _Ty > '
Вопрос: Есть ли что-то, чего я не заметил, ошибка в компиляторе (маловероятно, но на всякий случай) или... Ну, любые идеи?
Эти вопросы убираются значительно, как советовали Xeo. Чтобы предоставить дополнительные сведения и ссылки, связанные с моим другим вопросом в Stackoverflow, мне было интересно, как сделать синтаксический анализ на основе строк более чистым, чем обычные циклы. Немного кодирования и проверки из Интернета, и у меня был рабочий эскиз следующим образом
std::ifstream file(filename, std::ios_base::in);
if(file.good())
{
file.imbue(std::locale(std::locale(), new delimeter_tokens()));
for(auto& entry : istream_range<std::string>(file)
{
std::cout << entry << std::endl;
}
}
file.close();
но была небольшая ошибка, которую я пытался исправить. Я думаю, что было бы более естественно писать, как в коде, который не компилируется, а не нравится
for(auto& entry : istream_range<std::string>(file)
Пожалуйста, обратите внимание на другой итератор. delimeter_tokens определяется как Nawaz любезно показал здесь (код не дублируется) и istream_range, как в блоге Code Synthesis здесь. Я думаю, что начальная и конечная реализации должны работать, как описано в вышеупомянутом блоге блога Code Synthesis.
Последнее правило (возврат к автономным функциям begin() и end()) позволяет нам неинвазивно адаптировать существующий контейнер для интерфейса на основе диапазона.
Таким образом, мой вопрос со всем (ir) соответствующим фоном.