mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-16 03:12:43 +00:00
97f2a2213e
* Move some code outside dbms/src folder * Fix paths
91 lines
2.2 KiB
C++
91 lines
2.2 KiB
C++
#include <string>
|
|
#include <iostream>
|
|
#include <iomanip>
|
|
|
|
#include <Common/Stopwatch.h>
|
|
|
|
#include <Core/Types.h>
|
|
#include <IO/ReadHelpers.h>
|
|
#include <IO/WriteHelpers.h>
|
|
#include <IO/ReadBufferFromFileDescriptor.h>
|
|
#include <IO/WriteBufferFromFileDescriptor.h>
|
|
|
|
#include <common/find_symbols.h>
|
|
|
|
namespace DB
|
|
{
|
|
namespace ErrorCodes
|
|
{
|
|
extern const int CANNOT_PARSE_ESCAPE_SEQUENCE;
|
|
}
|
|
}
|
|
|
|
|
|
namespace test
|
|
{
|
|
static void readEscapedString(DB::String & s, DB::ReadBuffer & buf)
|
|
{
|
|
s = "";
|
|
while (!buf.eof())
|
|
{
|
|
const char * next_pos = find_first_symbols<'\b', '\f', '\n', '\r', '\t', '\0', '\\'>(buf.position(), buf.buffer().end());
|
|
|
|
s.append(buf.position(), next_pos - buf.position());
|
|
buf.position() += next_pos - buf.position();
|
|
|
|
if (!buf.hasPendingData())
|
|
continue;
|
|
|
|
if (*buf.position() == '\t' || *buf.position() == '\n')
|
|
return;
|
|
|
|
if (*buf.position() == '\\')
|
|
{
|
|
++buf.position();
|
|
if (buf.eof())
|
|
throw DB::Exception("Cannot parse escape sequence", DB::ErrorCodes::CANNOT_PARSE_ESCAPE_SEQUENCE);
|
|
s += DB::parseEscapeSequence(*buf.position());
|
|
++buf.position();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
int main(int, char **)
|
|
{
|
|
try
|
|
{
|
|
DB::ReadBufferFromFileDescriptor in(STDIN_FILENO);
|
|
// DB::WriteBufferFromFileDescriptor out(STDOUT_FILENO);
|
|
std::string s;
|
|
size_t rows = 0;
|
|
|
|
Stopwatch watch;
|
|
|
|
while (!in.eof())
|
|
{
|
|
test::readEscapedString(s, in);
|
|
in.ignore();
|
|
|
|
++rows;
|
|
|
|
/* DB::writeEscapedString(s, out);
|
|
DB::writeChar('\n', out);*/
|
|
}
|
|
|
|
watch.stop();
|
|
std::cerr << std::fixed << std::setprecision(2)
|
|
<< "Read " << rows << " rows (" << in.count() / 1000000.0 << " MB) in " << watch.elapsedSeconds() << " sec., "
|
|
<< rows / watch.elapsedSeconds() << " rows/sec. (" << in.count() / watch.elapsedSeconds() / 1000000 << " MB/s.)"
|
|
<< std::endl;
|
|
}
|
|
catch (const DB::Exception & e)
|
|
{
|
|
std::cerr << e.what() << ", " << e.displayText() << std::endl;
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|