// 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 #include "toolchain/lexer/lex_helpers.h" #include "llvm/Support/FormatVariadic.h" namespace Carbon { namespace { struct TooManyDigits : DiagnosticBase { static constexpr llvm::StringLiteral ShortName = "syntax-invalid-number"; auto Format() -> std::string { return llvm::formatv( "Found a sequence of {0} digits, which is greater than the " "limit of {1}.", count, limit) .str(); } size_t count; size_t limit; }; } // namespace auto CanLexInteger(DiagnosticEmitter& emitter, llvm::StringRef text) -> bool { // llvm::getAsInteger is used for parsing, but it's quadratic and visibly slow // on large integer values. This limit exists to avoid hitting those limits. // Per https://github.com/carbon-language/carbon-lang/issues/980, it may be // feasible to optimize integer parsing in order to address performance if // this limit becomes an issue. // // 2^128 would be 39 decimal digits or 128 binary. In either case, this limit // is far above the threshold for normal integers. constexpr size_t DigitLimit = 1000; if (text.size() > DigitLimit) { emitter.EmitError( text.begin(), {.count = text.size(), .limit = DigitLimit}); return false; } return true; } } // namespace Carbon