(root)/
gcc-13.2.0/
libobjc/
objc-private/
selector.h
       1  /* GNU Objective C Runtime selector implementation - Private functions
       2     Copyright (C) 2010-2023 Free Software Foundation, Inc.
       3     Contributed by Nicola Pero <nicola.pero@meta-innovation.com>
       4  
       5  This file is part of GCC.
       6  
       7  GCC is free software; you can redistribute it and/or modify it under the
       8  terms of the GNU General Public License as published by the Free Software
       9  Foundation; either version 3, or (at your option) any later version.
      10  
      11  GCC is distributed in the hope that it will be useful, but WITHOUT ANY
      12  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
      13  FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
      14  details.
      15  
      16  Under Section 7 of GPL version 3, you are granted additional
      17  permissions described in the GCC Runtime Library Exception, version
      18  3.1, as published by the Free Software Foundation.
      19  
      20  You should have received a copy of the GNU General Public License and
      21  a copy of the GCC Runtime Library Exception along with this program;
      22  see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
      23  <http://www.gnu.org/licenses/>.  */
      24  
      25  #ifndef __objc_private_selector_INCLUDE_GNU
      26  #define __objc_private_selector_INCLUDE_GNU
      27  
      28  /* Private runtime functions that may go away or be rewritten or
      29     replaced.  */
      30  
      31  /* Definition of a selector.  Selectors themselves are not unique, but
      32     the sel_id is a unique identifier.  */
      33  struct objc_selector
      34  {
      35    void *sel_id;
      36    const char *sel_types;
      37  };
      38  
      39  /* An inline, fast version of sel_isEqual().  */
      40  inline static BOOL
      41  sel_eq (SEL s1, SEL s2)
      42  {
      43    if (s1 == 0 || s2 == 0)
      44      return s1 == s2;
      45    else
      46      return s1->sel_id == s2->sel_id;
      47  }
      48  
      49  /* Number of selectors stored in each of the selector tables.  */
      50  extern unsigned int __objc_selector_max_index;
      51  
      52  /* Initialize the selector tables.  This must be called by init.c.  */
      53  void __objc_init_selector_tables(void);
      54  
      55  /* Various private functions to register selectors.  */
      56  void __objc_register_selectors_from_class(Class);
      57  void __objc_register_selectors_from_list (struct objc_method_list *);
      58  void __objc_register_selectors_from_description_list
      59  (struct objc_method_description_list *method_list);
      60  void __objc_register_selectors_from_module (struct objc_selector *selectors);
      61  
      62  /* Return whether a selector is mapped or not ("mapped" meaning that
      63     it has been inserted into the selector table).  This is private as
      64     only the runtime should ever encounter or need to know about
      65     unmapped selectors.  */
      66  BOOL sel_is_mapped (SEL aSel);
      67  
      68  /* Return selector representing name without registering it if it
      69     doesn't exist.  Typically used internally by the runtime when it's
      70     looking up methods that may or may not exist (such as +initialize)
      71     in the most efficient way.  */
      72  SEL
      73  sel_get_any_uid (const char *name);
      74  
      75  #endif /* not __objc_private_selector_INCLUDE_GNU */