diff options
| author | jsmall-nvidia <jsmall@nvidia.com> | 2021-02-12 14:31:56 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-02-12 14:31:56 -0500 |
| commit | 369279e91dde1b056d8d0e3bb83e7ba3f96321af (patch) | |
| tree | b94af28f1aed8aa57dcb15d039d9dcd739a1534e /source/core | |
| parent | cd79bfb5495db14afa167049ccf8e9f4612c5bc2 (diff) | |
Diagnostic location highlighting (#1700)
* #include an absolute path didn't work - because paths were taken to always be relative.
* WIP: First pass in supporting output of line error information.
* Add support for lexing to better be able to indicate SourceLocation information.
* Fix lexer usage in DiagnosticSink in C++ extractor.
* Update diagnostics tests to have line location info.
* Fixed test expected output that now have source location information in them.
* Better handling of tab.
* Fix test expected results for tabbing change.
* DiagnosticLexer -> DiagnosticSink::SourceLocationLexer
Added line continuation tests.
* Fix typo.
* Added String::appendRepeatedChar
* Change to rerun tests.
Co-authored-by: Tim Foley <tfoleyNV@users.noreply.github.com>
Diffstat (limited to 'source/core')
| -rw-r--r-- | source/core/slang-string.cpp | 12 | ||||
| -rw-r--r-- | source/core/slang-string.h | 7 |
2 files changed, 19 insertions, 0 deletions
diff --git a/source/core/slang-string.cpp b/source/core/slang-string.cpp index 4b1ec4c84..a7374d8ba 100644 --- a/source/core/slang-string.cpp +++ b/source/core/slang-string.cpp @@ -362,6 +362,18 @@ namespace Slang } } + void String::appendRepeatedChar(char chr, Index count) + { + SLANG_ASSERT(count >= 0); + if (count > 0) + { + char* chars = prepareForAppend(count); + // Set all space to repeated chr. + ::memset(chars, chr, sizeof(char) * count); + appendInPlace(chars, count); + } + } + void String::appendChar(char c) { const auto oldLength = getLength(); diff --git a/source/core/slang-string.h b/source/core/slang-string.h index e57718d40..3fb184ac7 100644 --- a/source/core/slang-string.h +++ b/source/core/slang-string.h @@ -100,6 +100,10 @@ namespace Slang { return slice.m_begin >= m_begin && slice.m_end <= m_end; } + bool isMemoryContained(const char* pos) const + { + return pos >= m_begin && pos <= m_end; + } Index getLength() const { @@ -439,6 +443,9 @@ namespace Slang /// Append a character (to remove ambiguity with other integral types) void appendChar(char chr); + /// Append the specified char count times + void appendRepeatedChar(char chr, Index count); + String(const char* str) { append(str); |
