mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-26 17:40:27 +00:00
3f3f45580a
Each of these strings would previously rely on StringView's char const* constructor overload, which would call __builtin_strlen on the string. Since we now have operator ""sv, we can replace these with much simpler versions. This opens the door to being able to remove StringView(char const*). No functional changes.
80 lines
2.3 KiB
C++
80 lines
2.3 KiB
C++
/*
|
|
* Copyright (c) 2021, Itamar S. <itamar8910@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/LexicalPath.h>
|
|
#include <LibCore/DirIterator.h>
|
|
#include <LibCore/Stream.h>
|
|
#include <LibCpp/Parser.h>
|
|
#include <LibTest/TestCase.h>
|
|
#include <unistd.h>
|
|
|
|
constexpr char TESTS_ROOT_DIR[] = "/home/anon/Tests/cpp-tests/parser";
|
|
|
|
static String read_all(String const& path)
|
|
{
|
|
auto file = MUST(Core::Stream::File::open(path, Core::Stream::OpenMode::Read));
|
|
auto file_size = MUST(file->size());
|
|
auto content = MUST(ByteBuffer::create_uninitialized(file_size));
|
|
if (!file->read_or_error(content.bytes()))
|
|
VERIFY_NOT_REACHED();
|
|
return String { content.bytes() };
|
|
}
|
|
|
|
TEST_CASE(test_regression)
|
|
{
|
|
Core::DirIterator directory_iterator(TESTS_ROOT_DIR, Core::DirIterator::Flags::SkipDots);
|
|
|
|
while (directory_iterator.has_next()) {
|
|
auto file_path = directory_iterator.next_full_path();
|
|
|
|
auto path = LexicalPath { file_path };
|
|
if (!path.has_extension(".cpp"sv))
|
|
continue;
|
|
|
|
outln("Checking {}...", path.basename());
|
|
|
|
auto ast_file_path = String::formatted("{}.ast", file_path.substring(0, file_path.length() - sizeof(".cpp") + 1));
|
|
|
|
auto source = read_all(file_path);
|
|
auto target_ast = read_all(ast_file_path);
|
|
|
|
StringView source_view(source);
|
|
Cpp::Preprocessor preprocessor(file_path, source_view);
|
|
Cpp::Parser parser(preprocessor.process_and_lex(), file_path);
|
|
auto root = parser.parse();
|
|
|
|
EXPECT(parser.errors().is_empty());
|
|
|
|
int pipefd[2] = {};
|
|
if (pipe(pipefd) < 0) {
|
|
perror("pipe");
|
|
exit(1);
|
|
}
|
|
|
|
FILE* input_stream = fdopen(pipefd[0], "r");
|
|
FILE* output_stream = fdopen(pipefd[1], "w");
|
|
|
|
root->dump(output_stream);
|
|
|
|
fclose(output_stream);
|
|
|
|
ByteBuffer buffer;
|
|
while (!feof(input_stream)) {
|
|
char chunk[4096];
|
|
size_t size = fread(chunk, sizeof(char), sizeof(chunk), input_stream);
|
|
if (size == 0)
|
|
break;
|
|
buffer.append(chunk, size);
|
|
}
|
|
|
|
fclose(input_stream);
|
|
|
|
String content { reinterpret_cast<char const*>(buffer.data()), buffer.size() };
|
|
|
|
auto equal = content == target_ast;
|
|
EXPECT(equal);
|
|
}
|
|
}
|