forked from carbon-language/carbon-lang
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsource_buffer.h
102 lines (84 loc) · 3.84 KB
/
source_buffer.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// Part of the Carbon Language project, under the Apache License v2.0 with LLVM
// Exceptions. See /LICENSE for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
#ifndef CARBON_TOOLCHAIN_SOURCE_SOURCE_BUFFER_H_
#define CARBON_TOOLCHAIN_SOURCE_SOURCE_BUFFER_H_
#include <memory>
#include <string>
#include "llvm/ADT/StringRef.h"
#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Support/VirtualFileSystem.h"
#include "toolchain/diagnostics/diagnostic_emitter.h"
namespace Carbon {
// A buffer of Carbon source code.
//
// This class holds a buffer of Carbon source code as text and makes it
// available for use in the rest of the Carbon compiler. It owns the memory for
// the underlying source code text and ensures it lives as long as the buffer
// objects.
//
// Every buffer of source code text is notionally loaded from a Carbon source
// file, even if provided directly when constructing the buffer. The name that
// should be used for that Carbon source file is also retained and made
// available.
//
// Because the underlying memory for the source code text may have been read
// from a file, and we may want to use facilities like `mmap` to simply map that
// file into memory, the buffer itself is not copyable to avoid needing to
// define copy semantics for a mapped file. We can relax this restriction with
// some implementation complexity in the future if needed.
class SourceBuffer {
public:
// Opens and reads the contents of stdin. Returns a SourceBuffer on success.
// Prints an error and returns nullopt on failure.
static auto MakeFromStdin(DiagnosticConsumer& consumer)
-> std::optional<SourceBuffer>;
// Opens the requested file. Returns a SourceBuffer on success. Prints an
// error and returns nullopt on failure.
static auto MakeFromFile(llvm::vfs::FileSystem& fs, llvm::StringRef filename,
DiagnosticConsumer& consumer)
-> std::optional<SourceBuffer>;
// Handles conditional use of stdin based on the filename being "-".
static auto MakeFromFileOrStdin(llvm::vfs::FileSystem& fs,
llvm::StringRef filename,
DiagnosticConsumer& consumer)
-> std::optional<SourceBuffer> {
if (filename == "-") {
return MakeFromStdin(consumer);
} else {
return MakeFromFile(fs, filename, consumer);
}
}
// Returns a source buffer with the provided text content. Copies `filename`
// and `text` to take ownership.
static auto MakeFromStringCopy(llvm::StringRef filename, llvm::StringRef text,
DiagnosticConsumer& consumer)
-> std::optional<SourceBuffer>;
// Use one of the factory functions above to create a source buffer.
SourceBuffer() = delete;
auto filename() const -> llvm::StringRef { return filename_; }
auto text() const -> llvm::StringRef { return text_->getBuffer(); }
[[nodiscard]] auto is_regular_file() const -> bool {
return is_regular_file_;
}
private:
// Creates a `SourceBuffer` from the given `llvm::MemoryBuffer`. Prints an
// error and returns nullopt on failure.
static auto MakeFromMemoryBuffer(
llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> buffer,
llvm::StringRef filename, bool is_regular_file,
DiagnosticConsumer& consumer) -> std::optional<SourceBuffer>;
explicit SourceBuffer(std::string filename,
std::unique_ptr<llvm::MemoryBuffer> text,
bool is_regular_file)
: filename_(std::move(filename)),
text_(std::move(text)),
is_regular_file_(is_regular_file) {}
std::string filename_;
std::unique_ptr<llvm::MemoryBuffer> text_;
// Whether this buffer is a regular file, rather than stdin or a named pipe or
// similar.
bool is_regular_file_;
};
} // namespace Carbon
#endif // CARBON_TOOLCHAIN_SOURCE_SOURCE_BUFFER_H_