|  | /* Symbol domains  -*- c++ -*- | 
|  |  | 
|  | Copyright (C) 2023 Free Software Foundation, Inc. | 
|  |  | 
|  | This file is part of GDB. | 
|  |  | 
|  | This program is free software; you can redistribute it and/or modify | 
|  | it under the terms of the GNU General Public License as published by | 
|  | the Free Software Foundation; either version 3 of the License, or | 
|  | (at your option) any later version. | 
|  |  | 
|  | This program is distributed in the hope that it will be useful, | 
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | GNU General Public License for more details. | 
|  |  | 
|  | You should have received a copy of the GNU General Public License | 
|  | along with this program.  If not, see <http://www.gnu.org/licenses/>.  */ | 
|  |  | 
|  | /* UNDEF_DOMAIN is used when a domain has not been discovered or | 
|  | none of the following apply.  This usually indicates an error either | 
|  | in the symbol information or in gdb's handling of symbols.  */ | 
|  |  | 
|  | SYM_DOMAIN (UNDEF) | 
|  |  | 
|  | /* VAR_DOMAIN is the usual domain.  In C, this contains variables, | 
|  | function names, typedef names and enum type values.  */ | 
|  |  | 
|  | SYM_DOMAIN (VAR) | 
|  |  | 
|  | /* STRUCT_DOMAIN is used in C to hold struct, union and enum type names. | 
|  | Thus, if `struct foo' is used in a C program, it produces a symbol named | 
|  | `foo' in the STRUCT_DOMAIN.  */ | 
|  |  | 
|  | SYM_DOMAIN (STRUCT) | 
|  |  | 
|  | /* MODULE_DOMAIN is used in Fortran to hold module type names.  */ | 
|  |  | 
|  | SYM_DOMAIN (MODULE) | 
|  |  | 
|  | /* LABEL_DOMAIN may be used for names of labels (for gotos).  */ | 
|  |  | 
|  | SYM_DOMAIN (LABEL) | 
|  |  | 
|  | /* Fortran common blocks.  Their naming must be separate from VAR_DOMAIN. | 
|  | They also always use LOC_COMMON_BLOCK.  */ | 
|  | SYM_DOMAIN (COMMON_BLOCK) | 
|  |  | 
|  | /* TYPE_DOMAIN is for types and typedefs.  Note that tags are not | 
|  | found here, see STRUCT_DOMAIN above.  If a language does not have a | 
|  | tag namespace, then all types (including structures, etc) are | 
|  | here.  */ | 
|  |  | 
|  | SYM_DOMAIN (TYPE) | 
|  |  | 
|  | /* FUNCTION_DOMAIN is for functions and methods.  */ | 
|  |  | 
|  | SYM_DOMAIN (FUNCTION) |