mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 15:52:43 +00:00 
			
		
		
		
	 3f3f45580a
			
		
	
	
		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);
 | |
|     }
 | |
| }
 |