mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-08-26 15:22:25 +08:00
Don't allow NULL as an argument to block_scope
block_scope has special behavior when the block is NULL. Remove this and patch up the callers instead.
This commit is contained in:
@ -511,7 +511,7 @@ d_lookup_symbol_nonlocal (const struct language_defn *langdef,
|
|||||||
const domain_enum domain)
|
const domain_enum domain)
|
||||||
{
|
{
|
||||||
struct block_symbol sym;
|
struct block_symbol sym;
|
||||||
const char *scope = block_scope (block);
|
const char *scope = block == nullptr ? "" : block_scope (block);
|
||||||
|
|
||||||
sym = lookup_module_scope (langdef, name, block, domain, scope, 0);
|
sym = lookup_module_scope (langdef, name, block, domain, scope, 0);
|
||||||
if (sym.symbol != NULL)
|
if (sym.symbol != NULL)
|
||||||
|
@ -148,17 +148,16 @@ public:
|
|||||||
{
|
{
|
||||||
struct block_symbol result = {};
|
struct block_symbol result = {};
|
||||||
|
|
||||||
|
const char *scope = block == nullptr ? "" : block_scope (block);
|
||||||
symbol_lookup_debug_printf
|
symbol_lookup_debug_printf
|
||||||
("rust_lookup_symbol_non_local (%s, %s (scope %s), %s)",
|
("rust_lookup_symbol_non_local (%s, %s (scope %s), %s)",
|
||||||
name, host_address_to_string (block), block_scope (block),
|
name, host_address_to_string (block), scope,
|
||||||
domain_name (domain));
|
domain_name (domain));
|
||||||
|
|
||||||
/* Look up bare names in the block's scope. */
|
/* Look up bare names in the block's scope. */
|
||||||
std::string scopedname;
|
std::string scopedname;
|
||||||
if (name[cp_find_first_component (name)] == '\0')
|
if (name[cp_find_first_component (name)] == '\0')
|
||||||
{
|
{
|
||||||
const char *scope = block_scope (block);
|
|
||||||
|
|
||||||
if (scope[0] != '\0')
|
if (scope[0] != '\0')
|
||||||
{
|
{
|
||||||
scopedname = std::string (scope) + "::" + name;
|
scopedname = std::string (scope) + "::" + name;
|
||||||
|
@ -373,7 +373,9 @@ rust_parser::crate_name (const std::string &name)
|
|||||||
std::string
|
std::string
|
||||||
rust_parser::super_name (const std::string &ident, unsigned int n_supers)
|
rust_parser::super_name (const std::string &ident, unsigned int n_supers)
|
||||||
{
|
{
|
||||||
const char *scope = block_scope (pstate->expression_context_block);
|
const char *scope = "";
|
||||||
|
if (pstate->expression_context_block != nullptr)
|
||||||
|
scope = block_scope (pstate->expression_context_block);
|
||||||
int offset;
|
int offset;
|
||||||
|
|
||||||
if (scope[0] == '\0')
|
if (scope[0] == '\0')
|
||||||
|
Reference in New Issue
Block a user