Convert objc-lang.c to type-safe registry API
authorTom Tromey <tom@tromey.com>
Thu, 2 May 2019 22:08:54 +0000 (16:08 -0600)
committerTom Tromey <tom@tromey.com>
Wed, 8 May 2019 22:01:56 +0000 (16:01 -0600)
This changes objc-lang.c to use the type-safe registry API.

gdb/ChangeLog
2019-05-08  Tom Tromey  <tom@tromey.com>

* objc-lang.c (objc_objfile_data): Change type.
(find_methods): Update.
(_initialize_objc_lang): Remove.

gdb/ChangeLog
gdb/objc-lang.c

index 0d4b3aeec3fc19a2fea505c8b58599dbbaaaaa21..08489a8558b48ce8c4216975c591be57c19aad02 100644 (file)
@@ -1,3 +1,9 @@
+2019-05-08  Tom Tromey  <tom@tromey.com>
+
+       * objc-lang.c (objc_objfile_data): Change type.
+       (find_methods): Update.
+       (_initialize_objc_lang): Remove.
+
 2019-05-08  Tom Tromey  <tom@tromey.com>
 
        * stabsread.c (rs6000_builtin_type_data): Change type.
index b25a98106c1339791c82d046b5bc2370abf0e26d..ab40e54a169403de23389ce8f866f245d6d15334 100644 (file)
@@ -75,7 +75,7 @@ struct objc_method {
   CORE_ADDR imp;
 };
 
-static const struct objfile_data *objc_objfile_data;
+static const struct objfile_key<unsigned int> objc_objfile_data;
 
 /* Lookup a structure type named "struct NAME", visible in lexical
    block BLOCK.  If NOERR is nonzero, return zero if NAME is not
@@ -1004,7 +1004,7 @@ find_methods (char type, const char *theclass, const char *category,
 
       unsigned int objfile_csym = 0;
 
-      objc_csym = (unsigned int *) objfile_data (objfile, objc_objfile_data);
+      objc_csym = objc_objfile_data.get (objfile);
       if (objc_csym != NULL && *objc_csym == 0)
        /* There are no ObjC symbols in this objfile.  Skip it entirely.  */
        continue;
@@ -1056,11 +1056,7 @@ find_methods (char type, const char *theclass, const char *category,
        }
 
       if (objc_csym == NULL)
-       {
-         objc_csym = XOBNEW (&objfile->objfile_obstack, unsigned int);
-         *objc_csym = objfile_csym;
-         set_objfile_data (objfile, objc_objfile_data, objc_csym);
-       }
+       objc_csym = objc_objfile_data.emplace (objfile, objfile_csym);
       else
        /* Count of ObjC methods in this objfile should be constant.  */
        gdb_assert (*objc_csym == objfile_csym);
@@ -1576,9 +1572,3 @@ resolve_msgsend_super_stret (CORE_ADDR pc, CORE_ADDR *new_pc)
     return 1;
   return 0;
 }
-
-void
-_initialize_objc_lang (void)
-{
-  objc_objfile_data = register_objfile_data ();
-}