From: Richard Henderson Date: Fri, 21 Dec 2001 19:44:06 +0000 (-0800) Subject: class.c (compile_resource_file): Set TREE_PUBLIC on the constructor only if the targe... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ef969525677f86bc8e7e188328939c5941f95b96;p=gcc.git class.c (compile_resource_file): Set TREE_PUBLIC on the constructor only if the target requires collect2. * class.c (compile_resource_file): Set TREE_PUBLIC on the constructor only if the target requires collect2. From-SVN: r48252 --- diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 7f3e20be9c5..6c0a6d706f0 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,5 +1,8 @@ 2001-12-21 Richard Henderson + * class.c (compile_resource_file): Set TREE_PUBLIC on the constructor + only if the target requires collect2. + * class.c (build_class_ref): Mark _Jv_fooClass DECL_EXTERNAL. 2001-12-20 Tom Tromey diff --git a/gcc/java/class.c b/gcc/java/class.c index e64e1936a72..68e25b9ca43 100644 --- a/gcc/java/class.c +++ b/gcc/java/class.c @@ -923,8 +923,11 @@ compile_resource_file (name, filename) current_function_decl = init_decl; DECL_RESULT (init_decl) = build_decl (RESULT_DECL, NULL_TREE, void_type_node); - /* DECL_EXTERNAL (init_decl) = 1;*/ - TREE_PUBLIC (init_decl) = 1; + + /* It can be a static function as long as collect2 does not have + to scan the object file to find its ctor/dtor routine. */ + TREE_PUBLIC (init_decl) = ! targetm.have_ctors_dtors; + pushlevel (0); make_decl_rtl (init_decl, NULL); init_function_start (init_decl, input_filename, 0);