Commit 812398e4 by Iain Sandoe Committed by Janis Johnson

re PR objc/35165 (Massive failures of objc on i686-apple-darwin9)

2010-03-25  Iain Sandoe  <iain.sandoe@sandoe-acoustics.co.uk>

	PR objc/35165
	PR testsuite/43512
	* objc-obj-c++-shared: New directory.
	* objc-obj-c++-shared/Object1-implementation.h: New file.
	* objc-obj-c++-shared/Object1.h: New file.
	* objc-obj-c++-shared/Protocol1.h: New file.
	* objc-obj-c++-shared/next-abi.h: New file.
	* objc-obj-c++-shared/next-mapping.h: New file.
	* objc/execute/next_mapping.h: Delete.
	* objc.dg/special/special.exp: For all targets run the tests with
	-fgnu-runtime, for darwin targets also run the tests with 
	-fnext-runtime.
	* objc.dg/dg.exp: Ditto.
	* obj-c++.dg/dg.exp: Ditto.
	* objc/execute/forward-1.m: Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required.  Amend testcase to
	include use of updated NeXT interface.
	* objc/execute/formal_protocol-5.m: Ditto.
	* objc/execute/protocol-isEqual-2.m: Ditto.
	* objc/execute/protocol-isEqual-4.m: Ditto.	
	* objc/execute/class-11.m: Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required.
	* objc/execute/object_is_class.m: Ditto.
	* objc/execute/enumeration-1.m: Ditto.
	* objc/execute/class-13.m: Ditto.
	* objc/execute/formal_protocol-2.m: Ditto.
	* objc/execute/formal_protocol-4.m: Ditto.
	* objc/execute/class-1.m: Ditto.
	* objc/execute/bycopy-1.m: Ditto.
	* objc/execute/formal_protocol-6.m: Ditto.
	* objc/execute/bycopy-3.m: Ditto.
	* objc/execute/class-3.m: Ditto.
	* objc/execute/bf-11.m: Ditto.
	* objc/execute/class-5.m: Ditto.
	* objc/execute/bf-13.m: Ditto.
	* objc/execute/class-7.m: Ditto.
	* objc/execute/bf-15.m: Ditto.
	* objc/execute/class-9.m: Ditto.
	* objc/execute/bf-17.m: Ditto.
	* objc/execute/bf-19.m: Ditto.
	* objc/execute/IMP.m: Ditto.
	* objc/execute/exceptions/catchall-1.m: Ditto.
	* objc/execute/exceptions/trivial.m: Ditto.
	* objc/execute/exceptions/finally-1.m: Ditto.
	* objc/execute/exceptions/local-variables-1.m: Ditto.
	* objc/execute/exceptions/foward-1.m: Ditto.
	* objc/execute/bf-2.m: Ditto.
	* objc/execute/string1.m: Ditto.
	* objc/execute/bf-4.m: Ditto.
	* objc/execute/informal_protocol.m: Ditto.
	* objc/execute/string3.m: Ditto.
	* objc/execute/bf-6.m: Ditto.
	* objc/execute/bf-8.m: Ditto.
	* objc/execute/class-tests-1.h: Ditto.
	* objc/execute/protocol-isEqual-1.m: Ditto.
	* objc/execute/protocol-isEqual-3.m: Ditto.
	* objc/execute/_cmd.m: Ditto.
	* objc/execute/function-message-1.m: Ditto.
	* objc/execute/bf-20.m: Ditto.
	* objc/execute/bf-common.h: Ditto.
	* objc/execute/np-2.m: Ditto.
	* objc/execute/class-10.m: Ditto.
	* objc/execute/class-12.m: Ditto.
	* objc/execute/enumeration-2.m: Ditto.
	* objc/execute/class-14.m: Ditto.
	* objc/execute/encode-1.m: Ditto.
	* objc/execute/formal_protocol-1.m: Ditto.
	* objc/execute/formal_protocol-3.m: Ditto.
	* objc/execute/accessing_ivars.m: Ditto.
	* objc/execute/bycopy-2.m: Ditto.
	* objc/execute/class-2.m: Ditto.
	* objc/execute/bf-10.m: Ditto.
	* objc/execute/formal_protocol-7.m: Ditto.
	* objc/execute/root_methods.m: Ditto.
	* objc/execute/class-4.m: Ditto.
	* objc/execute/bf-12.m: Ditto.
	* objc/execute/class-6.m: Ditto.
	* objc/execute/bf-14.m: Ditto.
	* objc/execute/nested-func-1.m: Ditto.
	* objc/execute/class-8.m: Ditto.
	* objc/execute/private.m: Ditto.
	* objc/execute/bf-16.m: Ditto.
	* objc/execute/bf-18.m: Ditto.
	* objc/execute/load-3.m: Ditto.
	* objc/execute/compatibility_alias.m: Ditto.
	* objc/execute/bf-1.m: Ditto.
	* objc/execute/no_clash.m: Ditto.
	* objc/execute/bf-3.m: Ditto.
	* objc/execute/string2.m: Ditto.
	* objc/execute/bf-5.m: Ditto.
	* objc/execute/string4.m: Ditto.
	* objc/execute/bf-7.m: Ditto.
	* objc/execute/object_is_meta_class.m: Ditto.
	* objc/execute/bf-9.m: Ditto.
	* objc/execute/bf-21.m: Ditto.
	* objc/execute/cascading-1.m: Ditto.
	* objc/execute/trivial.m: Ditto.
	* objc/execute/np-1.m: Ditto.
	* objc/compile/trivial.m: Ditto.
	* objc/execute/class_self-2.m: Include <stdlib.h>.
	* objc/execute/forward-1.x: Do not XFAIL for 32bit powerpc-darwin.
	* objc.dg/desig-init-1.m: Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required. XFAIL run if NeXT 
	and 64bit. Use new NeXT interface as required.
	* objc.dg/special/unclaimed-category-1.m: Ditto.
	* objc.dg/special/unclaimed-category-1.h: Ditto.
	* objc.dg/special/unclaimed-category-1a.m: Ditto.
	* objc.dg/func-ptr-1.m: Ditto.
	* objc.dg/stret-1.m: Ditto.	
	* objc.dg/encode-2.m: Ditto.
	* objc.dg/category-1.m: Ditto.
	* objc.dg/encode-3.m: Ditto.
	* objc.dg/call-super-3.m: Ditto.
	* objc.dg/method-3.m: Ditto.
	* objc.dg/func-ptr-2.m: Ditto.
	* objc.dg/lookup-1.m: Ditto.
	* objc.dg/encode-4.m: Ditto.
	* objc.dg/fix-and-continue-1.m: Ditto.
	* objc.dg/proto-lossage-3.m: Ditto.
	* objc.dg/method-13.m: Ditto.
	* objc.dg/proto-qual-1.m: Ditto.
	* objc.dg/zero-link-3.m: Ditto.
	* objc.dg/bitfield-1.m: Ditto.
	* objc.dg/va-meth-1.m: Ditto.
	* objc.dg/super-class-3.m: Ditto.
	* objc.dg/call-super-1.m: Ditto.
	* objc.dg/type-size-2.m: Ditto.
	* objc.dg/method-10.m: Ditto.
	* objc.dg/defs.m: Ditto.	
	* objc.dg/const-str-3.m: Ditto.
	* objc.dg/try-catch-6.m: Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required. Use new NeXT 
	interface as required.
	* objc.dg/super-class-4.m: Ditto.
	* objc.dg/comp-types-8.m: Ditto.
	* objc.dg/call-super-2.m: Ditto.
	* objc.dg/objc-fast-4.m: Ditto.
	* objc.dg/method-6.m: Ditto.
	* objc.dg/const-str-3.m: Ditto.
	* objc.dg/const-str-7.m: Ditto.
	* objc.dg/method-15.m: Ditto.
	* objc.dg/method-19.m: Ditto.
	* objc.dg/sync-1.m: Ditto.
	* objc.dg/layout-1.m: Ditto.
	* objc.dg/bitfield-3.m: Ditto.
	* objc.dg/try-catch-3.m: Ditto.
	* objc.dg/try-catch-7.m: Ditto.
	* objc.dg/comp-types-10.m: Ditto.
	* objc.dg/selector-2.: Ditto.
	* objc.dg/method-7.m: Ditto.
	* objc.dg/typedef-alias-1.m: Ditto.
	* objc.dg/proto-lossage-2.m: Ditto.
	* objc.dg/comp-types-11.m: Ditto.
	* objc.dg/sizeof-1.m: Ditto.
	* objc.dg/method-17.m: Ditto.
	* objc.dg/bitfield-5.m: Ditto.
	* objc.dg/try-catch-1.m: Ditto.
	* objc.dg/encode-5.m: Ditto.
	* objc.dg/fix-and-continue-2.m: Ditto.
	* objc.dg/method-9.m: Ditto.
	* objc.dg/isa-field-1.m: Ditto.
	* objc.dg/local-decl-2.m: Ditto.	
	* objc.dg/objc-gc-4.m: Ditto.
	* objc.dg/type-stream-1.m: Skip for NeXT runtime.
	* objc.dg/gnu-runtime-3.m: Ditto.
	* objc.dg/encode-7.m: Ditto.
	* objc.dg/encode-8.m: Ditto.
	* objc.dg/selector-3.m: Ditto.
	* objc.dg/gnu-runtime-1.m: Ditto.
	* objc.dg/const-str-12.m: Ditto.
	* objc.dg/gnu-runtime-2.m: Ditto.	
	* objc.dg/no-extra-load.m: Skip for gnu-runtime.
	* objc.dg/selector-1.m: Ditto.
	* objc.dg/stubify-2.m: Ditto.
	* objc.dg/zero-link-1.m: Ditto.
	* objc.dg/stret-2.m: Ditto.
	* objc.dg/zero-link-2.m: Ditto.
	* objc.dg/next-runtime-1.m: Ditto.
	* objc.dg/symtab-1.m: Ditto.
	* objc.dg/stubify-1.m: Ditto.
	* objc.dg/bitfield-2.m: Ditto.	
	* objc.dg/try-catch-10.m: Apply to both runtimes.
	* objc.dg/const-str-1.m: Ditto.
	* objc.dg/image-info.m: Ditto.
	* objc.dg/encode-9.m: Ditto.	
	* objc.dg/pragma-1.m: Apply test to all targets.
	* objc.dg/const-str-4.m: Ditto.
	* objc.dg/const-str-8.m: Ditto.
	* objc.dg/super-class-2.m: Ditto.
	* objc.dg/try-catch-5.m: Ditto.
	* objc.dg/const-str-10.m: Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required. Use new NeXT 
	interface as required.  Skip for gnu-runtime.  Test for .quad
	at m64.
	* objc.dg/const-str-11.m: Ditto.
	* objc.dg/const-str-9.m: Ditto.	
	* objc.dg/method-4.m: Skip for 64Bit NeXT.
	* objc.dg/encode-1.m: Remove redundant -lobjc.
	* objc.dg/try-catch-9.m: Tidy space.
	* obj-c++.dg/method-19.mm: Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required. XFAIL run if NeXT 
	and 64bit. Use new NeXT interface as required.
	* obj-c++.dg/template-4.mm: Ditto.
	* obj-c++.dg/defs.mm: Ditto.
	* obj-c++.dg/basic.mm: Ditto.
	* obj-c++.dg/encode-4.mm: Ditto.
	* obj-c++.dg/method-17.mm: Ditto.
	* obj-c++.dg/proto-lossage-3.mm: Ditto.
	* obj-c++.dg/cxx-class-1.mm: Ditto.
	* obj-c++.dg/method-10.mm: Ditto.
	* obj-c++.dg/va-meth-1.mm: Ditto.
	* obj-c++.dg/encode-5.mm: Ditto.
	* obj-c++.dg/lookup-2.mm: Ditto.
	* obj-c++.dg/template-3.mm: Ditto.
	* obj-c++.dg/proto-qual-1.mm: Ditto.
	* obj-c++.dg/qual-types-1.m: Ditto.
	* obj-c++.dg/cxx-scope-1.mm: Ditto.
	* obj-c++.dg/template-1.mm: Ditto.
	* obj-c++.dg/encode-6.mm: Ditto.
	* obj-c++.dg/bitfield-2.mm:  Use shared wrapper headers (Object1.h,
	Protocol1.h) and next-mapping.h as required. Use new NeXT 
	interface as required.
	* obj-c++.dg/except-1.mm: Ditto.
	* obj-c++.dg/const-str-7.mm: Ditto.
	* obj-c++.dg/ivar-list-semi.mm: Ditto.
	* obj-c++.dg/cxx-scope-2.mm: Ditto.
	* obj-c++.dg/selector-2.mm: Ditto.
	* obj-c++.dg/isa-field-1.mm: Ditto.
	* obj-c++.dg/try-catch-1.mm: Ditto.
	* obj-c++.dg/local-decl-1.mm: Ditto.
	* obj-c++.dg/try-catch-9.mm: Ditto.
	* obj-c++.dg/no-extra-load.mm: Ditto.
	* obj-c++.dg/selector-5.mm: Ditto.
	* obj-c++.dg/method-12.mm: Ditto.
	* obj-c++.dg/try-catch-11.mm: Ditto.
	* obj-c++.dg/comp-types-11.mm: Ditto.
	* obj-c++.dg/bitfield-3.mm: Ditto.
	* obj-c++.dg/method-6.mm: Ditto.
	* obj-c++.dg/super-class-2.mm: Ditto.
	* obj-c++.dg/method-21.mm: Ditto.
	* obj-c++.dg/const-str-8.mm: Ditto.
	* obj-c++.dg/try-catch-7.mm: Ditto.
	* obj-c++.dg/method-15.mm: Ditto.
	* obj-c++.dg/layout-1.mm: Ditto.
	* obj-c++.dg/cxx-ivars-1.mm: Ditto.
	* obj-c++.dg/const-str-3.mm: Ditto.
	* obj-c++.dg/try-catch-2.mm: Ditto.
	* obj-c++.dg/objc-gc-3.mm: Ditto.
	* obj-c++.dg/fix-and-continue-2.mm: Ditto.
	* obj-c++.dg/bitfield-1.mm: Ditto.
	* obj-c++.dg/selector-6.mm: Ditto.
	* obj-c++.dg/method-13.mm: Ditto.
	* obj-c++.dg/comp-types-12.mm: Ditto.
	* obj-c++.dg/bitfield-4.mm: Ditto.
	* obj-c++.dg/try-catch-8.mm: Ditto.
	* obj-c++.dg/method-2.mm: Ditto.
	* obj-c++.dg/cxx-ivars-2.mm: Ditto.
	* obj-c++.dg/typedef-alias-1.mm: Ditto.
	* obj-c++.dg/const-str-4.mm: Ditto.
	* obj-c++.dg/proto-lossage-2.mm: Ditto.
	* obj-c++.dg/try-catch-3.mm: Ditto.
	* obj-c++.dg/comp-types-9.mm: Ditto.
	* obj-c++.dg/gnu-runtime-2.mm: Skip if NeXT runtime.
	* obj-c++.dg/gnu-runtime-3.mm: Ditto.
	* obj-c++.dg/gnu-runtime-1.mm: Ditto.
	* objc.dg/zero-link-2.m: Skip if gnu runtime. Use shared wrapper 
	headers (Object1.h, Protocol1.h) and next-mapping.h as required. 
	Use new NeXT interface as required.
	* obj-c++.dg/const-str-10.mm: Ditto.
	* obj-c++.dg/const-str-11.mm: Ditto.
	* obj-c++.dg/const-str-9.mm: Ditto.
	* obj-c++.dg/method-11.mm: Ditto.
	* obj-c++.dg/cxx-ivars-3.mm: Skip if gnu runtime. Use shared wrapper 
	headers (Object1.h, Protocol1.h) and next-mapping.h as required. 
	Use new NeXT interface as required. XFAIL run if NeXT and 64bit.
	* obj-c++.dg/encode-8.mm: Remove redundant -lobjc.
	* obj-c++.dg/const-str-1.mm: Run for NeXT as well as gnu.

From-SVN: r157731
parent 58f5f6b4
2010-03-25 Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk>
PR objc/35165
PR testsuite/43512
* objc-obj-c++-shared: New directory.
* objc-obj-c++-shared/Object1-implementation.h: New file.
* objc-obj-c++-shared/Object1.h: New file.
* objc-obj-c++-shared/Protocol1.h: New file.
* objc-obj-c++-shared/next-abi.h: New file.
* objc-obj-c++-shared/next-mapping.h: New file.
* objc/execute/next_mapping.h: Delete.
* objc.dg/special/special.exp: For all targets run the tests with
-fgnu-runtime, for darwin targets also run the tests with
-fnext-runtime.
* objc.dg/dg.exp: Ditto.
* obj-c++.dg/dg.exp: Ditto.
* objc/execute/forward-1.m: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required. Amend testcase to
include use of updated NeXT interface.
* objc/execute/formal_protocol-5.m: Ditto.
* objc/execute/protocol-isEqual-2.m: Ditto.
* objc/execute/protocol-isEqual-4.m: Ditto.
* objc/execute/class-11.m: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required.
* objc/execute/object_is_class.m: Ditto.
* objc/execute/enumeration-1.m: Ditto.
* objc/execute/class-13.m: Ditto.
* objc/execute/formal_protocol-2.m: Ditto.
* objc/execute/formal_protocol-4.m: Ditto.
* objc/execute/class-1.m: Ditto.
* objc/execute/bycopy-1.m: Ditto.
* objc/execute/formal_protocol-6.m: Ditto.
* objc/execute/bycopy-3.m: Ditto.
* objc/execute/class-3.m: Ditto.
* objc/execute/bf-11.m: Ditto.
* objc/execute/class-5.m: Ditto.
* objc/execute/bf-13.m: Ditto.
* objc/execute/class-7.m: Ditto.
* objc/execute/bf-15.m: Ditto.
* objc/execute/class-9.m: Ditto.
* objc/execute/bf-17.m: Ditto.
* objc/execute/bf-19.m: Ditto.
* objc/execute/IMP.m: Ditto.
* objc/execute/exceptions/catchall-1.m: Ditto.
* objc/execute/exceptions/trivial.m: Ditto.
* objc/execute/exceptions/finally-1.m: Ditto.
* objc/execute/exceptions/local-variables-1.m: Ditto.
* objc/execute/exceptions/foward-1.m: Ditto.
* objc/execute/bf-2.m: Ditto.
* objc/execute/string1.m: Ditto.
* objc/execute/bf-4.m: Ditto.
* objc/execute/informal_protocol.m: Ditto.
* objc/execute/string3.m: Ditto.
* objc/execute/bf-6.m: Ditto.
* objc/execute/bf-8.m: Ditto.
* objc/execute/class-tests-1.h: Ditto.
* objc/execute/protocol-isEqual-1.m: Ditto.
* objc/execute/protocol-isEqual-3.m: Ditto.
* objc/execute/_cmd.m: Ditto.
* objc/execute/function-message-1.m: Ditto.
* objc/execute/bf-20.m: Ditto.
* objc/execute/bf-common.h: Ditto.
* objc/execute/np-2.m: Ditto.
* objc/execute/class-10.m: Ditto.
* objc/execute/class-12.m: Ditto.
* objc/execute/enumeration-2.m: Ditto.
* objc/execute/class-14.m: Ditto.
* objc/execute/encode-1.m: Ditto.
* objc/execute/formal_protocol-1.m: Ditto.
* objc/execute/formal_protocol-3.m: Ditto.
* objc/execute/accessing_ivars.m: Ditto.
* objc/execute/bycopy-2.m: Ditto.
* objc/execute/class-2.m: Ditto.
* objc/execute/bf-10.m: Ditto.
* objc/execute/formal_protocol-7.m: Ditto.
* objc/execute/root_methods.m: Ditto.
* objc/execute/class-4.m: Ditto.
* objc/execute/bf-12.m: Ditto.
* objc/execute/class-6.m: Ditto.
* objc/execute/bf-14.m: Ditto.
* objc/execute/nested-func-1.m: Ditto.
* objc/execute/class-8.m: Ditto.
* objc/execute/private.m: Ditto.
* objc/execute/bf-16.m: Ditto.
* objc/execute/bf-18.m: Ditto.
* objc/execute/load-3.m: Ditto.
* objc/execute/compatibility_alias.m: Ditto.
* objc/execute/bf-1.m: Ditto.
* objc/execute/no_clash.m: Ditto.
* objc/execute/bf-3.m: Ditto.
* objc/execute/string2.m: Ditto.
* objc/execute/bf-5.m: Ditto.
* objc/execute/string4.m: Ditto.
* objc/execute/bf-7.m: Ditto.
* objc/execute/object_is_meta_class.m: Ditto.
* objc/execute/bf-9.m: Ditto.
* objc/execute/bf-21.m: Ditto.
* objc/execute/cascading-1.m: Ditto.
* objc/execute/trivial.m: Ditto.
* objc/execute/np-1.m: Ditto.
* objc/compile/trivial.m: Ditto.
* objc/execute/class_self-2.m: Include <stdlib.h>.
* objc/execute/forward-1.x: Do not XFAIL for 32bit powerpc-darwin.
* objc.dg/desig-init-1.m: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required. XFAIL run if NeXT
and 64bit. Use new NeXT interface as required.
* objc.dg/special/unclaimed-category-1.m: Ditto.
* objc.dg/special/unclaimed-category-1.h: Ditto.
* objc.dg/special/unclaimed-category-1a.m: Ditto.
* objc.dg/func-ptr-1.m: Ditto.
* objc.dg/stret-1.m: Ditto.
* objc.dg/encode-2.m: Ditto.
* objc.dg/category-1.m: Ditto.
* objc.dg/encode-3.m: Ditto.
* objc.dg/call-super-3.m: Ditto.
* objc.dg/method-3.m: Ditto.
* objc.dg/func-ptr-2.m: Ditto.
* objc.dg/lookup-1.m: Ditto.
* objc.dg/encode-4.m: Ditto.
* objc.dg/fix-and-continue-1.m: Ditto.
* objc.dg/proto-lossage-3.m: Ditto.
* objc.dg/method-13.m: Ditto.
* objc.dg/proto-qual-1.m: Ditto.
* objc.dg/zero-link-3.m: Ditto.
* objc.dg/bitfield-1.m: Ditto.
* objc.dg/va-meth-1.m: Ditto.
* objc.dg/super-class-3.m: Ditto.
* objc.dg/call-super-1.m: Ditto.
* objc.dg/type-size-2.m: Ditto.
* objc.dg/method-10.m: Ditto.
* objc.dg/defs.m: Ditto.
* objc.dg/const-str-3.m: Ditto.
* objc.dg/try-catch-6.m: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required. Use new NeXT
interface as required.
* objc.dg/super-class-4.m: Ditto.
* objc.dg/comp-types-8.m: Ditto.
* objc.dg/call-super-2.m: Ditto.
* objc.dg/objc-fast-4.m: Ditto.
* objc.dg/method-6.m: Ditto.
* objc.dg/const-str-3.m: Ditto.
* objc.dg/const-str-7.m: Ditto.
* objc.dg/method-15.m: Ditto.
* objc.dg/method-19.m: Ditto.
* objc.dg/sync-1.m: Ditto.
* objc.dg/layout-1.m: Ditto.
* objc.dg/bitfield-3.m: Ditto.
* objc.dg/try-catch-3.m: Ditto.
* objc.dg/try-catch-7.m: Ditto.
* objc.dg/comp-types-10.m: Ditto.
* objc.dg/selector-2.: Ditto.
* objc.dg/method-7.m: Ditto.
* objc.dg/typedef-alias-1.m: Ditto.
* objc.dg/proto-lossage-2.m: Ditto.
* objc.dg/comp-types-11.m: Ditto.
* objc.dg/sizeof-1.m: Ditto.
* objc.dg/method-17.m: Ditto.
* objc.dg/bitfield-5.m: Ditto.
* objc.dg/try-catch-1.m: Ditto.
* objc.dg/encode-5.m: Ditto.
* objc.dg/fix-and-continue-2.m: Ditto.
* objc.dg/method-9.m: Ditto.
* objc.dg/isa-field-1.m: Ditto.
* objc.dg/local-decl-2.m: Ditto.
* objc.dg/objc-gc-4.m: Ditto.
* objc.dg/type-stream-1.m: Skip for NeXT runtime.
* objc.dg/gnu-runtime-3.m: Ditto.
* objc.dg/encode-7.m: Ditto.
* objc.dg/encode-8.m: Ditto.
* objc.dg/selector-3.m: Ditto.
* objc.dg/gnu-runtime-1.m: Ditto.
* objc.dg/const-str-12.m: Ditto.
* objc.dg/gnu-runtime-2.m: Ditto.
* objc.dg/no-extra-load.m: Skip for gnu-runtime.
* objc.dg/selector-1.m: Ditto.
* objc.dg/stubify-2.m: Ditto.
* objc.dg/zero-link-1.m: Ditto.
* objc.dg/stret-2.m: Ditto.
* objc.dg/zero-link-2.m: Ditto.
* objc.dg/next-runtime-1.m: Ditto.
* objc.dg/symtab-1.m: Ditto.
* objc.dg/stubify-1.m: Ditto.
* objc.dg/bitfield-2.m: Ditto.
* objc.dg/try-catch-10.m: Apply to both runtimes.
* objc.dg/const-str-1.m: Ditto.
* objc.dg/image-info.m: Ditto.
* objc.dg/encode-9.m: Ditto.
* objc.dg/pragma-1.m: Apply test to all targets.
* objc.dg/const-str-4.m: Ditto.
* objc.dg/const-str-8.m: Ditto.
* objc.dg/super-class-2.m: Ditto.
* objc.dg/try-catch-5.m: Ditto.
* objc.dg/const-str-10.m: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required. Use new NeXT
interface as required. Skip for gnu-runtime. Test for .quad
at m64.
* objc.dg/const-str-11.m: Ditto.
* objc.dg/const-str-9.m: Ditto.
* objc.dg/method-4.m: Skip for 64Bit NeXT.
* objc.dg/encode-1.m: Remove redundant -lobjc.
* objc.dg/try-catch-9.m: Tidy space.
* obj-c++.dg/method-19.mm: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required. XFAIL run if NeXT
and 64bit. Use new NeXT interface as required.
* obj-c++.dg/template-4.mm: Ditto.
* obj-c++.dg/defs.mm: Ditto.
* obj-c++.dg/basic.mm: Ditto.
* obj-c++.dg/encode-4.mm: Ditto.
* obj-c++.dg/method-17.mm: Ditto.
* obj-c++.dg/proto-lossage-3.mm: Ditto.
* obj-c++.dg/cxx-class-1.mm: Ditto.
* obj-c++.dg/method-10.mm: Ditto.
* obj-c++.dg/va-meth-1.mm: Ditto.
* obj-c++.dg/encode-5.mm: Ditto.
* obj-c++.dg/lookup-2.mm: Ditto.
* obj-c++.dg/template-3.mm: Ditto.
* obj-c++.dg/proto-qual-1.mm: Ditto.
* obj-c++.dg/qual-types-1.m: Ditto.
* obj-c++.dg/cxx-scope-1.mm: Ditto.
* obj-c++.dg/template-1.mm: Ditto.
* obj-c++.dg/encode-6.mm: Ditto.
* obj-c++.dg/bitfield-2.mm: Use shared wrapper headers (Object1.h,
Protocol1.h) and next-mapping.h as required. Use new NeXT
interface as required.
* obj-c++.dg/except-1.mm: Ditto.
* obj-c++.dg/const-str-7.mm: Ditto.
* obj-c++.dg/ivar-list-semi.mm: Ditto.
* obj-c++.dg/cxx-scope-2.mm: Ditto.
* obj-c++.dg/selector-2.mm: Ditto.
* obj-c++.dg/isa-field-1.mm: Ditto.
* obj-c++.dg/try-catch-1.mm: Ditto.
* obj-c++.dg/local-decl-1.mm: Ditto.
* obj-c++.dg/try-catch-9.mm: Ditto.
* obj-c++.dg/no-extra-load.mm: Ditto.
* obj-c++.dg/selector-5.mm: Ditto.
* obj-c++.dg/method-12.mm: Ditto.
* obj-c++.dg/try-catch-11.mm: Ditto.
* obj-c++.dg/comp-types-11.mm: Ditto.
* obj-c++.dg/bitfield-3.mm: Ditto.
* obj-c++.dg/method-6.mm: Ditto.
* obj-c++.dg/super-class-2.mm: Ditto.
* obj-c++.dg/method-21.mm: Ditto.
* obj-c++.dg/const-str-8.mm: Ditto.
* obj-c++.dg/try-catch-7.mm: Ditto.
* obj-c++.dg/method-15.mm: Ditto.
* obj-c++.dg/layout-1.mm: Ditto.
* obj-c++.dg/cxx-ivars-1.mm: Ditto.
* obj-c++.dg/const-str-3.mm: Ditto.
* obj-c++.dg/try-catch-2.mm: Ditto.
* obj-c++.dg/objc-gc-3.mm: Ditto.
* obj-c++.dg/fix-and-continue-2.mm: Ditto.
* obj-c++.dg/bitfield-1.mm: Ditto.
* obj-c++.dg/selector-6.mm: Ditto.
* obj-c++.dg/method-13.mm: Ditto.
* obj-c++.dg/comp-types-12.mm: Ditto.
* obj-c++.dg/bitfield-4.mm: Ditto.
* obj-c++.dg/try-catch-8.mm: Ditto.
* obj-c++.dg/method-2.mm: Ditto.
* obj-c++.dg/cxx-ivars-2.mm: Ditto.
* obj-c++.dg/typedef-alias-1.mm: Ditto.
* obj-c++.dg/const-str-4.mm: Ditto.
* obj-c++.dg/proto-lossage-2.mm: Ditto.
* obj-c++.dg/try-catch-3.mm: Ditto.
* obj-c++.dg/comp-types-9.mm: Ditto.
* obj-c++.dg/gnu-runtime-2.mm: Skip if NeXT runtime.
* obj-c++.dg/gnu-runtime-3.mm: Ditto.
* obj-c++.dg/gnu-runtime-1.mm: Ditto.
* objc.dg/zero-link-2.m: Skip if gnu runtime. Use shared wrapper
headers (Object1.h, Protocol1.h) and next-mapping.h as required.
Use new NeXT interface as required.
* obj-c++.dg/const-str-10.mm: Ditto.
* obj-c++.dg/const-str-11.mm: Ditto.
* obj-c++.dg/const-str-9.mm: Ditto.
* obj-c++.dg/method-11.mm: Ditto.
* obj-c++.dg/cxx-ivars-3.mm: Skip if gnu runtime. Use shared wrapper
headers (Object1.h, Protocol1.h) and next-mapping.h as required.
Use new NeXT interface as required. XFAIL run if NeXT and 64bit.
* obj-c++.dg/encode-8.mm: Remove redundant -lobjc.
* obj-c++.dg/const-str-1.mm: Run for NeXT as well as gnu.
2010-03-25 Dodji Seketeli <dodji@redhat.com> 2010-03-25 Dodji Seketeli <dodji@redhat.com>
PR c++/43206 PR c++/43206
......
// A basic sanity check for Objective-C++. // A basic sanity check for Objective-C++.
// { dg-do run } // { dg-do run }
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <iostream> #include <iostream>
@interface Greeter : Object @interface Greeter : Object
...@@ -19,3 +19,4 @@ main () ...@@ -19,3 +19,4 @@ main ()
Greeter *obj = [Greeter new]; Greeter *obj = [Greeter new];
[obj greet: "Hello from Objective-C\n"]; [obj greet: "Hello from Objective-C\n"];
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -9,8 +9,8 @@ ...@@ -9,8 +9,8 @@
/* Leave blank lines here to keep warnings on the same lines. */ /* Leave blank lines here to keep warnings on the same lines. */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort(); #define CHECK_IF(expr) if(!(expr)) abort();
...@@ -76,3 +76,4 @@ int main(void) { ...@@ -76,3 +76,4 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Check if bitfield ivars are correctly @encode'd when /* Check if bitfield ivars are correctly @encode'd when
the NeXT runtime is used. */ the NeXT runtime is used. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime -fsigned-char" } */ /* { dg-options "-fsigned-char" } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
typedef struct objc_object { struct objc_class *class_pointer; } *id; typedef struct objc_object { struct objc_class *class_pointer; } *id;
......
...@@ -2,9 +2,9 @@ ...@@ -2,9 +2,9 @@
layout of bitfields. */ layout of bitfields. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-options "-lobjc -Wpadded" } */ /* { dg-options "-Wpadded" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
......
/* Yet another mysterious gimplifier crasher. */ /* Yet another mysterious gimplifier crasher. */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-xfail-if "PR23716" { *-*-* } { "*" } { "" } } */ /* { dg-xfail-if "PR23716" { ! *-*-darwin* } { "*" } { "" } } */
/* { dg-prune-output ".*internal compiler error.*" } */ /* { dg-prune-output ".*internal compiler error.*" } */
/* { dg-options "-O3" } */ /* { dg-options "-O3" } */
......
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol Foo @protocol Foo
- (id)meth1; - (id)meth1;
......
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Derived: Object @interface Derived: Object
@end @end
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* Another gimplifier ICE... */ /* Another gimplifier ICE... */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface MyView: Object { @interface MyView: Object {
int _frame; int _frame;
......
/* Test errors for constant strings. */ /* Test errors for constant strings. */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime" } */
#ifdef __cplusplus #ifdef __cplusplus
extern void baz(...); extern void baz(...);
......
...@@ -2,10 +2,10 @@ ...@@ -2,10 +2,10 @@
constant string classes get derived. */ constant string classes get derived. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime" } */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface NSString: Object @interface NSString: Object
@end @end
...@@ -20,7 +20,11 @@ ...@@ -20,7 +20,11 @@
@interface NSConstantString : NSSimpleCString @interface NSConstantString : NSSimpleCString
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
Class _NSConstantStringClassReference;
#else
extern struct objc_class _NSConstantStringClassReference; extern struct objc_class _NSConstantStringClassReference;
#endif
const NSConstantString *appKey = @"MyApp"; const NSConstantString *appKey = @"MyApp";
......
...@@ -2,10 +2,11 @@ ...@@ -2,10 +2,11 @@
constant string classes get derived. */ constant string classes get derived. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime -fconstant-string-class=XStr" } */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-options "-fconstant-string-class=XStr" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface XString: Object { @interface XString: Object {
@protected @protected
...@@ -19,7 +20,11 @@ ...@@ -19,7 +20,11 @@
} }
@end @end
#ifndef NEXT_OBJC_USE_NEW_INTERFACE
extern struct objc_class _XStrClassReference; extern struct objc_class _XStrClassReference;
#else
extern Class _XStrClassReference;
#endif
const XStr *appKey = @"MyApp"; const XStr *appKey = @"MyApp";
......
...@@ -2,14 +2,18 @@ ...@@ -2,14 +2,18 @@
runtime. */ runtime. */
/* Developed by Markus Hitter <mah@jump-ing.de>. */ /* Developed by Markus Hitter <mah@jump-ing.de>. */
/* { dg-options "-fnext-runtime -fconstant-string-class=Foo -lobjc" } */ /* { dg-options "-fconstant-string-class=Foo" } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
#import "../objc-obj-c++-shared/Object1.h"
#import "../objc-obj-c++-shared/next-mapping.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <memory.h> #include <memory.h>
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h> #ifndef __NEXT_RUNTIME__
#include <objc/objc-api.h>
#endif
@interface Foo: Object { @interface Foo: Object {
char *cString; char *cString;
...@@ -18,7 +22,11 @@ ...@@ -18,7 +22,11 @@
- (char *)customString; - (char *)customString;
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
struct fudge_objc_class _FooClassReference;
#else
struct objc_class _FooClassReference; struct objc_class _FooClassReference;
#endif
@implementation Foo : Object @implementation Foo : Object
- (char *)customString { - (char *)customString {
...@@ -38,7 +46,7 @@ int main () { ...@@ -38,7 +46,7 @@ int main () {
constant string object. Can't be moved to +initialize since _that_ constant string object. Can't be moved to +initialize since _that_
is already a message. */ is already a message. */
memcpy(&_FooClassReference, objc_getClass("Foo"), sizeof(_FooClassReference)); memcpy(&_FooClassReference, objc_get_class("Foo"), sizeof(_FooClassReference));
if (strcmp ([string customString], "bla")) { if (strcmp ([string customString], "bla")) {
abort (); abort ();
} }
...@@ -46,3 +54,4 @@ int main () { ...@@ -46,3 +54,4 @@ int main () {
printf([@"This is a working constant string object\n" customString]); printf([@"This is a working constant string object\n" customString]);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Ensure that the preprocessor handles ObjC string constants gracefully. */ /* Ensure that the preprocessor handles ObjC string constants gracefully. */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime -fconstant-string-class=MyString -lobjc" } */ /* { dg-options "-fconstant-string-class=MyString" } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
#include <stdlib.h> #include <stdlib.h>
......
...@@ -2,17 +2,15 @@ ...@@ -2,17 +2,15 @@
scopes. */ scopes. */
/* Developed by Andrew Pinski <pinskia@physics.uc.edu> */ /* Developed by Andrew Pinski <pinskia@physics.uc.edu> */
/* { dg-options "-fconstant-string-class=Foo" } */
/* { dg-do run } */
/* { dg-options "-fnext-runtime -fconstant-string-class=Foo -lobjc" } */ #include "../objc-obj-c++-shared/Object1.h"
/* { dg-do run { target *-*-darwin* } } */ #include "../objc-obj-c++-shared/next-mapping.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <memory.h> #include <memory.h>
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
@interface Foo: Object { @interface Foo: Object {
char *cString; char *cString;
...@@ -21,8 +19,11 @@ ...@@ -21,8 +19,11 @@
- (char *)customString; - (char *)customString;
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
struct fudge_objc_class _FooClassReference;
#else
struct objc_class _FooClassReference; struct objc_class _FooClassReference;
#endif
@implementation Foo : Object @implementation Foo : Object
- (char *)customString { - (char *)customString {
...@@ -36,11 +37,10 @@ int main () { ...@@ -36,11 +37,10 @@ int main () {
{ {
Foo *string2 = @"bla"; Foo *string2 = @"bla";
if(string != string2) if(string != string2)
abort(); abort();
printf("Strings are being uniqued properly\n"); printf("Strings are being uniqued properly\n");
} }
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test for assigning compile-time constant-string objects to static variables. */ /* Test for assigning compile-time constant-string objects to static variables. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime -fconstant-string-class=Foo -lobjc" } */ /* { dg-options "-fconstant-string-class=Foo" } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#include <objc/Object.h>
@interface Foo: Object { @interface Foo: Object {
char *cString; char *cString;
...@@ -14,7 +13,11 @@ ...@@ -14,7 +13,11 @@
} }
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
Class _FooClassReference;
#else
struct objc_class _FooClassReference; struct objc_class _FooClassReference;
#endif
@implementation Foo : Object @implementation Foo : Object
- (char *)customString { - (char *)customString {
...@@ -37,3 +40,5 @@ int main () { ...@@ -37,3 +40,5 @@ int main () {
PrefsSynchronize(); PrefsSynchronize();
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test if ObjC constant strings get placed in the correct section. */ /* Test if ObjC constant strings get placed in the correct section. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime" } */ /* { dg-do compile } */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-skip-if "" { *-*-darwin* } { "-m64" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface NSConstantString: Object { @interface NSConstantString: Object {
char *cString; char *cString;
...@@ -13,7 +12,11 @@ ...@@ -13,7 +12,11 @@
} }
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
Class _NSConstantStringClassReference;
#else
extern struct objc_class _NSConstantStringClassReference; extern struct objc_class _NSConstantStringClassReference;
#endif
const NSConstantString *appKey = @"MyApp"; const NSConstantString *appKey = @"MyApp";
......
/* Test that Objective-C++ is able to chew through a simple C++ class hierarchy. /* Test that Objective-C++ is able to chew through a simple C++ class hierarchy.
This was broken in earlier ObjC++ incarnations. */ This was broken in earlier ObjC++ incarnations. */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
struct foo struct foo
{ {
foo(void *a) {}; foo(void *a) {};
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
// { dg-do run } // { dg-do run }
// { dg-options "-fno-objc-call-cxx-cdtors" } // { dg-options "-fno-objc-call-cxx-cdtors" }
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -40,3 +40,4 @@ int main (void) ...@@ -40,3 +40,4 @@ int main (void)
[obj manipulate_ivars]; [obj manipulate_ivars];
[obj free]; [obj free];
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
// { dg-do run { xfail { "*-*-*" } } } PR27247/PR23681 // { dg-do run { xfail { "*-*-*" } } } PR27247/PR23681
// { dg-options "-fobjc-call-cxx-cdtors" } // { dg-options "-fobjc-call-cxx-cdtors" }
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -74,3 +74,4 @@ int main (void) ...@@ -74,3 +74,4 @@ int main (void)
[foo free]; [foo free];
CHECK_IF(!ctor1_called && !ctor2_called && dtor1_called); CHECK_IF(!ctor1_called && !ctor2_called && dtor1_called);
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
// Check if ObjC classes with non-POD C++ ivars are specially marked in the metadata. // Check if ObjC classes with non-POD C++ ivars are specially marked in the metadata.
// { dg-do run { target *-*-darwin* } } // { dg-do run { target *-*-darwin* } }
// { dg-options "-fobjc-call-cxx-cdtors -fnext-runtime" } // { dg-options "-fobjc-call-cxx-cdtors" }
// { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } }
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc-runtime.h>
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -37,10 +40,16 @@ int main (void) ...@@ -37,10 +40,16 @@ int main (void)
{ {
Class cls; Class cls;
cls = objc_getClass("Foo"); cls = objc_get_class("Foo");
#if NEXT_OBJC_USE_NEW_INTERFACE
CHECK_IF(class_isMetaClass(cls) & CLS_HAS_CXX_STRUCTORS);
cls = objc_getClass("Bar");
CHECK_IF(!(class_isMetaClass(cls) & CLS_HAS_CXX_STRUCTORS));
#else
CHECK_IF(cls->info & CLS_HAS_CXX_STRUCTORS); CHECK_IF(cls->info & CLS_HAS_CXX_STRUCTORS);
cls = objc_getClass("Bar"); cls = objc_getClass("Bar");
CHECK_IF(!(cls->info & CLS_HAS_CXX_STRUCTORS)); CHECK_IF(!(cls->info & CLS_HAS_CXX_STRUCTORS));
#endif
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -2,8 +2,8 @@ ...@@ -2,8 +2,8 @@
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
@class Derived; @class Derived;
...@@ -51,3 +51,4 @@ int main(void) { ...@@ -51,3 +51,4 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <iostream> #include <iostream>
#include <string> #include <string>
......
/* Check @defs() in Objective-C++ */ /* Check @defs() in Objective-C++ */
/* Contributed by Devang Patel <dpatel@apple.com> */ /* Contributed by Devang Patel <dpatel@apple.com> */
/* { dg-options "" } */
/* { dg-options "-lobjc" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
extern "C" void abort(void); extern "C" void abort(void);
...@@ -41,3 +40,4 @@ int main() ...@@ -41,3 +40,4 @@ int main()
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -31,7 +31,12 @@ dg-init ...@@ -31,7 +31,12 @@ dg-init
set tests [lsort [find $srcdir/$subdir *.mm]] set tests [lsort [find $srcdir/$subdir *.mm]]
# Main loop. # Main loop.
dg-runtest $tests "" $DEFAULT_OBJCXXFLAGS dg-runtest $tests "-fgnu-runtime" $DEFAULT_OBJCXXFLAGS
# darwin targets can also run code with the NeXT runtime.
if [istarget "*-*-darwin*" ] {
dg-runtest $tests "-fnext-runtime" $DEFAULT_OBJCXXFLAGS
}
# All done. # All done.
dg-finish dg-finish
...@@ -15,20 +15,16 @@ ...@@ -15,20 +15,16 @@
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include "../objc-obj-c++-shared/next-mapping.h"
#include <objc/Object.h>
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#define METHOD Method #define METHOD Method
#define OBJC_GETCLASS objc_getClass
#define CLASS_GETINSTANCEMETHOD class_getInstanceMethod
#else #else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define METHOD Method_t #define METHOD Method_t
#define OBJC_GETCLASS objc_get_class #define method_get_types(M) (M)->method_types
#define CLASS_GETINSTANCEMETHOD class_get_instance_method
#endif #endif
#include <stdio.h> #include <stdio.h>
...@@ -78,27 +74,28 @@ unsigned offs1, offs2, offs3, offs4, offs5, offs6, offs7; ...@@ -78,27 +74,28 @@ unsigned offs1, offs2, offs3, offs4, offs5, offs6, offs7;
int main(void) { int main(void) {
Foo *foo = [[Foo alloc] init]; Foo *foo = [[Foo alloc] init];
Class fooClass = OBJC_GETCLASS("Foo"); Class fooClass = objc_get_class("Foo");
METHOD meth; METHOD meth;
const char *string; const char *string;
meth = CLASS_GETINSTANCEMETHOD(fooClass, @selector(setRect:withInt:)); meth = class_get_instance_method(fooClass, @selector(setRect:withInt:));
offs2 = 9999; offs2 = 9999;
sscanf(meth->method_types, "@%u@%u:%u{_XXRect={?=ff}{?=ff}}%ui%u", &offs1, &offs2, &offs3, sscanf(method_get_types(meth), "@%u@%u:%u{_XXRect={?=ff}{?=ff}}%ui%u", &offs1, &offs2, &offs3,
&offs4, &offs5); &offs4, &offs5);
CHECK_IF(!offs2); CHECK_IF(!offs2);
[foo setRect:my_rect withInt:123]; [foo setRect:my_rect withInt:123];
meth = CLASS_GETINSTANCEMETHOD(fooClass, @selector(char:float:double:long:)); meth = class_get_instance_method(fooClass, @selector(char:float:double:long:));
offs2 = 9999; offs2 = 9999;
if (sizeof (long) == 8) if (sizeof (long) == 8)
string = "v%u@%u:%uc%uf%ud%uq%u"; string = "v%u@%u:%uc%uf%ud%uq%u";
else else
string = "v%u@%u:%uc%uf%ud%ul%u"; string = "v%u@%u:%uc%uf%ud%ul%u";
sscanf(meth->method_types, string, &offs1, &offs2, &offs3, sscanf(method_get_types(meth), string, &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6, &offs7); &offs4, &offs5, &offs6, &offs7);
CHECK_IF(!offs2); CHECK_IF(!offs2);
[foo char:'c' float:2.3 double:3.5 long:2345L]; [foo char:'c' float:2.3 double:3.5 long:2345L];
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Method encoding tests for stand-alone @protocol declarations. */ /* Method encoding tests for stand-alone @protocol declarations. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Protocol.h> #include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
#include "../objc-obj-c++-shared/Protocol1.h"
#ifdef __cplusplus #ifdef __cplusplus
#define ProtoBool bool #define ProtoBool bool
#else #else
#define ProtoBool _Bool #define ProtoBool _Bool
#endif #endif
#ifndef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#define METHOD Method
#else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define METHOD Method_t
#define method_get_types(M) (M)->method_types
#endif #endif
#include <stdio.h> #include <stdio.h>
...@@ -37,6 +43,7 @@ typedef struct _XXRect { XXPoint origin; XXSize size; struct _XXRect *next; } XX ...@@ -37,6 +43,7 @@ typedef struct _XXRect { XXPoint origin; XXSize size; struct _XXRect *next; } XX
Protocol *proto = @protocol(Proto); Protocol *proto = @protocol(Proto);
struct objc_method_description *meth; struct objc_method_description *meth;
unsigned totsize, offs0, offs1, offs2, offs3, offs4, offs5, offs6, offs7; unsigned totsize, offs0, offs1, offs2, offs3, offs4, offs5, offs6, offs7;
static void scan_initial(const char *pattern) { static void scan_initial(const char *pattern) {
...@@ -71,3 +78,4 @@ int main(void) { ...@@ -71,3 +78,4 @@ int main(void) {
CHECK_IF(totsize == offs2 + sizeof(ObjCBool **)); CHECK_IF(totsize == offs2 + sizeof(ObjCBool **));
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Encoding tests for ObjC class layouts. */ /* Encoding tests for ObjC class layouts. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#ifdef __NEXT_RUNTIME__ #include "../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc-class.h> #ifndef __NEXT_RUNTIME__
#define OBJC_GETCLASS objc_getClass
#else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define OBJC_GETCLASS objc_get_class
#endif #endif
#include <stdlib.h> #include <stdlib.h>
...@@ -50,25 +47,43 @@ struct Nested { ...@@ -50,25 +47,43 @@ struct Nested {
@implementation Int2 @implementation Int2
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
Ivar *ivar;
#else
struct objc_ivar *ivar; struct objc_ivar *ivar;
#endif
static void check_ivar(const char *name, const char *type) { static void check_ivar(const char *name, const char *type) {
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
CHECK_IF(!strcmp(ivar_getName(*ivar), name));
CHECK_IF(!strcmp(ivar_getTypeEncoding(*ivar), type));
#else
CHECK_IF(!strcmp(ivar->ivar_name, name)); CHECK_IF(!strcmp(ivar->ivar_name, name));
CHECK_IF(!strcmp(ivar->ivar_type, type)); CHECK_IF(!strcmp(ivar->ivar_type, type));
#endif
ivar++; ivar++;
} }
int main(void) { int main(void) {
ivar = ((Class)OBJC_GETCLASS("Int1"))->ivars->ivar_list; #ifdef NEXT_OBJC_USE_NEW_INTERFACE
ivar = class_copyIvarList ((Class)objc_get_class("Int1"), NULL);
#else
ivar = ((Class)objc_get_class("Int1"))->ivars->ivar_list;
#endif
check_ivar("a", "c"); check_ivar("a", "c");
check_ivar("b", "c"); check_ivar("b", "c");
check_ivar("int2", "@\"Int2\""); check_ivar("int2", "@\"Int2\"");
check_ivar("nested", check_ivar("nested",
"{Nested=\"a\"f\"b\"f\"next\"@\"Int1\"\"innermost\"{Innermost=\"a\"C\"b\"C\"encl\"^{Nested}}}"); "{Nested=\"a\"f\"b\"f\"next\"@\"Int1\"\"innermost\"{Innermost=\"a\"C\"b\"C\"encl\"^{Nested}}}");
ivar = ((Class)OBJC_GETCLASS("Int2"))->ivars->ivar_list; #ifdef NEXT_OBJC_USE_NEW_INTERFACE
ivar = class_copyIvarList ((Class)objc_get_class("Int2"), NULL);
#else
ivar = ((Class)objc_get_class("Int2"))->ivars->ivar_list;
#endif
check_ivar("innermost", "^{Innermost=CC^{Nested}}"); check_ivar("innermost", "^{Innermost=CC^{Nested}}");
check_ivar("base", "@\"Int1\""); check_ivar("base", "@\"Int1\"");
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -9,20 +9,18 @@ ...@@ -9,20 +9,18 @@
/* Contributed by Alexander Malmberg <alexander@malmberg.org> */ /* Contributed by Alexander Malmberg <alexander@malmberg.org> */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#define METHOD Method #define METHOD Method
#define OBJC_GETCLASS objc_getClass
#define CLASS_GETINSTANCEMETHOD class_getInstanceMethod
#else #else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define METHOD Method_t #define METHOD Method_t
#define OBJC_GETCLASS objc_get_class #define method_get_types(M) (M)->method_types
#define CLASS_GETINSTANCEMETHOD class_get_instance_method
#endif #endif
@interface Test : Object @interface Test : Object
...@@ -49,7 +47,7 @@ int offs1, offs2, offs3, offs4, offs5, offs6; ...@@ -49,7 +47,7 @@ int offs1, offs2, offs3, offs4, offs5, offs6;
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
Class testClass = OBJC_GETCLASS("Test"); Class testClass = objc_get_class("Test");
METHOD meth; METHOD meth;
cc[0] = [Test new]; cc[0] = [Test new];
...@@ -60,16 +58,16 @@ int main(int argc, char **argv) ...@@ -60,16 +58,16 @@ int main(int argc, char **argv)
[*c test2: bb with: bb + 5]; [*c test2: bb with: bb + 5];
CHECK_IF (bb[3] == 5); CHECK_IF (bb[3] == 5);
meth = CLASS_GETINSTANCEMETHOD(testClass, @selector(test2:with:)); meth = class_get_instance_method(testClass, @selector(test2:with:));
offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1; offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1;
sscanf(meth->method_types, "v%d@%d:%d[%di]%d^i%d", &offs1, &offs2, &offs3, sscanf(method_get_types(meth), "v%d@%d:%d[%di]%d^i%d", &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6); &offs4, &offs5, &offs6);
CHECK_IF (!offs2 && offs4 == 5 && offs3 > 0); CHECK_IF (!offs2 && offs4 == 5 && offs3 > 0);
CHECK_IF (offs5 == 2 * offs3 && offs6 == 3 * offs3 && offs1 == 4 * offs3); CHECK_IF (offs5 == 2 * offs3 && offs6 == 3 * offs3 && offs1 == 4 * offs3);
meth = CLASS_GETINSTANCEMETHOD(testClass, @selector(test3:)); meth = class_get_instance_method(testClass, @selector(test3:));
offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1; offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1;
sscanf(meth->method_types, "v%d@%d:%d[%d[%d{Test=#f}]]%d", &offs1, &offs2, &offs3, sscanf(method_get_types(meth), "v%d@%d:%d[%d[%d{Test=#f}]]%d", &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6); &offs4, &offs5, &offs6);
CHECK_IF (!offs2 && offs4 == 3 && offs5 == 4 && offs3 > 0); CHECK_IF (!offs2 && offs4 == 3 && offs5 == 4 && offs3 > 0);
CHECK_IF (offs6 == 2 * offs3 && offs1 == 3 * offs3); CHECK_IF (offs6 == 2 * offs3 && offs1 == 3 * offs3);
......
...@@ -3,7 +3,6 @@ ...@@ -3,7 +3,6 @@
should be encoded as '*'). */ should be encoded as '*'). */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run { xfail { "*-*-*" } } } PR27249 */ /* { dg-do run { xfail { "*-*-*" } } } PR27249 */
/* { dg-options "-lobjc" } */
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
......
...@@ -8,14 +8,7 @@ ...@@ -8,14 +8,7 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include "../objc-obj-c++-shared/Object1.h"
@interface Object {
Class isa;
}
+ alloc;
- - init;
@end
// ObjectiveC class header // ObjectiveC class header
@interface ObjCclass : Object { @interface ObjCclass : Object {
...@@ -69,3 +62,5 @@ void CPPclass::function1() ...@@ -69,3 +62,5 @@ void CPPclass::function1()
/* Shouldn't be here because we threw. */ /* Shouldn't be here because we threw. */
abort (); abort ();
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
/* { dg-do assemble { target *-*-darwin* } } */ /* { dg-do assemble { target *-*-darwin* } } */
/* { dg-options "-mfix-and-continue" } */ /* { dg-options "-mfix-and-continue" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Foo: Object @interface Foo: Object
+ (Object *)indexableFileTypes; + (Object *)indexableFileTypes;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
the system runtime used). */ the system runtime used). */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include <objc/Object.h>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
regardless of runtime used on target system. */ regardless of runtime used on target system. */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include <objc/Object.h>
#include <string.h> #include <string.h>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
the system runtime used). */ the system runtime used). */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-options "-fgnu-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-xfail-if "PR23613" { "*-*-*" } { "*" } { "" } } */ /* { dg-xfail-if "PR23613" { "*-*-*" } { "*" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Object (Test) @interface Object (Test)
- (Class) test1: (id)object; - (Class) test1: (id)object;
...@@ -42,3 +42,4 @@ Class test3(id object) { ...@@ -42,3 +42,4 @@ Class test3(id object) {
Class cls = object->isa; Class cls = object->isa;
return cls; return cls;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Allow for an optional semicolon following the ivar block. */ /* Allow for an optional semicolon following the ivar block. */
/* Contributed by: Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by: Ziemowit Laski <zlaski@apple.com>. */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Tink : Object { @interface Tink : Object {
@private @private
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wpadded -Wpacked -Wabi" } */ /* { dg-options "-Wpadded -Wpacked -Wabi" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Derived1: Object @interface Derived1: Object
{ } { }
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Sprite: Object { @interface Sprite: Object {
int sprite, spree; int sprite, spree;
......
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-if "PR23614" { "*-*-*" } { "*" } { "" } } */ /* { dg-xfail-if "PR23614" { "*-*-*" } { "*" } { "" } } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
class MyWidget { class MyWidget {
...@@ -55,3 +55,5 @@ int main(void) { ...@@ -55,3 +55,5 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test for sending messages to aliased classes (and instances thereof). */ /* Test for sending messages to aliased classes (and instances thereof). */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -43,3 +43,4 @@ int main(void) { ...@@ -43,3 +43,4 @@ int main(void) {
CHECK_IF([(Int1Alias *)int2typedef instanceMeth] == 1697); CHECK_IF([(Int1Alias *)int2typedef instanceMeth] == 1697);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Check if class references (generated for the NeXT runtime) are appropriately /* Check if class references (generated for the NeXT runtime) are appropriately
folded. This test is safe to run on all targets. */ folded. This test is safe to run on all targets. */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime" } */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
typedef Object ObjectTypedef1; typedef Object ObjectTypedef1;
typedef ObjectTypedef1 ObjectTypedef2; typedef ObjectTypedef1 ObjectTypedef2;
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-options "-Wstrict-selector-match" } */ /* { dg-options "-Wstrict-selector-match" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Protocol.h> #include "../objc-obj-c++-shared/Protocol1.h"
@interface Base @interface Base
- (unsigned)port; - (unsigned)port;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* { dg-options "-Wstrict-selector-match" } */ /* { dg-options "-Wstrict-selector-match" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Class1 @interface Class1
- (void)setWindow:(Object *)wdw; - (void)setWindow:(Object *)wdw;
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-options "-Wstrict-selector-match" } */ /* { dg-options "-Wstrict-selector-match" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol MyObject @protocol MyObject
- (id)initWithData:(Object *)data; - (id)initWithData:(Object *)data;
......
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
message sends (so that proper C/C++ argument conversions may message sends (so that proper C/C++ argument conversions may
take place). */ take place). */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -30,3 +30,4 @@ int main(void) ...@@ -30,3 +30,4 @@ int main(void)
[foo brokenType: (int)d floatingPoint: d]; [foo brokenType: (int)d floatingPoint: d];
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,15 +3,12 @@ ...@@ -3,15 +3,12 @@
root classes must be considered. */ root classes must be considered. */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#ifdef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include <objc/objc-runtime.h>
#define OBJC_GETCLASS objc_getClass
#else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define OBJC_GETCLASS objc_get_class
#endif #endif
#include <stdlib.h> #include <stdlib.h>
...@@ -59,7 +56,7 @@ ...@@ -59,7 +56,7 @@
int main(void) int main(void)
{ {
Class obj = OBJC_GETCLASS("Derived"); Class obj = objc_get_class("Derived");
/* None of the following should elicit compiler-time warnings. */ /* None of the following should elicit compiler-time warnings. */
...@@ -78,3 +75,4 @@ int main(void) ...@@ -78,3 +75,4 @@ int main(void)
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class NSString; @class NSString;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wreturn-type -Wextra" } */ /* { dg-options "-Wreturn-type -Wextra" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Foo: Object @interface Foo: Object
- (id) meth1; - (id) meth1;
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class NotKnown; @class NotKnown;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// { dg-do compile } // { dg-do compile }
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <iostream> #include <iostream>
@interface Greeter : Object @interface Greeter : Object
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-options "-fobjc-gc" } */ /* { dg-options "-fobjc-gc" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class MyWindow; @class MyWindow;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
provide a suitable method. */ provide a suitable method. */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol Zot @protocol Zot
-(void) zot; -(void) zot;
......
...@@ -2,9 +2,10 @@ ...@@ -2,9 +2,10 @@
a protocol with no instance/class methods respectively. a protocol with no instance/class methods respectively.
Problem report and original fix by richard@brainstorm.co.uk. */ Problem report and original fix by richard@brainstorm.co.uk. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Protocol1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h> #include <objc/Object.h>
#include <objc/Protocol.h>
@protocol NoInstanceMethods @protocol NoInstanceMethods
+ + testMethod; + + testMethod;
......
...@@ -2,8 +2,8 @@ ...@@ -2,8 +2,8 @@
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Protocol.h> #include "../objc-obj-c++-shared/Protocol1.h"
#ifndef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include <objc/objc-api.h> #include <objc/objc-api.h>
#endif #endif
......
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -66,3 +66,4 @@ int main (void) { ...@@ -66,3 +66,4 @@ int main (void) {
CHECK_IF(FooHolder::counter == 0); CHECK_IF(FooHolder::counter == 0);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* { dg-options "-Wselector" } */ /* { dg-options "-Wselector" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Foo @interface Foo
@end @end
......
/* { dg-options "" } */ /* { dg-options "" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
int main() int main()
{ {
......
/* { dg-options "" } */ /* { dg-options "" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
int main() int main()
{ {
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class MyWpModule; @class MyWpModule;
......
...@@ -2,8 +2,8 @@ ...@@ -2,8 +2,8 @@
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -47,3 +47,4 @@ int main (void) { ...@@ -47,3 +47,4 @@ int main (void) {
CHECK_IF(count == 0); CHECK_IF(count == 0);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -78,3 +78,4 @@ int main(void) { ...@@ -78,3 +78,4 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-skip-if "" { *-*-darwin* } { "-m64" } { "" } } */ /* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h> #include "../objc-obj-c++-shared/next-mapping.h"
#include <stdarg.h> #include <stdarg.h>
#include <stdlib.h> #include <stdlib.h>
#ifdef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
/* The following ain't pretty, but does allow us to have just one copy
of next_mapping.h. */
#include "../objc/execute/next_mapping.h"
#else
#include <objc/NXConstStr.h> #include <objc/NXConstStr.h>
#endif #endif
...@@ -80,3 +76,4 @@ int main(void) { ...@@ -80,3 +76,4 @@ int main(void) {
CHECK_IF(abc(a1, a2) * t.k == 35); CHECK_IF(abc(a1, a2) * t.k == 35);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdio.h> #include <stdio.h>
#include <setjmp.h> #include <setjmp.h>
......
/* Ensure that @try/@catch blocks do not mess with types of /* Ensure that @try/@catch blocks do not mess with types of
local objects (other than their volatile bits). */ local objects (other than their volatile bits). */
/* { dg-options "-fobjc-exceptions -fnext-runtime" } */ /* { dg-options "-fobjc-exceptions" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol Proto1 @protocol Proto1
- (int)meth1; - (int)meth1;
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
/* { dg-xfail-if "PR23616" { "*-*-*" } { "*" } { "" } } */ /* { dg-xfail-if "PR23616" { "*-*-*" } { "*" } { "" } } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
...@@ -77,3 +77,4 @@ int main (void) { ...@@ -77,3 +77,4 @@ int main (void) {
test((Object *)-1); test((Object *)-1);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
const char *foo(void) const char *foo(void)
{ {
......
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
int main (int argc, const char * argv[]) { int main (int argc, const char * argv[]) {
Object * pool = [Object new]; Object * pool = [Object new];
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Derived: Object @interface Derived: Object
- (id) meth; - (id) meth;
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
/* { dg-prune-output ".*internal compiler error.*" } */ /* { dg-prune-output ".*internal compiler error.*" } */
/* { dg-options "-fobjc-exceptions -O2" } */ /* { dg-options "-fobjc-exceptions -O2" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
...@@ -65,3 +65,4 @@ int main(void) { ...@@ -65,3 +65,4 @@ int main(void) {
foo(15, &gf1); foo(15, &gf1);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Typedefs of ObjC types should work without any bogus warnings. */ /* Typedefs of ObjC types should work without any bogus warnings. */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
typedef Object MyObject; typedef Object MyObject;
......
/* Based on objc/execute/va_method.m, by Nicola Pero */ /* Based on objc/execute/va_method.m, by Nicola Pero */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdarg.h> #include <stdarg.h>
#include <stdlib.h> #include <stdlib.h>
...@@ -72,3 +72,4 @@ int main (void) ...@@ -72,3 +72,4 @@ int main (void)
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* This provides a minimal implementation of the Object root class.
* It is split from the definition so that it can be placed
* at the end of source files that require it. This reduces
* clutter in .s and other internmediate code while debugging.
*/
#ifndef _OBJC_OBJECT1_IMPLEMENTATION_H_
#define _OBJC_OBJECT1_IMPLEMENTATION_H_
#ifdef DO_NEXT_M64_OBJECT_IMPLEMENTATION
@implementation Object
+ + initialize {
return self;
}
- init {
return self;
}
+ class {
return object_getClass(self);
}
+ new {
return [[self alloc] init];
}
+ free {
return nil;
}
- free {
return object_dispose(self);
}
+ alloc {
return class_createInstance(self, 0);
}
- class {
return isa;
}
- superclass {
return class_getSuperclass([self class]);
}
- (const char *) name {
return class_getName([self class]);
}
-(BOOL)conformsTo:(Protocol *)protocol {
Class cls;
for (cls = [self class]; cls; cls = [cls superclass]) {
if (class_conformsToProtocol(cls, protocol)) return YES;
}
return NO;
}
@end
#endif /* NEEDS_OBJECT_IMPLEMENTATION */
#endif /* _OBJC_OBJECT1_IMPLEMENTATION_H_ */
\ No newline at end of file
/* Object definition taken from <objc/Object.h> */#ifndef _OBJC_OBJECT1_H_ #define _OBJC_OBJECT1_H_ #undef DO_NEXT_M64_OBJECT_IMPLEMENTATION #ifndef __NEXT_RUNTIME__ # include <objc/Object.h> #else # include "next-abi.h" # ifndef NEXT_OBJC_USE_NEW_INTERFACE/* We are on a next system, or version, that is happy to compile V0 ABI */ # include <objc/Object.h> # else # if (NEXT_OBJC_ABI_VERSION==0)/* We are on a system that has V0 ABI implementation in libobjc.dylib. * However, we need to use the new accessors and pretend that the * structures are opaque to avoid 'deprecated' warnings */ # include <objc/Object.h> # else/* We are on a system that includes a V2 ABI Object in libobjc.dylib. */ # ifdef __OBJC2__/* ... and we have a V2 ABI compiler .. */ # include <objc/Object.h> # else/* We can't access the Object definition in libobjc.dylib because * we can't yet generate OBJC2 code. * * So we'll roll our own Object - purely for the sake of compile * checks - the code is unlikely to run... */ # ifndef _OBJC_OBJECT_H_ # define _OBJC_OBJECT_H_ #include <stdarg.h> #import <objc/objc-runtime.h> /* This is a cut-down Object with only the methods currently required by the testsuite declared. For those executables that require an implementation (to link) this can be provided in a given test by placing: #include "path/to/objc-c++shared/Object1-implementation.h" at the end of the source for the test. */ @interface Object { Class isa; /* A pointer to the instance's class structure */ } + initialize; - init; + new; + free; - free; + alloc; //- copy; //+ allocFromZone:(void *)zone; //- copyFromZone:(void *)zone; //- (void *)zone; + class; //+ superclass; //+ (const char *) name; - class; - superclass; - (const char *) name; //- self; //- (unsigned int) hash; //-(BOOL) isEqual:anObject; /* Testing inheritance relationships */ //- (BOOL) isKindOf: aClassObject; //- (BOOL) isMemberOf: aClassObject; //- (BOOL) isKindOfClassNamed: (const char *)aClassName; //- (BOOL) isMemberOfClassNamed: (const char *)aClassName; /* Testing class functionality */ //+ (BOOL) instancesRespondTo:(SEL)aSelector; //- (BOOL) respondsTo:(SEL)aSelector; /* Testing protocol conformance */ - (BOOL) conformsTo: (Protocol *)aProtocolObject; //+ (BOOL) conformsTo: (Protocol *)aProtocolObject; /* Obtaining method descriptors from protocols */ //- (struct objc_method_description *) descriptionForMethod:(SEL)aSel; //+ (struct objc_method_description *) descriptionForInstanceMethod:(SEL)aSel; /* Obtaining method handles */ //- (IMP) methodFor:(SEL)aSelector; //+ (IMP) instanceMethodFor:(SEL)aSelector; /* Sending messages determined at run time */ //- perform:(SEL)aSelector; //- perform:(SEL)aSelector with:anObject; //- perform:(SEL)aSelector with:object1 with:object2; /* Posing */ //+ poseAs: aClassObject; /* Enforcing intentions */ //- subclassResponsibility:(SEL)aSelector; //- notImplemented:(SEL)aSelector; /* Error handling */ //- doesNotRecognize:(SEL)aSelector; //- error:(const char *)aString, ...; /* Debugging */ //- (void) printForDebugger:(void *)stream; /* Archiving */ //- awake; //- write:(void *)stream; //- read:(void *)stream; //+ (int) version; //+ setVersion: (int) aVersion; /* Forwarding */ //- forward: (SEL)sel : (marg_list)args; //- performv: (SEL)sel : (marg_list)args; @end #define DO_NEXT_M64_OBJECT_IMPLEMENTATION # endif /* _OBJC_OBJECT_H_ */ # endif /* __OBJC2__ */ # endif /* ABI=0 */ # endif /* NEXT_OBJC_USE_NEW_INTERFACE */ # endif /* __NEXT_RUNTIME__ */ #endif /* _OBJC_OBJECT1_H_ */
\ No newline at end of file
/*
* Temporary work-around to avoid the need for method attributes in
* the NeXT Runtime Protocol header.
*/
#ifndef _OBJC_PROTOCOL1_H_
#define _OBJC_PROTOCOL1_H_
# ifndef __NEXT_RUNTIME__
# include <objc/Protocol.h>
# else
# include "next-abi.h"
# ifndef NEXT_OBJC_USE_NEW_INTERFACE
/* We are on a NeXT version without method __attributes__ */
# import <objc/Protocol.h>
# else
/* We make our own interface without the deprecation messages
* This is essentially <objc/Protocol.h> without the OBJC2
* flags.
*
*/
# ifndef _OBJC_PROTOCOL_H_
# define _OBJC_PROTOCOL_H_
# import "Object1.h"
@interface Protocol : Object
{
@private
char *protocol_name ;
struct objc_protocol_list *protocol_list ;
struct objc_method_description_list *instance_methods ;
struct objc_method_description_list *class_methods ;
}
/* Obtaining attributes intrinsic to the protocol */
#if (NEXT_OBJC_ABI_VERSION==0)
- (const char *)name ; /* Not avail in v2, deprecated in prior */
/* Testing protocol conformance */
- (BOOL) conformsTo: (Protocol *)aProtocolObject ; /* Not avail in v2 */
#endif
/* Looking up information specific to a protocol */
/* Deprecated, but available */
- (struct objc_method_description *) descriptionForInstanceMethod:(SEL)aSel ;
- (struct objc_method_description *) descriptionForClassMethod:(SEL)aSel ;
@end
# endif /* __NEXT_RUNTIME__ */
# endif /* _OBJC_PROTOCOL_H_ */
# endif /* NEXT_OBJC_ABI_VERSION */
#endif /* _OBJC_PROTOCOL1_H_ */
#ifndef _OBJC_NEXT_ABI_H_
#define _OBJC_NEXT_ABI_H_
/* Produce a define that allows us to figure out what facilities are
available for this gcc and OS combination.
*/
/* By default we do nothing - therefore ifdef NEXT_OBJC_USE_NEW_INTERFACE
* is reliable for detecting
* (a) versions of the compiler that are transitional to the new next ABI
* (b) versions of the target that require the new ABI.
*
* This applies for versions of OSX >= 10.5 (darwin9).
*
* A compiler capable of producing ObjC V2 ABI should define __OBJC2__
*/
#undef NEXT_OBJC_ABI_VERSION
#undef NEXT_OBJC_USE_NEW_INTERFACE
#ifdef __NEXT_RUNTIME__
# if (MAC_OS_X_VERSION_MIN_REQUIRED >= MAC_OS_X_VERSION_10_5 || __OBJC2__)
/* We have to use an updated interface for 32bit NeXT to avoid
* 'deprecated' warnings.
* For 64bit NeXT the ABI is different (and the interfaces 'deprecated'
* for 32bit have been removed).
*/
# define NEXT_OBJC_USE_NEW_INTERFACE 1
# if __OBJC2__ || __LP64__
/* We have OBJC v2 ABI compiler,
(or, at least, the available NeXT runtime requires one) */
# define NEXT_OBJC_ABI_VERSION 2
# else
/* We leave it open to define ABI 1 if and when we implement those
* extensions.
*/
# define NEXT_OBJC_ABI_VERSION 0
# endif
# endif
#endif
#endif /* _OBJC_NEXT_ABI_H_ */
/* This file "renames" various ObjC GNU runtime entry points
(and fakes the existence of several others)
if the NeXT runtime is being used. */
/* Authors: Ziemowit Laski <zlaski@apple.com> */
/* David Ayers <d.ayers@inode.at> */
/* Darwin 64bit/OBJC2 modifications Iain Sandoe */
#ifdef __NEXT_RUNTIME__
/* Includes next-abi.h to set NEXT_OBJC_USE_NEW_INTERFACE etc.*/
#ifndef _OBJC_OBJECT1_H_
#include "Object1.h"
#endif
#include <objc/objc-class.h>
#include <ctype.h>
#include <stdlib.h>
#include <string.h>
#define objc_get_class(C) objc_getClass(C)
#define objc_get_meta_class(C) objc_getMetaClass(C)
#define class_get_class_method(C, S) class_getClassMethod(C, S)
#define class_get_instance_method(C, S) class_getInstanceMethod(C, S)
#define sel_get_name(S) sel_getName(S)
#define class_create_instance(C) class_createInstance(C, 0)
#define class_get_class_name(C) object_getClassName(C)
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
# define object_class_name(O) (object_getClassName(O))
# define object_get_class(O) (object_getClass((id)O))
# define object_get_super_class(O) class_get_super_class(object_get_class(O))
# define object_is_class(O) class_is_meta_class(object_get_class(O))
# define object_is_meta_class(O) (object_is_class(O) && class_is_meta_class(O) \
&& class_is_meta_class(object_get_class(O)))
# define method_get_imp(M) (method_getImplementation((Method)M))
# define method_get_types(M) (method_getTypeEncoding((Method)M))
# define class_get_super_class(C) (class_getSuperclass((Class)C))
# define class_is_meta_class(C) (class_isMetaClass((Class)C) ? YES: NO)
# define class_is_class(C) (class_is_meta_class(C) == NO)
#else
# define object_class_name(O) (O->name)
# define object_get_super_class(O) class_get_super_class(*(struct objc_class **)O)
# define object_get_class(O) (*(struct objc_class **)O)
# define object_is_class(O) class_is_meta_class(*(struct objc_class **)O)
# define object_is_meta_class(O) (class_is_meta_class(O) && class_is_meta_class(*(struct objc_class **)O))
# define method_get_imp(M) (((Method)M)->method_imp)
# define method_get_types(M) (((Method)M)->method_types)
# define class_get_super_class(C) (((struct objc_class *)C)->super_class)
# define class_is_meta_class(C) (CLS_GETINFO((struct objc_class *)C, CLS_META)? YES: NO)
# define class_is_class(C) (CLS_GETINFO((struct objc_class *)C, CLS_CLASS)? YES: NO)
#endif
#define objc_lookup_class(N) objc_lookUpClass(N)
/* You need either an empty +initialize method or an empty -forward:: method.
The NeXT runtime unconditionally sends +initialize to classes when they are
first used, and unconditionally tries to forward methods that the class
doesn't understand (including +initialize). If you have neither +initialize
nor -forward::, the runtime complains.
The simplest workaround is to add
+ initialize { return self; }
to every root class @implementation. */
#ifndef NULL
#define NULL 0
#endif
/* The following is necessary to "cover" the bf*.m test cases on NeXT. */
#undef MAX
#undef MIN
#undef ROUND
#ifdef __cplusplus
# define MAX(X, Y) ((X > Y) ? X : Y)
# define MIN(X, Y) ((X < Y) ? X : Y)
# define ROUND(V, A) (A * ((V + A - 1) / A))
#else
# define MAX(X, Y) \
({ typeof (X) __x = (X), __y = (Y); \
(__x > __y ? __x : __y); })
# define MIN(X, Y) \
({ typeof (X) __x = (X), __y = (Y); \
(__x < __y ? __x : __y); })
# define ROUND(V, A) \
({ typeof (V) __v = (V); typeof (A) __a = (A); \
__a * ((__v+__a - 1)/__a); })
#endif
#define BITS_PER_UNIT __CHAR_BIT__
typedef struct{ char a; } __small_struct;
#define STRUCTURE_SIZE_BOUNDARY (BITS_PER_UNIT * sizeof (__small_struct))
/* Not sure why the following are missing from NeXT objc headers... */
#ifndef _C_LNG_LNG
#define _C_LNG_LNG 'q'
#endif
#ifndef _C_ULNG_LNG
#define _C_ULNG_LNG 'Q'
#endif
#ifndef _C_ATOM
#define _C_ATOM '%'
#endif
#ifndef _C_BOOL
#define _C_BOOL 'B'
#endif
#define _C_CONST 'r'
#define _C_IN 'n'
#define _C_INOUT 'N'
#define _C_OUT 'o'
#define _C_BYCOPY 'O'
#define _C_BYREF 'R'
#define _C_ONEWAY 'V'
#define _C_GCINVISIBLE '!'
#define _F_CONST 0x01
#define _F_IN 0x01
#define _F_OUT 0x02
#define _F_INOUT 0x03
#define _F_BYCOPY 0x04
#define _F_BYREF 0x08
#define _F_ONEWAY 0x10
#define _F_GCINVISIBLE 0x20
struct objc_struct_layout
{
const char *original_type;
const char *type;
const char *prev_type;
unsigned int record_size;
unsigned int record_align;
};
typedef union arglist {
char *arg_ptr;
char arg_regs[sizeof (char*)];
} *arglist_t; /* argument frame */
const char *objc_skip_typespec (const char *type);
void objc_layout_structure_get_info (struct objc_struct_layout *layout,
unsigned int *offset, unsigned int *align, const char **type);
void objc_layout_structure (const char *type,
struct objc_struct_layout *layout);
BOOL objc_layout_structure_next_member (struct objc_struct_layout *layout);
void objc_layout_finish_structure (struct objc_struct_layout *layout,
unsigned int *size, unsigned int *align);
int objc_aligned_size (const char *type);
/*
return the size of an object specified by type
*/
int
objc_sizeof_type (const char *type)
{
/* Skip the variable name if any */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
switch (*type) {
case _C_ID:
return sizeof (id);
break;
case _C_CLASS:
return sizeof (Class);
break;
case _C_SEL:
return sizeof (SEL);
break;
case _C_CHR:
return sizeof (char);
break;
case _C_UCHR:
return sizeof (unsigned char);
break;
case _C_SHT:
return sizeof (short);
break;
case _C_USHT:
return sizeof (unsigned short);
break;
case _C_INT:
return sizeof (int);
break;
case _C_UINT:
return sizeof (unsigned int);
break;
case _C_LNG:
return sizeof (long);
break;
case _C_ULNG:
return sizeof (unsigned long);
break;
case _C_LNG_LNG:
return sizeof (long long);
break;
case _C_ULNG_LNG:
return sizeof (unsigned long long);
break;
case _C_FLT:
return sizeof (float);
break;
case _C_DBL:
return sizeof (double);
break;
case _C_PTR:
case _C_ATOM:
case _C_CHARPTR:
return sizeof (char *);
break;
case _C_ARY_B:
{
int len = atoi (type + 1);
while (isdigit ((unsigned char)*++type))
;
return len * objc_aligned_size (type);
}
break;
case _C_BFLD:
{
/* The NeXT encoding of bitfields is _still_: b 'size' */
int size = atoi (type + 1);
/* Return an upper bound on byte size */
return (size + BITS_PER_UNIT - 1) / BITS_PER_UNIT;
}
case _C_STRUCT_B:
{
struct objc_struct_layout layout;
unsigned int size;
objc_layout_structure (type, &layout);
while (objc_layout_structure_next_member (&layout))
/* do nothing */ ;
objc_layout_finish_structure (&layout, &size, NULL);
return size;
}
case _C_UNION_B:
{
int max_size = 0;
while (*type != _C_UNION_E && *type++ != '=')
/* do nothing */;
while (*type != _C_UNION_E)
{
/* Skip the variable name if any */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
max_size = MAX (max_size, objc_sizeof_type (type));
type = objc_skip_typespec (type);
}
return max_size;
}
}
return 0; /* error */
}
/*
Return the alignment of an object specified by type
*/
int
objc_alignof_type (const char *type)
{
/* Skip the variable name if any */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
switch (*type) {
case _C_ID:
return __alignof__ (id);
break;
case _C_CLASS:
return __alignof__ (Class);
break;
case _C_SEL:
return __alignof__ (SEL);
break;
case _C_CHR:
return __alignof__ (char);
break;
case _C_UCHR:
return __alignof__ (unsigned char);
break;
case _C_SHT:
return __alignof__ (short);
break;
case _C_USHT:
return __alignof__ (unsigned short);
break;
case _C_INT:
case _C_BFLD: /* This is for the NeXT only */
return __alignof__ (int);
break;
case _C_UINT:
return __alignof__ (unsigned int);
break;
case _C_LNG:
return __alignof__ (long);
break;
case _C_ULNG:
return __alignof__ (unsigned long);
break;
case _C_LNG_LNG:
return __alignof__ (long long);
break;
case _C_ULNG_LNG:
return __alignof__ (unsigned long long);
break;
case _C_FLT:
return __alignof__ (float);
break;
case _C_DBL:
return __alignof__ (double);
break;
case _C_PTR:
case _C_ATOM:
case _C_CHARPTR:
return __alignof__ (char *);
break;
case _C_ARY_B:
while (isdigit ((unsigned char)*++type))
/* do nothing */;
return objc_alignof_type (type);
case _C_STRUCT_B:
{
struct objc_struct_layout layout;
unsigned int align;
objc_layout_structure (type, &layout);
while (objc_layout_structure_next_member (&layout))
/* do nothing */;
objc_layout_finish_structure (&layout, NULL, &align);
return align;
}
case _C_UNION_B:
{
int maxalign = 0;
while (*type != _C_UNION_E && *type++ != '=')
/* do nothing */;
while (*type != _C_UNION_E)
{
/* Skip the variable name if any */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
maxalign = MAX (maxalign, objc_alignof_type (type));
type = objc_skip_typespec (type);
}
return maxalign;
}
}
return 0; /* error */
}
/*
The aligned size if the size rounded up to the nearest alignment.
*/
int
objc_aligned_size (const char *type)
{
int size, align;
/* Skip the variable name */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
size = objc_sizeof_type (type);
align = objc_alignof_type (type);
return ROUND (size, align);
}
/*
The size rounded up to the nearest integral of the wordsize, taken
to be the size of a void *.
*/
int
objc_promoted_size (const char *type)
{
int size, wordsize;
/* Skip the variable name */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
size = objc_sizeof_type (type);
wordsize = sizeof (void *);
return ROUND (size, wordsize);
}
/*
Skip type qualifiers. These may eventually precede typespecs
occurring in method prototype encodings.
*/
inline const char *
objc_skip_type_qualifiers (const char *type)
{
while (*type == _C_CONST
|| *type == _C_IN
|| *type == _C_INOUT
|| *type == _C_OUT
|| *type == _C_BYCOPY
|| *type == _C_BYREF
|| *type == _C_ONEWAY
|| *type == _C_GCINVISIBLE)
{
type += 1;
}
return type;
}
/*
Skip one typespec element. If the typespec is prepended by type
qualifiers, these are skipped as well.
*/
const char *
objc_skip_typespec (const char *type)
{
/* Skip the variable name if any */
if (*type == '"')
{
for (type++; *type++ != '"';)
/* do nothing */;
}
type = objc_skip_type_qualifiers (type);
switch (*type) {
case _C_ID:
/* An id may be annotated by the actual type if it is known
with the @"ClassName" syntax */
if (*++type != '"')
return type;
else
{
while (*++type != '"')
/* do nothing */;
return type + 1;
}
/* The following are one character type codes */
case _C_CLASS:
case _C_SEL:
case _C_CHR:
case _C_UCHR:
case _C_CHARPTR:
case _C_ATOM:
case _C_SHT:
case _C_USHT:
case _C_INT:
case _C_UINT:
case _C_LNG:
case _C_ULNG:
case _C_LNG_LNG:
case _C_ULNG_LNG:
case _C_FLT:
case _C_DBL:
case _C_VOID:
case _C_UNDEF:
return ++type;
break;
case _C_ARY_B:
/* skip digits, typespec and closing ']' */
while (isdigit ((unsigned char)*++type))
;
type = objc_skip_typespec (type);
if (*type == _C_ARY_E)
return ++type;
else
break; /* error */
case _C_BFLD:
/* The NeXT encoding for bitfields is _still_: b 'size' */
while (isdigit ((unsigned char)*++type))
; /* skip type and size */
return type;
case _C_STRUCT_B:
/* skip name, and elements until closing '}' */
while (*type != _C_STRUCT_E && *type++ != '=')
;
while (*type != _C_STRUCT_E)
{
type = objc_skip_typespec (type);
}
return ++type;
case _C_UNION_B:
/* skip name, and elements until closing ')' */
while (*type != _C_UNION_E && *type++ != '=')
;
while (*type != _C_UNION_E)
{
type = objc_skip_typespec (type);
}
return ++type;
case _C_PTR:
/* Just skip the following typespec */
return objc_skip_typespec (++type);
}
return 0; /* error */
}
/*
Skip an offset as part of a method encoding. This is prepended by a
'+' if the argument is passed in registers.
*/
inline const char *
objc_skip_offset (const char *type)
{
if (*type == '+')
type++;
while (isdigit ((unsigned char) *++type))
;
return type;
}
/*
Skip an argument specification of a method encoding.
*/
const char *
objc_skip_argspec (const char *type)
{
type = objc_skip_typespec (type);
type = objc_skip_offset (type);
return type;
}
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
typedef void *PMETH;
#else
typedef struct objc_method *PMETH;
#endif
/*
Return the number of arguments that the method MTH expects.
Note that all methods need two implicit arguments `self' and
`_cmd'.
*/
int
method_get_number_of_arguments (PMETH mth)
{
int i = 0;
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
const char *type = method_getTypeEncoding((Method)mth);
#else
const char *type = mth->method_types;
#endif
while (*type)
{
type = objc_skip_argspec (type);
i += 1;
}
return i - 1;
}
/*
Return the size of the argument block needed on the stack to invoke
the method MTH. This may be zero, if all arguments are passed in
registers.
*/
int
method_get_sizeof_arguments (PMETH mth)
{
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
const char *type = objc_skip_typespec (method_getTypeEncoding((Method)mth));
#else
const char *type = objc_skip_typespec (mth->method_types);
#endif
return atoi (type);
}
/*
Return a pointer to the next argument of ARGFRAME. type points to
the last argument. Typical use of this look like:
{
char *datum, *type;
for (datum = method_get_first_argument (method, argframe, &type);
datum; datum = method_get_next_argument (argframe, &type))
{
unsigned flags = objc_get_type_qualifiers (type);
type = objc_skip_type_qualifiers (type);
if (*type != _C_PTR)
[portal encodeData: datum ofType: type];
else
{
if ((flags & _F_IN) == _F_IN)
[portal encodeData: *(char **) datum ofType: ++type];
}
}
}
*/
char *
method_get_next_argument (arglist_t argframe, const char **type)
{
const char *t = objc_skip_argspec (*type);
if (*t == '\0')
return 0;
*type = t;
t = objc_skip_typespec (t);
if (*t == '+')
return argframe->arg_regs + atoi (++t);
else
return argframe->arg_ptr + atoi (t);
}
/*
Return a pointer to the value of the first argument of the method
described in M with the given argumentframe ARGFRAME. The type
is returned in TYPE. type must be passed to successive calls of
method_get_next_argument.
*/
char *
method_get_first_argument (PMETH m,
arglist_t argframe,
const char **type)
{
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
*type = method_getTypeEncoding((Method)m);
#else
*type = m->method_types;
#endif
return method_get_next_argument (argframe, type);
}
/*
Return a pointer to the ARGth argument of the method
M from the frame ARGFRAME. The type of the argument
is returned in the value-result argument TYPE
*/
char *
method_get_nth_argument (PMETH m,
arglist_t argframe, int arg,
const char **type)
{
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
const char *t = objc_skip_argspec (method_getTypeEncoding((Method)m));
#else
const char *t = objc_skip_argspec (m->method_types);
#endif
if (arg > method_get_number_of_arguments (m))
return 0;
while (arg--)
t = objc_skip_argspec (t);
*type = t;
t = objc_skip_typespec (t);
if (*t == '+')
return argframe->arg_regs + atoi (++t);
else
return argframe->arg_ptr + atoi (t);
}
unsigned
objc_get_type_qualifiers (const char *type)
{
unsigned res = 0;
BOOL flag = YES;
while (flag)
switch (*type++)
{
case _C_CONST: res |= _F_CONST; break;
case _C_IN: res |= _F_IN; break;
case _C_INOUT: res |= _F_INOUT; break;
case _C_OUT: res |= _F_OUT; break;
case _C_BYCOPY: res |= _F_BYCOPY; break;
case _C_BYREF: res |= _F_BYREF; break;
case _C_ONEWAY: res |= _F_ONEWAY; break;
case _C_GCINVISIBLE: res |= _F_GCINVISIBLE; break;
default: flag = NO;
}
return res;
}
/* The following three functions can be used to determine how a
structure is laid out by the compiler. For example:
struct objc_struct_layout layout;
int i;
objc_layout_structure (type, &layout);
while (objc_layout_structure_next_member (&layout))
{
int position, align;
const char *type;
objc_layout_structure_get_info (&layout, &position, &align, &type);
printf ("element %d has offset %d, alignment %d\n",
i++, position, align);
}
These functions are used by objc_sizeof_type and objc_alignof_type
functions to compute the size and alignment of structures. The
previous method of computing the size and alignment of a structure
was not working on some architectures, particulary on AIX, and in
the presence of bitfields inside the structure. */
void
objc_layout_structure (const char *type,
struct objc_struct_layout *layout)
{
const char *ntype;
layout->original_type = ++type;
/* Skip "<name>=" if any. Avoid embedded structures and unions. */
ntype = type;
while (*ntype != _C_STRUCT_E && *ntype != _C_STRUCT_B && *ntype != _C_UNION_B
&& *ntype++ != '=')
/* do nothing */;
/* If there's a "<name>=", ntype - 1 points to '='; skip the the name */
if (*(ntype - 1) == '=')
type = ntype;
layout->type = type;
layout->prev_type = NULL;
layout->record_size = 0;
layout->record_align = MAX (BITS_PER_UNIT, STRUCTURE_SIZE_BOUNDARY);
}
BOOL
objc_layout_structure_next_member (struct objc_struct_layout *layout)
{
register int desired_align = 0;
/* The current type without the type qualifiers */
const char *type;
/* Add the size of the previous field to the size of the record. */
if (layout->prev_type)
{
type = objc_skip_type_qualifiers (layout->prev_type);
if (*type != _C_BFLD)
layout->record_size += objc_sizeof_type (type) * BITS_PER_UNIT;
else
layout->record_size += atoi (++type);
}
if (*layout->type == _C_STRUCT_E)
return NO;
/* Skip the variable name if any */
if (*layout->type == '"')
{
for (layout->type++; *layout->type++ != '"';)
/* do nothing */;
}
type = objc_skip_type_qualifiers (layout->type);
desired_align = objc_alignof_type (type) * BITS_PER_UNIT;
/* Record must have at least as much alignment as any field.
Otherwise, the alignment of the field within the record
is meaningless. */
layout->record_align = MAX (layout->record_align, desired_align);
if (*type == _C_BFLD)
{
int bfld_size = atoi (++type);
int int_align = __alignof__ (int) * BITS_PER_UNIT;
/* If this bitfield would traverse a word alignment boundary, push it out
to that boundary instead. */
if (layout->record_size % int_align
&& (layout->record_size / int_align
< (layout->record_size + bfld_size - 1) / int_align))
layout->record_size = ROUND (layout->record_size, int_align);
}
else if (layout->record_size % desired_align != 0)
{
/* We need to skip space before this field.
Bump the cumulative size to multiple of field alignment. */
layout->record_size = ROUND (layout->record_size, desired_align);
}
/* Jump to the next field in record. */
layout->prev_type = layout->type;
layout->type = objc_skip_typespec (layout->type); /* skip component */
return YES;
}
void objc_layout_finish_structure (struct objc_struct_layout *layout,
unsigned int *size,
unsigned int *align)
{
if (layout->type && *layout->type == _C_STRUCT_E)
{
/* Round the size up to be a multiple of the required alignment */
layout->record_size = ROUND (layout->record_size, layout->record_align);
layout->type = NULL;
}
if (size)
*size = layout->record_size / BITS_PER_UNIT;
if (align)
*align = layout->record_align / BITS_PER_UNIT;
}
void objc_layout_structure_get_info (struct objc_struct_layout *layout,
unsigned int *offset,
unsigned int *align,
const char **type)
{
if (offset)
*offset = layout->record_size / BITS_PER_UNIT;
if (align)
*align = layout->record_align / BITS_PER_UNIT;
if (type)
*type = layout->prev_type;
}
/* A small, portable NSConstantString implementation for use with the NeXT
runtime.
On full-fledged Mac OS X systems, NSConstantString is provided
as part of the Foundation framework. However, on bare Darwin systems,
Foundation is not included, and hence there is no NSConstantString
implementation to link against.
This code is derived from the GNU runtime's NXConstantString implementation.
*/
/* This definition cut out of <objc/Object.h> with the OBJC2 deprecation
messages removed.
*/
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
struct fudge_objc_class {
Class isa;
#if NEXT_OBJC_ABI_VERSION < 2
Class super_class ;
const char *name ;
long version ;
long info ;
long instance_size ;
struct anon *ivars ; /* objc_ivar_list */
struct anon1 **methodLists ; /* objc_method_list */
struct objc_cache *cache ;
struct objc_protocol_list *protocols ;
#endif
} _NSConstantStringClassReference ;
#else
struct objc_class _NSConstantStringClassReference ;
#endif
@interface NSConstantString : Object
{
char *c_string;
unsigned int len;
}
-(const char *) cString;
-(unsigned int) length;
@end
@implementation NSConstantString
-(const char *) cString
{
return (c_string);
}
-(unsigned int) length
{
return (len);
}
@end
/* The NSConstantString metaclass will need to be initialized before we can
send messages to strings. */
void objc_constant_string_init (void) __attribute__((constructor));
void objc_constant_string_init (void) {
memcpy (&_NSConstantStringClassReference,
objc_getClass ("NSConstantString"),
sizeof (_NSConstantStringClassReference));
}
#endif /* #ifdef __NEXT_RUNTIME__ */
...@@ -2,9 +2,10 @@ ...@@ -2,9 +2,10 @@
being "promoted" to ints). */ being "promoted" to ints). */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
...@@ -78,3 +79,5 @@ int main(void) { ...@@ -78,3 +79,5 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Check if bitfield ivars are correctly @encode'd when /* Check if bitfield ivars are correctly @encode'd when
the NeXT runtime is used. */ the NeXT runtime is used. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime -fsigned-char" } */ /* { dg-options "-fsigned-char" } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
typedef struct objc_object { struct objc_class *class_pointer; } *id; typedef struct objc_object { struct objc_class *class_pointer; } *id;
......
/* Check if the @defs() construct preserves the correct /* Check if the @defs() construct preserves the correct
layout of bitfields. */ layout of bitfields. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc -Wpadded" } */ /* { dg-options "-Wpadded" } */
/* { dg-do run } */ /* { dg-do run } */
#include <objc/objc.h> #include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
extern int strcmp(const char *str1, const char *str2); extern int strcmp(const char *str1, const char *str2);
......
...@@ -7,8 +7,8 @@ ...@@ -7,8 +7,8 @@
/* { dg-options "-Wpadded" } */ /* { dg-options "-Wpadded" } */
/* { dg-do run } */ /* { dg-do run } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
......
/* Check if objc_super stack variables are created correctly (and /* Check if objc_super stack variables are created correctly (and
not clobbered by other values). */ not clobbered by other values). */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-std=c99 -lobjc" } */ /* { dg-options "-std=c99" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/objc.h> #include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
...@@ -74,3 +74,5 @@ int main(void) { ...@@ -74,3 +74,5 @@ int main(void) {
[v free]; [v free];
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Check if casting 'self' or 'super' affects message lookup in the /* Check if casting 'self' or 'super' affects message lookup in the correct way. */
correct way. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do compile } */ /* { dg-do compile } */
#include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
#include <stddef.h> #include <stddef.h>
#include <objc/objc.h>
#include <objc/Object.h>
#ifdef __NEXT_RUNTIME__
#define OBJC_GETCLASS objc_getClass
#else
#define OBJC_GETCLASS objc_get_class
#endif
@protocol Func @protocol Func
+ (int) class_func0; + (int) class_func0;
...@@ -70,11 +63,11 @@ ...@@ -70,11 +63,11 @@
} }
+ (int) class_func6 + (int) class_func6
{ {
return (size_t)[OBJC_GETCLASS("Object") class_func1]; /* { dg-warning ".Object. may not respond to .\\+class_func1." } */ return (size_t)[objc_get_class("Object") class_func1]; /* { dg-warning ".Object. may not respond to .\\+class_func1." } */
} }
+ (int) class_func7 + (int) class_func7
{ {
return [OBJC_GETCLASS("Derived") class_func1]; return [objc_get_class("Derived") class_func1];
} }
- (int) instance_func1 - (int) instance_func1
{ {
...@@ -100,11 +93,11 @@ ...@@ -100,11 +93,11 @@
} }
- (int) instance_func6 - (int) instance_func6
{ {
return (size_t)[OBJC_GETCLASS("Object") class_func1]; /* { dg-warning ".Object. may not respond to .\\+class_func1." } */ return (size_t)[objc_get_class("Object") class_func1]; /* { dg-warning ".Object. may not respond to .\\+class_func1." } */
} }
- (int) instance_func7 - (int) instance_func7
{ {
return [OBJC_GETCLASS("Derived") class_func1]; return [objc_get_class("Derived") class_func1];
} }
@end @end
...@@ -129,7 +122,7 @@ ...@@ -129,7 +122,7 @@
int i = (size_t)[self instance_func0]; /* { dg-warning ".Derived. may not respond to .\\-instance_func0." } */ int i = (size_t)[self instance_func0]; /* { dg-warning ".Derived. may not respond to .\\-instance_func0." } */
i += [(Derived <Func> *)self categ_instance_func2]; i += [(Derived <Func> *)self categ_instance_func2];
i += (size_t)[(Object <Func> *)self categ_instance_func2]; /* { dg-warning ".Object. may not respond to .\\-categ_instance_func2." } */ i += (size_t)[(Object <Func> *)self categ_instance_func2]; /* { dg-warning ".Object. may not respond to .\\-categ_instance_func2." } */
/* { dg-warning ".\\-categ_instance_func2. not found in protocol" "" { target *-*-* } 131 } */ /* { dg-warning ".\\-categ_instance_func2. not found in protocol" "" { target *-*-* } 124 } */
i += (size_t)[(id <Func>)self categ_instance_func2]; /* { dg-warning ".\\-categ_instance_func2. not found in protocol" } */ i += (size_t)[(id <Func>)self categ_instance_func2]; /* { dg-warning ".\\-categ_instance_func2. not found in protocol" } */
i += [(id)self categ_instance_func2]; i += [(id)self categ_instance_func2];
return i + (size_t)[super instance_func0]; /* { dg-warning ".Object. may not respond to .\\-instance_func0." } */ return i + (size_t)[super instance_func0]; /* { dg-warning ".Object. may not respond to .\\-instance_func0." } */
......
/* Check if sending messages to super does not interfere with sending messages /* Check if sending messages to super does not interfere with sending messages
to classes. */ to classes. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-options "-lobjc" } */ /* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -52,3 +53,5 @@ int main(void) { ...@@ -52,3 +53,5 @@ int main(void) {
CHECK_IF([derived instance_func1] == 234 + 345); CHECK_IF([derived instance_func1] == 234 + 345);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test class methods inside categories. */ /* Test class methods inside categories. */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "need OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
extern int strcmp(const char *s1, const char *s2);
extern void abort(void);
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#define SUPERCLASS superclass #define SUPERCLASS superclass
...@@ -11,8 +14,6 @@ ...@@ -11,8 +14,6 @@
#define SUPERCLASS superClass #define SUPERCLASS superClass
#endif #endif
extern int strcmp(const char *s1, const char *s2);
extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
@interface MyObject: Object @interface MyObject: Object
...@@ -36,8 +37,15 @@ int main (int argc, const char * argv[]) ...@@ -36,8 +37,15 @@ int main (int argc, const char * argv[])
Class w1 = [MyObject whatever1]; Class w1 = [MyObject whatever1];
Class w2 = [MyObject whatever2]; Class w2 = [MyObject whatever2];
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
CHECK_IF(!strcmp( object_getClassName( w1 ), "Object"));
CHECK_IF(!strcmp( object_getClassName( w2 ), "Object"));
#else
CHECK_IF(!strcmp(w1->name, "Object")); CHECK_IF(!strcmp(w1->name, "Object"));
CHECK_IF(!strcmp(w2->name, "Object")); CHECK_IF(!strcmp(w2->name, "Object"));
#endif
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol Foo @protocol Foo
- (id)meth1; - (id)meth1;
......
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Derived: Object @interface Derived: Object
@end @end
......
/* { dg-do compile } */ /* { dg-do compile } */
/* Another gimplifier ICE... */ /* Another gimplifier ICE... */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface MyView: Object { @interface MyView: Object {
int _frame; int _frame;
......
/* Test errors for constant strings. */ /* Test errors for constant strings. */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime" } */
#ifdef __cplusplus #ifdef __cplusplus
extern void baz(...); extern void baz(...);
......
...@@ -2,10 +2,10 @@ ...@@ -2,10 +2,10 @@
constant string classes get derived. */ constant string classes get derived. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime" } */ /* { dg-do compile { target { *-*-darwin* } } } */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface NSString: Object @interface NSString: Object
@end @end
...@@ -20,9 +20,14 @@ ...@@ -20,9 +20,14 @@
@interface NSConstantString : NSSimpleCString @interface NSConstantString : NSSimpleCString
@end @end
#ifndef NEXT_OBJC_USE_NEW_INTERFACE
extern struct objc_class _NSConstantStringClassReference; extern struct objc_class _NSConstantStringClassReference;
#else
extern Class _NSConstantStringClassReference;
#endif
const NSConstantString *appKey = @"MyApp"; const NSConstantString *appKey = @"MyApp";
/* { dg-final { scan-assembler ".section __OBJC, __cstring_object" } } */ /* { dg-final { scan-assembler ".section __OBJC, __cstring_object" } } */
/* { dg-final { scan-assembler ".long\t__NSConstantStringClassReference\n\t.long\t.*\n\t.long\t5\n\t.data" } } */ /* { dg-final { scan-assembler ".long\t__NSConstantStringClassReference\n\t.long\t.*\n\t.long\t5\n\t.data" { target { *-*-darwin* && { ! lp64 } } } } } */
/* { dg-final { scan-assembler ".quad\t__NSConstantStringClassReference\n\t.quad\t.*\n\t.long\t5\n\t.space" { target { *-*-darwin* && { lp64 } } } } } */
...@@ -2,10 +2,11 @@ ...@@ -2,10 +2,11 @@
constant string classes get derived. */ constant string classes get derived. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime -fconstant-string-class=XStr" } */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-options "-fconstant-string-class=XStr" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface XString: Object { @interface XString: Object {
@protected @protected
...@@ -19,9 +20,14 @@ ...@@ -19,9 +20,14 @@
} }
@end @end
#ifndef NEXT_OBJC_USE_NEW_INTERFACE
extern struct objc_class _XStrClassReference; extern struct objc_class _XStrClassReference;
#else
extern Class _XStrClassReference;
#endif
const XStr *appKey = @"MyApp"; const XStr *appKey = @"MyApp";
/* { dg-final { scan-assembler ".section __OBJC, __cstring_object" } } */ /* { dg-final { scan-assembler ".section __OBJC, __cstring_object" } } */
/* { dg-final { scan-assembler ".long\t__XStrClassReference\n\t.long\t.*\n\t.long\t5\n\t.data" } } */ /* { dg-final { scan-assembler ".long\t__XStrClassReference\n\t.long\t.*\n\t.long\t5\n\t.data" { target { *-*-darwin* && { ! lp64 } } } } } */
/* { dg-final { scan-assembler ".quad\t__XStrClassReference\n\t.quad\t.*\n\t.long\t5\n\t.space" { target { *-*-darwin* && { lp64 } } } } } */
/* { dg-options "-Wall -funit-at-a-time -fgnu-runtime" } */ /* { dg-options "-Wall -funit-at-a-time" } */
/* { dg-do compile } */ /* { dg-do compile } */
/* PR objc/27438, make sure that the decl produced by the front-end /* PR objc/27438, make sure that the decl produced by the front-end
does not cause a warning to be produced. */ does not cause a warning to be produced. */
/* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
@interface NXConstantString @interface NXConstantString
{ {
......
/* Test the -fconstant-string-class=Foo option under the NeXT /* Test the -fconstant-string-class=Foo option under the NeXT runtime. */
runtime. */
/* Developed by Markus Hitter <mah@jump-ing.de>. */ /* Developed by Markus Hitter <mah@jump-ing.de>. */
/* { dg-do run } */
/* { dg-options "-fconstant-string-class=Foo" } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
/* { dg-options "-fnext-runtime -fconstant-string-class=Foo -lobjc" } */ #import "../objc-obj-c++-shared/Object1.h"
/* { dg-do run { target *-*-darwin* } } */ #import "../objc-obj-c++-shared/next-mapping.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <memory.h> #include <memory.h>
#include <objc/objc.h>
#include <objc/Object.h>
@interface Foo: Object { @interface Foo: Object {
char *cString; char *cString;
...@@ -18,7 +17,11 @@ ...@@ -18,7 +17,11 @@
- (char *)customString; - (char *)customString;
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
struct fudge_objc_class _FooClassReference;
#else
struct objc_class _FooClassReference; struct objc_class _FooClassReference;
#endif
@implementation Foo : Object @implementation Foo : Object
- (char *)customString { - (char *)customString {
...@@ -38,7 +41,7 @@ int main () { ...@@ -38,7 +41,7 @@ int main () {
constant string object. Can't be moved to +initialize since _that_ constant string object. Can't be moved to +initialize since _that_
is already a message. */ is already a message. */
memcpy(&_FooClassReference, objc_getClass("Foo"), sizeof(_FooClassReference)); memcpy(&_FooClassReference, objc_get_class("Foo"), sizeof(_FooClassReference));
if (strcmp ([string customString], "bla")) { if (strcmp ([string customString], "bla")) {
abort (); abort ();
} }
...@@ -46,3 +49,5 @@ int main () { ...@@ -46,3 +49,5 @@ int main () {
printf([@"This is a working constant string object\n" customString]); printf([@"This is a working constant string object\n" customString]);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Ensure that the preprocessor handles ObjC string constants gracefully. */ /* Ensure that the preprocessor handles ObjC string constants gracefully. */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime -fconstant-string-class=MyString -lobjc" } */ /* { dg-options "-fconstant-string-class=MyString " } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run } */
extern void abort(void); extern void abort(void);
......
/* Test to make sure that the const objc strings are the same across /* Test to make sure that the const objc strings are the same across scopes. */
scopes. */
/* Developed by Andrew Pinski <pinskia@physics.uc.edu> */ /* Developed by Andrew Pinski <pinskia@physics.uc.edu> */
/* { dg-options "-fconstant-string-class=Foo " } */
/* { dg-do run } */
#include "../objc-obj-c++-shared/Object1.h"
/* { dg-options "-fnext-runtime -fconstant-string-class=Foo -lobjc" } */
/* { dg-do run { target *-*-darwin* } } */
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <memory.h> #include <memory.h>
#include <objc/objc.h>
#include <objc/Object.h>
@interface Foo: Object { @interface Foo: Object {
char *cString; char *cString;
...@@ -21,8 +15,11 @@ ...@@ -21,8 +15,11 @@
- (char *)customString; - (char *)customString;
@end @end
#ifndef NEXT_OBJC_USE_NEW_INTERFACE
struct objc_class _FooClassReference; struct objc_class _FooClassReference;
#else
Class _FooClassReference;
#endif
@implementation Foo : Object @implementation Foo : Object
- (char *)customString { - (char *)customString {
...@@ -30,13 +27,11 @@ struct objc_class _FooClassReference; ...@@ -30,13 +27,11 @@ struct objc_class _FooClassReference;
} }
@end @end
int main () { int main () {
Foo *string = @"bla"; Foo *string = @"bla";
{ {
Foo *string2 = @"bla"; Foo *string2 = @"bla";
if(string != string2) if(string != string2)
abort(); abort();
printf("Strings are being uniqued properly\n"); printf("Strings are being uniqued properly\n");
...@@ -44,3 +39,4 @@ int main () { ...@@ -44,3 +39,4 @@ int main () {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test for assigning compile-time constant-string objects to static variables. */ /* Test for assigning compile-time constant-string objects to static variables. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fconstant-string-class=Foo" } */
/* { dg-do run } */
/* { dg-options "-fnext-runtime -fconstant-string-class=Foo -lobjc" } */ #include "../objc-obj-c++-shared/Object1.h"
/* { dg-do run { target *-*-darwin* } } */
#include <stdlib.h> #include <stdlib.h>
#include <objc/Object.h>
@interface Foo: Object { @interface Foo: Object {
char *cString; char *cString;
...@@ -14,7 +12,11 @@ ...@@ -14,7 +12,11 @@
} }
@end @end
#ifndef NEXT_OBJC_USE_NEW_INTERFACE
struct objc_class _FooClassReference; struct objc_class _FooClassReference;
#else
Class _FooClassReference;
#endif
@implementation Foo : Object @implementation Foo : Object
- (char *)customString { - (char *)customString {
...@@ -37,3 +39,5 @@ int main () { ...@@ -37,3 +39,5 @@ int main () {
PrefsSynchronize(); PrefsSynchronize();
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test if ObjC constant strings get placed in the correct section. */ /* Test if ObjC constant strings get placed in the correct section. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-fnext-runtime" } */ /* { dg-do compile } */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface NSConstantString: Object { @interface NSConstantString: Object {
char *cString; char *cString;
...@@ -12,9 +12,14 @@ ...@@ -12,9 +12,14 @@
} }
@end @end
#ifndef NEXT_OBJC_USE_NEW_INTERFACE
extern struct objc_class _NSConstantStringClassReference; extern struct objc_class _NSConstantStringClassReference;
#else
Class _NSConstantStringClassReference;
#endif
static const NSConstantString *appKey = @"MyApp"; static const NSConstantString *appKey = @"MyApp";
/* { dg-final { scan-assembler ".section __OBJC, __cstring_object" } } */ /* { dg-final { scan-assembler ".section __OBJC, __cstring_object" } } */
/* { dg-final { scan-assembler ".long\t__NSConstantStringClassReference\n\t.long\t.*\n\t.long\t5\n\t.data" } } */ /* { dg-final { scan-assembler ".long\t__NSConstantStringClassReference\n\t.long\t.*\n\t.long\t5\n\t.data" { target { *-*-darwin* && { ! lp64 } } } } } */
/* { dg-final { scan-assembler ".quad\t__NSConstantStringClassReference\n\t.quad\t.*\n\t.long\t5\n\t.space" { target { *-*-darwin* && { lp64 } } } } } */
/* Check if the @defs() construct preserves the correct /* Check if the @defs() construct preserves the correct
offsets of ivars. */ offsets of ivars. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/objc.h> #include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h> //#include <objc/objc.h>
extern void abort(void); extern void abort(void);
...@@ -65,3 +66,5 @@ int main(void) { ...@@ -65,3 +66,5 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Test Objective-C capability for handling GNU/C99 designated /* Test Objective-C capability for handling GNU/C99 designated initializers, and distinguishing them
initializers, and distinguishing them from message sends. */ from message sends. Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-std=gnu99" } */ /* { dg-options "-std=gnu99" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <objc/objc.h>
#include <objc/Object.h>
@interface Cls : Object @interface Cls : Object
+ (int) meth1; + (int) meth1;
...@@ -47,3 +47,5 @@ int main(void) { ...@@ -47,3 +47,5 @@ int main(void) {
/* { dg-warning "Messages without a matching method signature" "" { target *-*-* } 0 } */ /* { dg-warning "Messages without a matching method signature" "" { target *-*-* } 0 } */
/* { dg-warning "will be assumed to return .id. and accept" "" { target *-*-* } 0 } */ /* { dg-warning "will be assumed to return .id. and accept" "" { target *-*-* } 0 } */
/* { dg-warning ".\.\.\.. as arguments" "" { target *-*-* } 0 } */ /* { dg-warning ".\.\.\.. as arguments" "" { target *-*-* } 0 } */
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -29,7 +29,13 @@ dg-init ...@@ -29,7 +29,13 @@ dg-init
# Main loop. # Main loop.
dg-runtest [lsort [glob -nocomplain $srcdir/$subdir/*.\[m\]]] \ dg-runtest [lsort [glob -nocomplain $srcdir/$subdir/*.\[m\]]] \
"" $DEFAULT_CFLAGS "-fgnu-runtime" $DEFAULT_CFLAGS
# darwin targets can also run code with the NeXT runtime.
if [istarget "*-*-darwin*" ] {
dg-runtest [lsort [glob -nocomplain $srcdir/$subdir/*.\[m\]]] \
"-fnext-runtime" $DEFAULT_CFLAGS
}
# All done. # All done.
dg-finish dg-finish
...@@ -3,9 +3,8 @@ ...@@ -3,9 +3,8 @@
should be encoded as '*'). This is somewhat tricky wrt the NeXT runtime, should be encoded as '*'). This is somewhat tricky wrt the NeXT runtime,
where we have 'typedef char BOOL'. */ where we have 'typedef char BOOL'. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime -lobjc" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-options "-fnext-runtime" } */
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include <objc/objc.h> #include <objc/objc.h>
......
...@@ -15,19 +15,17 @@ ...@@ -15,19 +15,17 @@
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/objc.h> #include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h> #include "../objc-obj-c++-shared/next-mapping.h"
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#define METHOD Method #define METHOD Method
#define OBJC_GETCLASS objc_getClass
#define CLASS_GETINSTANCEMETHOD class_getInstanceMethod
#else #else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define METHOD Method_t #define METHOD Method_t
#define OBJC_GETCLASS objc_get_class #define method_get_types(M) (M)->method_types
#define CLASS_GETINSTANCEMETHOD class_get_instance_method
#endif #endif
extern int sscanf(const char *str, const char *format, ...); extern int sscanf(const char *str, const char *format, ...);
...@@ -76,27 +74,31 @@ unsigned offs1, offs2, offs3, offs4, offs5, offs6, offs7; ...@@ -76,27 +74,31 @@ unsigned offs1, offs2, offs3, offs4, offs5, offs6, offs7;
int main(void) { int main(void) {
Foo *foo = [[Foo alloc] init]; Foo *foo = [[Foo alloc] init];
Class fooClass = OBJC_GETCLASS("Foo"); Class fooClass = objc_get_class("Foo");
METHOD meth; METHOD meth;
const char *string; const char *string;
meth = CLASS_GETINSTANCEMETHOD(fooClass, @selector(setRect:withInt:)); meth = class_get_instance_method(fooClass, @selector(setRect:withInt:));
offs2 = 9999; offs2 = 9999;
sscanf(meth->method_types, "@%u@%u:%u{_XXRect={?=ff}{?=ff}}%ui%u", &offs1, &offs2, &offs3,
sscanf(method_get_types(meth), "@%u@%u:%u{_XXRect={?=ff}{?=ff}}%ui%u", &offs1, &offs2, &offs3,
&offs4, &offs5); &offs4, &offs5);
CHECK_IF(!offs2); CHECK_IF(!offs2);
[foo setRect:my_rect withInt:123]; [foo setRect:my_rect withInt:123];
meth = CLASS_GETINSTANCEMETHOD(fooClass, @selector(char:float:double:long:)); meth = class_get_instance_method(fooClass, @selector(char:float:double:long:));
offs2 = 9999; offs2 = 9999;
if (sizeof (long) == 8) if (sizeof (long) == 8)
string = "v%u@%u:%uc%uf%ud%uq%u"; string = "v%u@%u:%uc%uf%ud%uq%u";
else else
string = "v%u@%u:%uc%uf%ud%ul%u"; string = "v%u@%u:%uc%uf%ud%ul%u";
sscanf(meth->method_types, string, &offs1, &offs2, &offs3, sscanf(method_get_types(meth), string, &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6, &offs7); &offs4, &offs5, &offs6, &offs7);
CHECK_IF(!offs2); CHECK_IF(!offs2);
[foo char:'c' float:2.3 double:3.5 long:2345L]; [foo char:'c' float:2.3 double:3.5 long:2345L];
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -2,7 +2,10 @@ ...@@ -2,7 +2,10 @@
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
#include <objc/Protocol.h> #include <stdlib.h>
#include "../objc-obj-c++-shared/Protocol1.h"
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#ifdef __cplusplus #ifdef __cplusplus
#define ProtoBool bool #define ProtoBool bool
#else #else
......
/* Encoding tests for ObjC class layouts. */ /* Encoding tests for ObjC class layouts. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#include <objc/objc-class.h> #include <objc/objc-class.h>
#define OBJC_GETCLASS objc_getClass
#else #else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define OBJC_GETCLASS objc_get_class
#endif #endif
extern void abort(void); extern void abort(void);
extern int strcmp(const char *s1, const char *s2); extern int strcmp(const char *s1, const char *s2);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
@class Int1, Int2; @class Int1, Int2;
...@@ -49,25 +50,44 @@ struct Nested { ...@@ -49,25 +50,44 @@ struct Nested {
@implementation Int2 @implementation Int2
@end @end
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
Ivar *ivar;
#else
struct objc_ivar *ivar; struct objc_ivar *ivar;
#endif
static void check_ivar(const char *name, const char *type) { static void check_ivar(const char *name, const char *type) {
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
CHECK_IF(!strcmp(ivar_getName(*ivar), name));
CHECK_IF(!strcmp(ivar_getTypeEncoding(*ivar), type));
#else
CHECK_IF(!strcmp(ivar->ivar_name, name)); CHECK_IF(!strcmp(ivar->ivar_name, name));
CHECK_IF(!strcmp(ivar->ivar_type, type)); CHECK_IF(!strcmp(ivar->ivar_type, type));
#endif
ivar++; ivar++;
} }
int main(void) { int main(void) {
ivar = ((Class)OBJC_GETCLASS("Int1"))->ivars->ivar_list; #ifdef NEXT_OBJC_USE_NEW_INTERFACE
ivar = class_copyIvarList ((Class)objc_get_class("Int1"), NULL);
#else
ivar = ((Class)objc_get_class("Int1"))->ivars->ivar_list;
#endif
check_ivar("a", "c"); check_ivar("a", "c");
check_ivar("b", "c"); check_ivar("b", "c");
check_ivar("int2", "@\"Int2\""); check_ivar("int2", "@\"Int2\"");
check_ivar("nested", check_ivar("nested",
"{Nested=\"a\"f\"b\"f\"next\"@\"Int1\"\"innermost\"{Innermost=\"a\"C\"b\"C\"encl\"^{Nested}}}"); "{Nested=\"a\"f\"b\"f\"next\"@\"Int1\"\"innermost\"{Innermost=\"a\"C\"b\"C\"encl\"^{Nested}}}");
ivar = ((Class)OBJC_GETCLASS("Int2"))->ivars->ivar_list; #ifdef NEXT_OBJC_USE_NEW_INTERFACE
ivar = class_copyIvarList ((Class)objc_get_class("Int2"), NULL);
#else
ivar = ((Class)objc_get_class("Int2"))->ivars->ivar_list;
#endif
check_ivar("innermost", "^{Innermost=CC^{Nested}}"); check_ivar("innermost", "^{Innermost=CC^{Nested}}");
check_ivar("base", "@\"Int1\""); check_ivar("base", "@\"Int1\"");
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -9,20 +9,18 @@ ...@@ -9,20 +9,18 @@
/* Contributed by Alexander Malmberg <alexander@malmberg.org> */ /* Contributed by Alexander Malmberg <alexander@malmberg.org> */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#define METHOD Method #define METHOD Method
#define OBJC_GETCLASS objc_getClass
#define CLASS_GETINSTANCEMETHOD class_getInstanceMethod
#else #else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define METHOD Method_t #define METHOD Method_t
#define OBJC_GETCLASS objc_get_class #define method_get_types(M) (M)->method_types
#define CLASS_GETINSTANCEMETHOD class_get_instance_method
#endif #endif
@interface Test : Object @interface Test : Object
...@@ -49,7 +47,7 @@ int offs1, offs2, offs3, offs4, offs5, offs6; ...@@ -49,7 +47,7 @@ int offs1, offs2, offs3, offs4, offs5, offs6;
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
Class testClass = OBJC_GETCLASS("Test"); Class testClass = objc_get_class("Test");
METHOD meth; METHOD meth;
cc[0] = [Test new]; cc[0] = [Test new];
...@@ -60,16 +58,16 @@ int main(int argc, char **argv) ...@@ -60,16 +58,16 @@ int main(int argc, char **argv)
[*c test2: bb with: bb + 5]; [*c test2: bb with: bb + 5];
CHECK_IF (bb[3] == 5); CHECK_IF (bb[3] == 5);
meth = CLASS_GETINSTANCEMETHOD(testClass, @selector(test2:with:)); meth = class_get_instance_method(testClass, @selector(test2:with:));
offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1; offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1;
sscanf(meth->method_types, "v%d@%d:%d[%di]%d^i%d", &offs1, &offs2, &offs3, sscanf(method_get_types(meth), "v%d@%d:%d[%di]%d^i%d", &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6); &offs4, &offs5, &offs6);
CHECK_IF (!offs2 && offs4 == 5 && offs3 > 0); CHECK_IF (!offs2 && offs4 == 5 && offs3 > 0);
CHECK_IF (offs5 == 2 * offs3 && offs6 == 3 * offs3 && offs1 == 4 * offs3); CHECK_IF (offs5 == 2 * offs3 && offs6 == 3 * offs3 && offs1 == 4 * offs3);
meth = CLASS_GETINSTANCEMETHOD(testClass, @selector(test3:)); meth = class_get_instance_method(testClass, @selector(test3:));
offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1; offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = -1;
sscanf(meth->method_types, "v%d@%d:%d[%d[%d{Test=#f}]]%d", &offs1, &offs2, &offs3, sscanf(method_get_types(meth), "v%d@%d:%d[%d[%d{Test=#f}]]%d", &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6); &offs4, &offs5, &offs6);
CHECK_IF (!offs2 && offs4 == 3 && offs5 == 4 && offs3 > 0); CHECK_IF (!offs2 && offs4 == 3 && offs5 == 4 && offs3 > 0);
CHECK_IF (offs6 == 2 * offs3 && offs1 == 3 * offs3); CHECK_IF (offs6 == 2 * offs3 && offs1 == 3 * offs3);
......
/* { dg-options "-fgnu-runtime" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/encoding.h> #include <objc/encoding.h>
#include <stdlib.h> #include <stdlib.h>
......
/* { dg-options "-fgnu-runtime" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/encoding.h> #include <objc/encoding.h>
#include <stdlib.h> #include <stdlib.h>
......
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime " } */
/* There was an ICE due to diving by zero in the objc front-end. */ /* There was an ICE due to diving by zero in the objc front-end. */
......
...@@ -4,8 +4,9 @@ ...@@ -4,8 +4,9 @@
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
/* { dg-options "-mfix-and-continue" } */ /* { dg-options "-mfix-and-continue" } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdlib.h> #include <stdlib.h>
@class MyTarget, MySet; @class MyTarget, MySet;
...@@ -88,3 +89,5 @@ int main(void) { ...@@ -88,3 +89,5 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
/* { dg-do assemble { target *-*-darwin* } } */ /* { dg-do assemble { target *-*-darwin* } } */
/* { dg-options "-mfix-and-continue" } */ /* { dg-options "-mfix-and-continue" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Foo: Object @interface Foo: Object
+ (Object *)indexableFileTypes; + (Object *)indexableFileTypes;
......
/* Test for handling of function pointer ivars */ /* Test for handling of function pointer ivars */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
extern int strcmp(const char *, const char *); extern int strcmp(const char *, const char *);
extern void abort(void); extern void abort(void);
...@@ -46,3 +47,5 @@ int main () ...@@ -46,3 +47,5 @@ int main ()
return(0); return(0);
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -2,9 +2,11 @@ ...@@ -2,9 +2,11 @@
into pointers. */ into pointers. */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
/* provide an Object class for NeXT runtimes 10.5 and above */
#include "../objc-obj-c++-shared/Object1.h"
@interface Func: Object @interface Func: Object
+ (int) processNumber:(int)a and:(int)b usingFunction:(int(int,int))func; + (int) processNumber:(int)a and:(int)b usingFunction:(int(int,int))func;
...@@ -35,3 +37,5 @@ int main(void) { ...@@ -35,3 +37,5 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
the system runtime used). */ the system runtime used). */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include <objc/Object.h>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
regardless of runtime used on target system. */ regardless of runtime used on target system. */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fgnu-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include <objc/Object.h>
#include <string.h> #include <string.h>
......
/* Sanity check for GNU-runtime regardless of runtime used on target system. */ /* Sanity check for GNU-runtime regardless of runtime used on target system. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-options "-fgnu-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include <objc/Object.h>
#include <string.h> #include <string.h>
......
...@@ -2,15 +2,12 @@ ...@@ -2,15 +2,12 @@
__OBJC,__image_info section to be emitted. This is only __OBJC,__image_info section to be emitted. This is only
usable on MacOS X 10.3 and later. */ usable on MacOS X 10.3 and later. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-freplace-objc-classes" } */
/* { dg-do compile { target *-*-darwin* } } */
#ifndef __NEXT_RUNTIME__ /* { dg-do compile { target { *-*-darwin* } } } */
#error Feature not currently supported by the GNU runtime /* { dg-options "-freplace-objc-classes" } */
#endif
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
......
/* Ensure there are no bizarre difficulties with accessing the 'isa' field of objects. */ /* Ensure there are no bizarre difficulties with accessing the 'isa' field of objects. */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Object (Test) @interface Object (Test)
- (Class) test1: (id)object; - (Class) test1: (id)object;
...@@ -14,11 +14,19 @@ ...@@ -14,11 +14,19 @@
@implementation Object (Test) @implementation Object (Test)
Class test1(id object) { Class test1(id object) {
#ifdef __NEXT_RUNTIME__
Class cls = object->isa; Class cls = object->isa;
#else
Class cls = object->class_pointer;
#endif
return cls; return cls;
} }
- (Class) test1: (id)object { - (Class) test1: (id)object {
#ifdef __NEXT_RUNTIME__
Class cls = object->isa; Class cls = object->isa;
#else
Class cls = object->class_pointer;
#endif
return cls; return cls;
} }
...@@ -27,17 +35,29 @@ Class test1(id object) { ...@@ -27,17 +35,29 @@ Class test1(id object) {
@implementation Derived @implementation Derived
Class test2(id object) { Class test2(id object) {
#ifdef __NEXT_RUNTIME__
Class cls = object->isa; Class cls = object->isa;
#else
Class cls = object->class_pointer;
#endif
return cls; return cls;
} }
- (Class) test2: (id)object { - (Class) test2: (id)object {
#ifdef __NEXT_RUNTIME__
Class cls = object->isa; Class cls = object->isa;
#else
Class cls = object->class_pointer;
#endif
return cls; return cls;
} }
@end @end
Class test3(id object) { Class test3(id object) {
#ifdef __NEXT_RUNTIME__
Class cls = object->isa; Class cls = object->isa;
#else
Class cls = object->class_pointer;
#endif
return cls; return cls;
} }
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wpadded -Wpacked" } */ /* { dg-options "-Wpadded -Wpacked" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Derived1: Object @interface Derived1: Object
{ } { }
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Sprite: Object { @interface Sprite: Object {
int sprite, spree; int sprite, spree;
......
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
#include "../objc-obj-c++-shared/Object1.h"
typedef struct MyWidget { typedef struct MyWidget {
int a; int a;
...@@ -35,7 +36,7 @@ MyWidget gWidget = { 17 }; ...@@ -35,7 +36,7 @@ MyWidget gWidget = { 17 };
@implementation Container @implementation Container
+ (MyWidget *)elementForView:(Foo *)view + (MyWidget *)elementForView:(Foo *)view
{ {
MyWidget *widget = nil; MyWidget *widget = (MyWidget *) nil;
if ([view conformsTo:@protocol(MyProto)]) { if ([view conformsTo:@protocol(MyProto)]) {
widget = [(Foo <MyProto> *)view widget]; widget = [(Foo <MyProto> *)view widget];
} }
...@@ -52,3 +53,5 @@ int main(void) { ...@@ -52,3 +53,5 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,8 +3,10 @@ ...@@ -3,8 +3,10 @@
message sends (so that proper C/C++ argument conversions may message sends (so that proper C/C++ argument conversions may
take place). */ take place). */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -30,3 +32,4 @@ int main(void) ...@@ -30,3 +32,4 @@ int main(void)
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
root classes must be considered. */ root classes must be considered. */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/objc.h> #include <objc/objc.h>
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class NSString; @class NSString;
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wreturn-type -Wextra" } */ /* { dg-options "-Wreturn-type -Wextra" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Foo: Object @interface Foo: Object
- (id) meth1; - (id) meth1;
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class NotKnown; @class NotKnown;
......
/* Test for sending messages to aliased classes (and instances thereof). */ /* Test for sending messages to aliased classes (and instances thereof). */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -43,3 +44,5 @@ int main(void) { ...@@ -43,3 +44,5 @@ int main(void) {
CHECK_IF([(Int1Alias *)int2typedef instanceMeth] == 1697); CHECK_IF([(Int1Alias *)int2typedef instanceMeth] == 1697);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Check if class references (generated for the NeXT runtime) are appropriately /* Check if class references (generated for the NeXT runtime) are appropriately
folded. This test is safe to run on all targets. */ folded. */
/* Author: Ziemowit Laski <zlaski@apple.com>. */ /* Author: Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime" } */ /* The ABI is different for m64 darwin so skip this test for now */
/* { dg-do compile } */ /* { dg-do compile { target { *-*-darwin* && { ! lp64 } } } } */
/* { dg-skip-if "" { *-*-darwin* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
typedef Object ObjectTypedef1; typedef Object ObjectTypedef1;
typedef ObjectTypedef1 ObjectTypedef2; typedef ObjectTypedef1 ObjectTypedef2;
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wstrict-selector-match" } */ /* { dg-options "-Wstrict-selector-match" } */
#include <objc/Protocol.h> #include "../objc-obj-c++-shared/Protocol1.h"
@interface Base @interface Base
- (unsigned)port; - (unsigned)port;
......
/* Check if finding multiple signatures for a method is handled gracefully. */ /* Check if finding multiple signatures for a method is handled gracefully. */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wstrict-selector-match" } */ /* { dg-options "-Wstrict-selector-match" } */
#include <objc/Object.h>
#include "../objc-obj-c++-shared/Object1.h"
@interface Class1 @interface Class1
- (void)setWindow:(Object *)wdw; - (void)setWindow:(Object *)wdw;
......
/* Check if finding multiple signatures for a method is handled gracefully /* Check if finding multiple signatures for a method is handled gracefully
when method lookup succeeds (see also method-7.m). */ when method lookup succeeds (see also method-7.m). */
/* Contributed by Ziemowit Laski <zlaski@apple.com> */ /* Contributed by Ziemowit Laski <zlaski@apple.com> */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wstrict-selector-match" } */ /* { dg-options "-Wstrict-selector-match" } */
#include <objc/Object.h>
#include "../objc-obj-c++-shared/Object1.h"
@protocol MyObject @protocol MyObject
- (id)initWithData:(Object *)data; - (id)initWithData:(Object *)data;
......
...@@ -3,9 +3,9 @@ ...@@ -3,9 +3,9 @@
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-options "-fnext-runtime" } */ /* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface FooBar: Object @interface FooBar: Object
- (void)boo; - (void)boo;
......
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
main() { [NSObject new]; } main() { [NSObject new]; }
......
/* The code should call objc_msgSend directly, not through a pointer. */ /* The code should call objc_msgSend directly, not through a pointer. */
/* { dg-do compile { target powerpc*-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-options "-O0 -fnext-runtime" } */ /* { dg-options "-O0" } */
/* { dg-skip-if "" { powerpc*-*-darwin* } { "-m64" } { "" } } */
/* Radar 4015820 */ /* Radar 4015820 */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
void foo(void) { void foo(void) {
Object *o; Object *o;
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-options "-fobjc-gc" } */ /* { dg-options "-fobjc-gc" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class MyWindow; @class MyWindow;
......
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile } */
/* ??? Is there a better pragma that is handled for all targets, not /* ??? Is there a better pragma that is handled for all targets, not
handled by the preprocessor, that would be better for testing here? */ handled by the preprocessor, that would be better for testing here? */
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
provide a suitable method. */ provide a suitable method. */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol Zot @protocol Zot
-(void) zot; -(void) zot;
......
...@@ -2,9 +2,10 @@ ...@@ -2,9 +2,10 @@
a protocol with no instance/class methods respectively. a protocol with no instance/class methods respectively.
Problem report and original fix by richard@brainstorm.co.uk. */ Problem report and original fix by richard@brainstorm.co.uk. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Protocol1.h"
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
#include <objc/Protocol.h>
@protocol NoInstanceMethods @protocol NoInstanceMethods
+ + testMethod; + + testMethod;
......
/* Check that protocol qualifiers are compiled and encoded properly. */ /* Check that protocol qualifiers are compiled and encoded properly. */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Protocol.h> #include "../objc-obj-c++-shared/Protocol1.h"
#ifndef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include <objc/objc-api.h> #include <objc/objc-api.h>
#endif #endif
......
/* Test warning for non existing selectors. */ /* Test warning for non existing selectors. */
/* Contributed by Devang Patel <dpatel@apple.com>. */ /* Contributed by Devang Patel <dpatel@apple.com>. */
/* { dg-options "-Wselector -fnext-runtime" } */ /* { dg-options "-Wselector" } */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
typedef struct objc_object { struct objc_class *class_pointer; } *id; typedef struct objc_object { struct objc_class *class_pointer; } *id;
typedef struct objc_selector *SEL; typedef struct objc_selector *SEL;
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* { dg-options "-Wselector" } */ /* { dg-options "-Wselector" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Foo @interface Foo
@end @end
......
/* Test warning for non-existent selectors. */ /* Test warning for non-existent selectors. */
/* This is the "-fgnu-runtime" variant of objc.dg/selector-1.m. */ /* This is the "-fgnu-runtime" variant of objc.dg/selector-1.m. */
/* { dg-options "-Wselector -fgnu-runtime" } */ /* { dg-options "-Wselector" } */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
typedef struct objc_object { struct objc_class *class_pointer; } *id; typedef struct objc_object { struct objc_class *class_pointer; } *id;
typedef const struct objc_selector *SEL; typedef const struct objc_selector *SEL;
......
/* Check that the sizeof() operator works with ObjC classes and their aliases. */ /* Check that the sizeof() operator works with ObjC classes and their aliases. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-lobjc" } */ /* { dg-options "" } */
/* { dg-do run } */ /* { dg-do run } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort(); #define CHECK_IF(expr) if(!(expr)) abort();
...@@ -31,3 +31,4 @@ int main(void) { ...@@ -31,3 +31,4 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -33,14 +33,29 @@ dg-init ...@@ -33,14 +33,29 @@ dg-init
# This test is special because we must compile two different modules, # This test is special because we must compile two different modules,
# unclaimed-category-1a.m and unclaimed-category-1.m, then link # unclaimed-category-1a.m and unclaimed-category-1.m, then link
# together, then run the resulting executable. # together, then run the resulting executable.
set lines [objc_target_compile "$srcdir/$subdir/unclaimed-category-1a.m" "unclaimed-category-1a.o" object "additional_flags=-I${srcdir}/../../libobjc"] # for all systems we point to the libobjc includes and use the -fgnu-runtime
set add_flags "additional_flags=-I${srcdir}/../../libobjc"
lappend add_flags "additional_flags=-fgnu-runtime"
set lines [objc_target_compile "$srcdir/$subdir/unclaimed-category-1a.m" "unclaimed-category-1a.o" object $add_flags ]
if ![string match "" $lines] then { if ![string match "" $lines] then {
fail "unclaimed-category-1a.o" fail "unclaimed-category-1a.o"
} else { } else {
dg-runtest "$srcdir/$subdir/unclaimed-category-1.m" "unclaimed-category-1a.o" "-I${srcdir}/../../libobjc" dg-runtest "$srcdir/$subdir/unclaimed-category-1.m" "unclaimed-category-1a.o" "-I${srcdir}/../../libobjc -fgnu-runtime"
file delete unclaimed-category-1a.o file delete unclaimed-category-1a.o
} }
if [istarget "*-*-darwin*" ] {
set add_flags ""
lappend add_flags "additional_flags=-fnext-runtime"
set lines [objc_target_compile "$srcdir/$subdir/unclaimed-category-1a.m" "unclaimed-category-1a.o" object $add_flags ]
if ![string match "" $lines] then {
fail "unclaimed-category-1a.o"
} else {
dg-runtest "$srcdir/$subdir/unclaimed-category-1.m" "unclaimed-category-1a.o" "-fnext-runtime"
file delete unclaimed-category-1a.o
}
}
# All done. # All done.
dg-finish dg-finish
/* Contributed by Nicola Pero - Fri Dec 14 08:36:00 GMT 2001 */ /* Contributed by Nicola Pero - Fri Dec 14 08:36:00 GMT 2001 */
#include <objc/objc.h>
#include <objc/Object.h>
#ifdef __NEXT_RUNTIME__
#define objc_get_class(C) objc_getClass(C)
#define class_create_instance(C) class_createInstance(C, 0)
#endif
/* Test loading unclaimed categories - categories of a class defined /* Test loading unclaimed categories - categories of a class defined
separately from the class itself. */ separately from the class itself. */
......
/* Contributed by Nicola Pero - Fri Dec 14 08:36:00 GMT 2001 */ /* Contributed by Nicola Pero - Fri Dec 14 08:36:00 GMT 2001 */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#ifndef __NEXT_RUNTIME__
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h> #endif
extern void abort (void); extern void abort (void);
...@@ -69,3 +73,5 @@ int main (void) ...@@ -69,3 +73,5 @@ int main (void)
return 0; return 0;
} }
#import "../../objc-obj-c++-shared/Object1-implementation.h"
/* Contributed by Nicola Pero - Fri Dec 14 08:36:00 GMT 2001 */ /* Contributed by Nicola Pero - Fri Dec 14 08:36:00 GMT 2001 */
#include <objc/objc.h>
#include <objc/Object.h>
/* Test loading unclaimed categories - categories of a class defined /* Test loading unclaimed categories - categories of a class defined
separately from the class itself. */ separately from the class itself. */
......
/* Test for handling of struct-returning methods. */ /* Test for handling of struct-returning methods. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -60,3 +61,5 @@ int main(void) ...@@ -60,3 +61,5 @@ int main(void)
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,8 +3,9 @@ ...@@ -3,8 +3,9 @@
points). */ points). */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
struct astruct { struct astruct {
float a, b; float a, b;
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
_objc_msgSend<end-of-line>" without the $stub suffix. */ _objc_msgSend<end-of-line>" without the $stub suffix. */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-options "-Os -mdynamic-no-pic" } */ /* { dg-options "-Os -mdynamic-no-pic" } */
typedef struct objc_object { } *id ; typedef struct objc_object { } *id ;
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
/* Testcase extracted from TextEdit:Document.m. */ /* Testcase extracted from TextEdit:Document.m. */
/* { dg-do compile { target *-*-darwin* } } */ /* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-options "-mdynamic-no-pic -fdump-rtl-jump" } */ /* { dg-options "-mdynamic-no-pic -fdump-rtl-jump" } */
typedef struct objc_object { } *id ; typedef struct objc_object { } *id ;
......
/* Test calling super from within a category class method. */ /* Test calling super from within a category class method. */
/* Author: Ziemowit Laski <zlaski@apple.com> */ /* Author: Ziemowit Laski <zlaski@apple.com> */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fnext-runtime" } */
typedef struct objc_object { struct objc_class *isa; } *id; typedef struct objc_object { struct objc_class *isa; } *id;
......
...@@ -2,8 +2,10 @@ ...@@ -2,8 +2,10 @@
is an ObjC class name. */ is an ObjC class name. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
...@@ -41,3 +43,4 @@ int main(void) { ...@@ -41,3 +43,4 @@ int main(void) {
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
should be traversed to find the @interface. */ should be traversed to find the @interface. */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@class MyWpModule; @class MyWpModule;
......
/* Check if the objc_symtab descriptor is being laid out correctly. */ /* Check if the objc_symtab descriptor is being laid out correctly. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime" } */
/* { dg-do compile { target *-*-darwin* } } */
#include <objc/Object.h> /* { dg-do compile { target { *-*-darwin* } } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
@interface Base: Object @interface Base: Object
- (void)setValues; - (void)setValues;
......
/* Make sure that @synchronized parses. */ /* Make sure that @synchronized parses. */
/* { dg-options "-fnext-runtime -fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
void foo(id sem) void foo(id sem)
{ {
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
#include <stdio.h> #include <stdio.h>
#include <setjmp.h> #include <setjmp.h>
......
/* Ensure that @try/@catch blocks do not mess with types of /* Ensure that @try/@catch blocks do not mess with types of
local objects (other than their volatile bits). */ local objects (other than their volatile bits). */
/* { dg-options "-fobjc-exceptions -fnext-runtime" } */ /* { dg-options "-fobjc-exceptions" } */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@protocol Proto1 @protocol Proto1
- (int)meth1; - (int)meth1;
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
const char *foo(void) const char *foo(void)
{ {
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
generating the warning message. */ generating the warning message. */
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-Wall -fnext-runtime -fobjc-exceptions" } */ /* { dg-options "-Wall -fobjc-exceptions" } */
@interface Exception @interface Exception
@end @end
......
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
int main (int argc, const char * argv[]) { int main (int argc, const char * argv[]) {
Object * pool = [Object new]; Object * pool = [Object new];
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
/* { dg-do compile } */ /* { dg-do compile } */
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
@interface Derived: Object @interface Derived: Object
- (id) meth; - (id) meth;
......
...@@ -5,7 +5,6 @@ ...@@ -5,7 +5,6 @@
/* { dg-options "-fobjc-exceptions" } */ /* { dg-options "-fobjc-exceptions" } */
/* { dg-do compile } */ /* { dg-do compile } */
void foo (int *arg1, int *arg2) void foo (int *arg1, int *arg2)
{ {
*arg1 = *arg2; *arg1 = *arg2;
......
...@@ -3,16 +3,17 @@ ...@@ -3,16 +3,17 @@
encoded as pointers. */ encoded as pointers. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include <objc/objc.h> #include "../objc-obj-c++-shared/Object1.h"
#include "../objc-obj-c++-shared/next-mapping.h"
//#include <objc/objc.h>
#ifdef __NEXT_RUNTIME__ #ifdef __NEXT_RUNTIME__
#include <objc/objc-runtime.h> #include <objc/objc-runtime.h>
#define OBJC_GETCLASS objc_getClass #define METHOD Method
#define CLASS_GETINSTANCEMETHOD class_getInstanceMethod
#else #else
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define OBJC_GETCLASS objc_get_class #define METHOD Method_t
#define CLASS_GETINSTANCEMETHOD class_get_instance_method #define method_get_types(M) (M)->method_types
#endif #endif
extern int sscanf(const char *str, const char *format, ...); extern int sscanf(const char *str, const char *format, ...);
...@@ -32,27 +33,29 @@ enum Enum { one, two, three, four }; ...@@ -32,27 +33,29 @@ enum Enum { one, two, three, four };
@end @end
Class cls; Class cls;
struct objc_method *meth; METHOD meth ;
unsigned totsize, offs0, offs1, offs2, offs3, offs4, offs5, offs6, offs7; unsigned totsize, offs0, offs1, offs2, offs3, offs4, offs5, offs6, offs7;
static void scan_initial(const char *pattern) { static void scan_initial(const char *pattern) {
totsize = offs0 = offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = offs7 = (unsigned)-1; totsize = offs0 = offs1 = offs2 = offs3 = offs4 = offs5 = offs6 = offs7 = (unsigned)-1;
sscanf(meth->method_types, pattern, &totsize, &offs0, &offs1, &offs2, &offs3, sscanf(method_get_types(meth), pattern, &totsize, &offs0, &offs1, &offs2, &offs3,
&offs4, &offs5, &offs6, &offs7); &offs4, &offs5, &offs6, &offs7);
CHECK_IF(!offs0 && offs1 == sizeof(id) && offs2 == offs1 + sizeof(SEL) && totsize >= offs2); CHECK_IF(!offs0 && offs1 == sizeof(id) && offs2 == offs1 + sizeof(SEL) && totsize >= offs2);
} }
int main(void) { int main(void) {
cls = OBJC_GETCLASS("ArrayTest"); cls = objc_get_class("ArrayTest");
meth = CLASS_GETINSTANCEMETHOD(cls, @selector(str:with:and:)); meth = class_get_instance_method(cls, @selector(str:with:and:));
scan_initial("r*%u@%u:%u*%u*%u[4i]%u"); scan_initial("r*%u@%u:%u*%u*%u[4i]%u");
CHECK_IF(offs3 == offs2 + sizeof(signed char *) && offs4 == offs3 + sizeof(unsigned char *)); CHECK_IF(offs3 == offs2 + sizeof(signed char *) && offs4 == offs3 + sizeof(unsigned char *));
CHECK_IF(totsize == offs4 + sizeof(enum Enum *)); CHECK_IF(totsize == offs4 + sizeof(enum Enum *));
meth = CLASS_GETINSTANCEMETHOD(cls, @selector(meth1:with:with:)); meth = class_get_instance_method(cls, @selector(meth1:with:with:));
scan_initial("i%u@%u:%u^i%u[0i]%u[2i]%u"); scan_initial("i%u@%u:%u^i%u[0i]%u[2i]%u");
CHECK_IF(offs3 == offs2 + sizeof(int *) && offs4 == offs3 + sizeof(int *)); CHECK_IF(offs3 == offs2 + sizeof(int *) && offs4 == offs3 + sizeof(int *));
CHECK_IF(totsize == offs4 + sizeof(int *)); CHECK_IF(totsize == offs4 + sizeof(int *));
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* { dg-options "-fgnu-runtime" } */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-skip-if "" { *-*-* } { "-fnext-runtime" } { "" } } */
#include <objc/typedstream.h> #include <objc/typedstream.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
......
/* Typedefs of ObjC types should work without any bogus warnings. */ /* Typedefs of ObjC types should work without any bogus warnings. */
/* { dg-do compile } */ /* { dg-do compile } */
#include <objc/Object.h> #include "../objc-obj-c++-shared/Object1.h"
typedef Object MyObject; typedef Object MyObject;
......
/* Based on objc/execute/va_method.m, by Nicola Pero */ /* Based on objc/execute/va_method.m, by Nicola Pero */
/* { dg-do run } */ /* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h>
#include <stdarg.h> #include <stdarg.h>
#include <stdlib.h> #include <stdlib.h>
...@@ -67,3 +69,5 @@ int main (void) ...@@ -67,3 +69,5 @@ int main (void)
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
/* Check if the '-fzero-link' flag correctly emits an objc_getClass() call. */ /* Check if the '-fzero-link' flag correctly emits an objc_getClass() call. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime -fzero-link" } */
/* { dg-do compile } */
/* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-options "-fzero-link" } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort(); #define CHECK_IF(expr) if(!(expr)) abort();
......
/* Check if the '-fno-zero-link' flag correctly _omits_ an objc_getClass() call. */ /* Check if the '-fno-zero-link' flag correctly _omits_ an objc_getClass() call. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime -fno-zero-link" } */
/* { dg-do compile } */
/* { dg-do compile { target *-*-darwin* } } */
/* { dg-skip-if "" { *-*-* } { "-fgnu-runtime" } { "" } } */
/* { dg-options "-fno-zero-link" } */
#include "../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort(); #define CHECK_IF(expr) if(!(expr)) abort();
......
/* Check that the '-fzero-link' flag doesn't prevent messaging from working. */ /* Check that the '-fzero-link' flag doesn't prevent messaging from working. */
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
/* { dg-options "-fnext-runtime -fzero-link -lobjc" } */
/* { dg-do run { target *-*-darwin* } } */ /* { dg-do run { target *-*-darwin* } } */
/* { dg-options "-fzero-link" } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
#import <objc/objc.h> #include "../objc-obj-c++-shared/Object1.h"
#import <objc/Object.h> //#import <objc/objc.h>
extern void abort(void); extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort(); #define CHECK_IF(expr) if(!(expr)) abort();
...@@ -22,3 +24,5 @@ int main(void) { ...@@ -22,3 +24,5 @@ int main(void) {
CHECK_IF(val == 1593); CHECK_IF(val == 1593);
return 0; return 0;
} }
#include "../objc-obj-c++-shared/Object1-implementation.h"
#import <objc/Object.h> #import "../../objc-obj-c++-shared/Object1.h"
int main(void) int main(void)
{ {
......
/* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */
#include <stdlib.h>
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Test getting and calling the IMP of a method */ /* Test getting and calling the IMP of a method */
@interface TestClass @interface TestClass
...@@ -20,7 +21,6 @@ ...@@ -20,7 +21,6 @@
} }
@end @end
int main (void) int main (void)
{ {
Class class; Class class;
......
/* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */
#include <objc/objc.h>
#include <objc/objc-api.h>
#include "next_mapping.h" #include <stdlib.h>
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc-api.h>
/* Test the hidden argument _cmd to method calls */ /* Test the hidden argument _cmd to method calls */
......
/* Contributed by Nicola Pero - Thu Mar 8 16:27:46 CET 2001 */ /* Contributed by Nicola Pero - Thu Mar 8 16:27:46 CET 2001 */
#include <objc/objc.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
/* Test that by using -> we can access ivars of other objects of the same /* Test that by using -> we can access ivars of other objects of the same
class */ class */
......
#include <objc/objc.h> #import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
...@@ -19,4 +19,3 @@ ...@@ -19,4 +19,3 @@
@end @end
#include "bf-common.h" #include "bf-common.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
...@@ -22,4 +22,3 @@ ...@@ -22,4 +22,3 @@
@end @end
#include "bf-common.h" #include "bf-common.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
struct A { struct A {
int i; int i;
...@@ -23,4 +23,3 @@ struct A { ...@@ -23,4 +23,3 @@ struct A {
@end @end
#include "bf-common.h" #include "bf-common.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
struct A { struct A {
int i; int i;
...@@ -22,4 +22,3 @@ struct A { ...@@ -22,4 +22,3 @@ struct A {
@end @end
#include "bf-common.h" #include "bf-common.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
...@@ -14,4 +14,3 @@ ...@@ -14,4 +14,3 @@
@end @end
#include "bf-common.h" #include "bf-common.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
typedef enum typedef enum
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
...@@ -19,4 +19,3 @@ ...@@ -19,4 +19,3 @@
@end @end
#include "bf-common.h" #include "bf-common.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
......
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
@interface MyObject @interface MyObject
{ {
...@@ -20,4 +20,3 @@ ...@@ -20,4 +20,3 @@
@end @end
#include "bf-common.h" #include "bf-common.h"
#include <stdlib.h>
#include "../../objc-obj-c++-shared/next-mapping.h"
#ifndef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include <objc/encoding.h> #include <objc/encoding.h>
#endif #endif
#include "next_mapping.h"
void print_ivars (Class class) void print_ivars (Class class)
{ {
......
...@@ -3,8 +3,7 @@ ...@@ -3,8 +3,7 @@
* Fri Feb 2 11:48:01 GMT 2001 * Fri Feb 2 11:48:01 GMT 2001
*/ */
#include <objc/objc.h> #include "../../objc-obj-c++-shared/Protocol1.h"
#include <objc/Protocol.h>
@protocol MyProtocol @protocol MyProtocol
- (bycopy id) bycopyMethod; - (bycopy id) bycopyMethod;
......
...@@ -3,9 +3,7 @@ ...@@ -3,9 +3,7 @@
* Fri Feb 2 11:48:01 GMT 2001 * Fri Feb 2 11:48:01 GMT 2001
*/ */
#include <objc/objc.h> #include "../../objc-obj-c++-shared/Protocol1.h"
#include <objc/Object.h>
#include <objc/Protocol.h>
@protocol MyProtocol @protocol MyProtocol
+ (bycopy id<MyProtocol>) bycopyMethod; + (bycopy id<MyProtocol>) bycopyMethod;
......
...@@ -9,14 +9,12 @@ ...@@ -9,14 +9,12 @@
* interfere with what we are testing, which is that the `bycopy' * interfere with what we are testing, which is that the `bycopy'
* keyword generates the _F_BYCOPY qualifier for the return type. */ * keyword generates the _F_BYCOPY qualifier for the return type. */
#include <objc/objc.h> #include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/Object.h> #include "../../objc-obj-c++-shared/Protocol1.h"
#include <objc/Protocol.h>
#ifndef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include <objc/encoding.h> #include <objc/encoding.h>
#endif #endif
#include "next_mapping.h"
@protocol MyProtocol @protocol MyProtocol
+ (bycopy id<MyProtocol>) bycopyMethod; + (bycopy id<MyProtocol>) bycopyMethod;
......
#include <objc/Object.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
@interface Foo : Object @interface Foo : Object
+ + foo; + + foo;
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a RootClass */ /* Tests creating a RootClass */
@interface RootClass @interface RootClass
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods and a subclass overriding the superclass' accessor methods and a subclass overriding the superclass'
implementation, and using self to call another method of itself */ implementation, and using self to call another method of itself */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods and a subclass overriding the superclass' accessor methods and a subclass overriding the superclass'
implementation and using self to call another method of itself - in implementation and using self to call another method of itself - in
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with a class methods */ /* Tests creating a root class and a subclass with a class methods */
@interface RootClass @interface RootClass
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with a class accessor /* Tests creating a root class and a subclass with a class accessor
methods and a subclass overriding the superclass' implementation methods and a subclass overriding the superclass' implementation
but reusing it with super */ but reusing it with super */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with a class accessor /* Tests creating a root class and a subclass with a class accessor
methods and a subclass overriding the superclass' implementation, methods and a subclass overriding the superclass' implementation,
and using self to call another method of itself */ and using self to call another method of itself */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass */ /* Tests creating a root class and a subclass */
@interface RootClass @interface RootClass
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a minimal subclass tree */ /* Tests creating a root class and a minimal subclass tree */
@interface RootClass @interface RootClass
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods */ accessor methods */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods and a subclass overriding the superclass' accessor methods and a subclass overriding the superclass'
implementation */ implementation */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods and a subclass overriding the superclass' accessor methods and a subclass overriding the superclass'
implementation but reusing it with super */ implementation but reusing it with super */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods; accessor methods implemented in a separate accessor methods; accessor methods implemented in a separate
category */ category */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods and a subclass overriding the superclass' accessor methods and a subclass overriding the superclass'
implementation - in a category */ implementation - in a category */
......
/* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero - Tue Mar 6 23:05:53 CET 2001 */
#include "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include "next_mapping.h"
/* Tests creating a root class and a subclass with an ivar and /* Tests creating a root class and a subclass with an ivar and
accessor methods and a subclass overriding the superclass' accessor methods and a subclass overriding the superclass'
implementation but reusing it with super - in a category */ implementation but reusing it with super - in a category */
......
/* Contributed by Nicola Pero on Tue Mar 6 23:05:53 CET 2001 */ /* Contributed by Nicola Pero on Tue Mar 6 23:05:53 CET 2001 */
#include <stdlib.h>
#include "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
#include <stdlib.h>
/* /*
* Standard Tests For Classes and Objects - abort upon failing; return * Standard Tests For Classes and Objects - abort upon failing; return
......
/* Contributed by Nicola Pero - Fri Oct 26 22:39:32 BST 2001 */ /* Contributed by Nicola Pero - Fri Oct 26 22:39:32 BST 2001 */
#include <stdlib.h>
#include <objc/objc.h> #include <objc/objc.h>
/* Test calling a class method on self where self has been redefined /* Test calling a class method on self where self has been redefined
......
/* Contributed by Nicola Pero - Thu Mar 8 17:23:59 CET 2001 */ /* Contributed by Nicola Pero - Thu Mar 8 17:23:59 CET 2001 */
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
@compatibility_alias MyObject Object; @compatibility_alias MyObject Object;
......
/* Contributed by Nicola Pero - Thu Mar 8 16:27:46 CET 2001 */ /* Contributed by Nicola Pero - Thu Mar 8 16:27:46 CET 2001 */
#include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
/* Test very simple @encode */ /* Test very simple @encode */
......
/* Contributed by Nicola Pero - Wed Dec 5 17:12:40 GMT 2001 */ /* Contributed by Nicola Pero - Wed Dec 5 17:12:40 GMT 2001 */
#include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
/* Test using a bitfield enumeration ivar. */ /* Test using a bitfield enumeration ivar. */
......
/* Contributed by Nicola Pero - Wed Dec 5 17:12:40 GMT 2001 */ /* Contributed by Nicola Pero - Wed Dec 5 17:12:40 GMT 2001 */
#include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
typedef enum { black, white } color; typedef enum { black, white } color;
......
...@@ -2,15 +2,15 @@ ...@@ -2,15 +2,15 @@
exceptions. */ exceptions. */
/* Developed by Ziemowit Laski <zlaski@apple.com>. */ /* Developed by Ziemowit Laski <zlaski@apple.com>. */
#include <objc/Object.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h>
#import "../../../objc-obj-c++-shared/Object1.h"
/* The following is not required in actual user code; we include it /* The following is not required in actual user code; we include it
here to check that the compiler generates an internal definition of here to check that the compiler generates an internal definition of
_setjmp that is consistent with what <setjmp.h> provides. */ _setjmp that is consistent with what <setjmp.h> provides. */
#include <setjmp.h> #include <setjmp.h>
extern void abort(void);
#define CHECK_IF(expr) if(!(expr)) abort() #define CHECK_IF(expr) if(!(expr)) abort()
@interface Frob: Object @interface Frob: Object
......
#include <objc/Object.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#import "../../../objc-obj-c++-shared/Object1.h"
static int made_try = 0; static int made_try = 0;
......
/* Check that throwing an exception from a -forward:: works. */ /* Check that throwing an exception from a -forward:: works. */
/* Developed by Marcin Koziej <creep@desk.pl>. */ /* Developed by Marcin Koziej <creep@desk.pl>. */
#import <objc/Object.h>
#import <objc/objc-api.h>
#include <stdlib.h> #include <stdlib.h>
#import "../../../objc-obj-c++-shared/Object1.h"
#import <objc/objc-api.h>
static int i; static int i;
......
...@@ -2,9 +2,9 @@ ...@@ -2,9 +2,9 @@
block survive until the @catch block is reached. */ block survive until the @catch block is reached. */
/* Developed by Ziemowit Laski <zlaski@apple.com>. */ /* Developed by Ziemowit Laski <zlaski@apple.com>. */
#include <objc/Object.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#import "../../../objc-obj-c++-shared/Object1.h"
int gi1 = 9, gi2 = 19; int gi1 = 9, gi2 = 19;
float gf1 = 9.0, gf2 = 19.0; float gf1 = 9.0, gf2 = 19.0;
......
#import <objc/Object.h> #include <stdlib.h>
#import "../../../objc-obj-c++-shared/Object1.h"
/* do nothing except prove we can compile and link code calling the
ecceptions mechanism */
int main(void) int main(void)
{ {
[Object class]; @try {
return 0; int a = 1 ;
@throw [Object new];
}
@catch (Object *obj) {
return 0;
}
abort();
} }
#import "../../../objc-obj-c++-shared/Object1-implementation.h"
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Object.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
/* Tests defining a protocol and a class adopting it */ /* Tests defining a protocol and a class adopting it */
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Object.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
/* Test defining a protocol, a class adopting it, and using an object /* Test defining a protocol, a class adopting it, and using an object
of type `id <protocol>'. */ of type `id <protocol>'. */
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Object.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
/* Test defining two protocol, a class adopting both of them, /* Test defining two protocol, a class adopting both of them,
and using an object of type `id <Protocol1, Protocol2>' */ and using an object of type `id <Protocol1, Protocol2>' */
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Object.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
/* Test defining a protocol, a class adopting it in a category */ /* Test defining a protocol, a class adopting it in a category */
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Protocol.h> #include <stdlib.h>
#include "../../objc-obj-c++-shared/Protocol1.h"
/* Test defining a protocol, and accessing it using @protocol */ /* Test defining a protocol, and accessing it using @protocol */
...@@ -23,7 +24,11 @@ int main (void) ...@@ -23,7 +24,11 @@ int main (void)
{ {
Protocol *protocol = @protocol (Evaluating); Protocol *protocol = @protocol (Evaluating);
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
if (strcmp (protocol_getName(protocol), "Evaluating"))
#else
if (strcmp ([protocol name], "Evaluating")) if (strcmp ([protocol name], "Evaluating"))
#endif
{ {
abort (); abort ();
} }
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Protocol.h> #include <stdlib.h>
#include "../../objc-obj-c++-shared/Protocol1.h"
/* Test defining a protocol, and accessing it using @protocol */ /* Test defining a protocol, and accessing it using @protocol */
...@@ -15,7 +16,11 @@ int main (void) ...@@ -15,7 +16,11 @@ int main (void)
{ {
Protocol *protocol = @protocol (Evaluating); Protocol *protocol = @protocol (Evaluating);
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
if (strcmp (protocol_getName(protocol), "Evaluating"))
#else
if (strcmp ([protocol name], "Evaluating")) if (strcmp ([protocol name], "Evaluating"))
#endif
{ {
abort (); abort ();
} }
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#include <objc/objc.h>
#include <objc/Object.h> #include <stdlib.h>
#include <objc/Protocol.h> #import "../../objc-obj-c++-shared/Protocol1.h"
/* Test defining two protocols, one incorporating the other one. */ /* Test defining two protocols, one incorporating the other one. */
......
...@@ -2,20 +2,13 @@ ...@@ -2,20 +2,13 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <objc/Object.h>
#import "../../objc-obj-c++-shared/Object1.h"
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc-api.h> #include <objc/objc-api.h>
#define VALUETOUSE 1234567890 #define VALUETOUSE 1234567890
#ifdef __NEXT_RUNTIME__
/* Does not run with the next runtime. */
int main(void)
{
return 0;
}
#else
id forwarder, receiver; id forwarder, receiver;
@interface Forwarder: Object @interface Forwarder: Object
...@@ -62,8 +55,13 @@ id forwarder, receiver; ...@@ -62,8 +55,13 @@ id forwarder, receiver;
receiver = theReceiver; receiver = theReceiver;
return self; return self;
} }
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
- forward: (SEL)theSel: (marg_list)theArgFrame
{
#else
-(retval_t) forward: (SEL)theSel: (arglist_t)theArgFrame -(retval_t) forward: (SEL)theSel: (arglist_t)theArgFrame
{ {
#endif
/* If we have a reciever try to perform on that object */ /* If we have a reciever try to perform on that object */
if (receiver) if (receiver)
return [receiver performv: theSel: theArgFrame]; return [receiver performv: theSel: theArgFrame];
...@@ -81,5 +79,3 @@ int main() ...@@ -81,5 +79,3 @@ int main()
[forwarder display]; [forwarder display];
exit(0); exit(0);
} }
#endif
...@@ -20,9 +20,8 @@ if { [istarget alpha*-*-linux*] ...@@ -20,9 +20,8 @@ if { [istarget alpha*-*-linux*]
|| [istarget alpha*-dec-osf*] || [istarget alpha*-dec-osf*]
|| ([istarget i?86-*-solaris2*] && [check_effective_target_lp64] ) || ([istarget i?86-*-solaris2*] && [check_effective_target_lp64] )
|| [istarget mips-sgi-irix*] || [istarget mips-sgi-irix*]
|| [istarget powerpc*-*-darwin*]
|| [istarget sparc*-sun-solaris2*] || [istarget sparc*-sun-solaris2*]
|| ([istarget x86_64-*-darwin*] && [check_effective_target_lp64] ) } { || ([istarget *-*-darwin*] && [check_effective_target_lp64] ) } {
set torture_eval_before_execute { set torture_eval_before_execute {
global compiler_conditional_xfail_data global compiler_conditional_xfail_data
set compiler_conditional_xfail_data { set compiler_conditional_xfail_data {
......
#include <objc/Object.h> #import "../../objc-obj-c++-shared/Object1.h"
@interface Foo : Object @interface Foo : Object
+ + bar; + + bar;
......
/* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 21:35:47 CET 2001 */
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
@interface Object (StopProtocol) @interface Object (StopProtocol)
- (void) stop; - (void) stop;
......
...@@ -8,8 +8,9 @@ ...@@ -8,8 +8,9 @@
proper order. proper order.
*/ */
#include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
@interface A : Object @interface A : Object
@end @end
......
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
/* Contributed by Ziemowit Laski <zlaski@apple.com>. */ /* Contributed by Ziemowit Laski <zlaski@apple.com>. */
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
int bappy (int (*blargh) (int a, int b, int c)) int bappy (int (*blargh) (int a, int b, int c))
{ {
......
/* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */
#include <objc/objc.h> #import "../../objc-obj-c++-shared/Object1.h"
#include <objc/Object.h> #import <objc/objc.h>
/* Test that using the same name for different things makes no /* Test that using the same name for different things makes no
problem */ problem */
......
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
* Tue Sep 19 4:29AM * Tue Sep 19 4:29AM
*/ */
#include "../../objc-obj-c++-shared/Protocol1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Protocol.h>
@protocol MyProtocol @protocol MyProtocol
- (oneway void) methodA; - (oneway void) methodA;
......
...@@ -2,8 +2,8 @@ ...@@ -2,8 +2,8 @@
* Contributed by Nicola Pero <n.pero@mi.flashnet.it> * Contributed by Nicola Pero <n.pero@mi.flashnet.it>
* Tue Sep 19 4:34AM * Tue Sep 19 4:34AM
*/ */
#include "../../objc-obj-c++-shared/Protocol1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Protocol.h>
@protocol MyProtocol @protocol MyProtocol
+ (oneway void) methodA; + (oneway void) methodA;
......
/* Contributed by Nicola Pero - Tue Jul 3 10:55:21 BST 2001 */ /* Contributed by Nicola Pero - Tue Jul 3 10:55:21 BST 2001 */
#import "../../objc-obj-c++-shared/next-mapping.h"
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
#include "next_mapping.h"
/* This test demonstrate a failure in object_is_class which was fixed */ /* This test demonstrate a failure in object_is_class which was fixed */
......
/* Contributed by Nicola Pero - Tue Jul 3 10:55:21 BST 2001 */ /* Contributed by Nicola Pero - Tue Jul 3 10:55:21 BST 2001 */
#include <objc/objc.h> #import "../../objc-obj-c++-shared/Object1.h"
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <objc/objc-api.h> #include <objc/objc-api.h>
#include <objc/Object.h>
#include "next_mapping.h"
/* This test demonstrate a failure in object_is_meta_class which was fixed */ /* This test demonstrate a failure in object_is_meta_class which was fixed */
......
/* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */ /* Contributed by Nicola Pero - Fri Mar 9 19:39:15 CET 2001 */
#import "../../objc-obj-c++-shared/Object1.h"
#include <objc/objc.h> #include <objc/objc.h>
#include <objc/Object.h>
/* Test the @private, @protected, @public keyworks for ivars. We only /* Test the @private, @protected, @public keyworks for ivars. We only
check syntax. */ check syntax. */
......
/* Contributed by Nicola Pero - Fri Jun 4 03:16:17 BST 2004 */ /* Contributed by Nicola Pero - Fri Jun 4 03:16:17 BST 2004 */
/* Test that a protocol is equal to itself. */ /* Test that a protocol is equal to itself. */
#include <objc/Protocol.h> #include "../../objc-obj-c++-shared/Protocol1.h"
@protocol Foo @protocol Foo
- (void)foo; - (void)foo;
...@@ -10,7 +10,11 @@ int main (void) ...@@ -10,7 +10,11 @@ int main (void)
{ {
Protocol *protocol = @protocol(Foo); Protocol *protocol = @protocol(Foo);
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
if ( !protocol_isEqual (protocol, protocol))
#else
if (! [protocol isEqual: protocol]) if (! [protocol isEqual: protocol])
#endif
{ {
abort (); abort ();
} }
......
/* Contributed by Nicola Pero - Fri Jun 4 03:16:17 BST 2004 */ /* Contributed by Nicola Pero - Fri Jun 4 03:16:17 BST 2004 */
/* Test that protocols with different names are different. */ /* Test that protocols with different names are different. */
#include <objc/Protocol.h>
#include "../../objc-obj-c++-shared/Protocol1.h"
@protocol Foo1 @protocol Foo1
- (void)foo1; - (void)foo1;
...@@ -12,7 +13,11 @@ ...@@ -12,7 +13,11 @@
int main (void) int main (void)
{ {
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
if (protocol_isEqual (@protocol(Foo1), @protocol(Foo2)))
#else
if ([@protocol(Foo1) isEqual: @protocol(Foo2)]) if ([@protocol(Foo1) isEqual: @protocol(Foo2)])
#endif
{ {
abort (); abort ();
} }
......
/* Contributed by Nicola Pero - Fri Jun 4 03:16:17 BST 2004 */ /* Contributed by Nicola Pero - Fri Jun 4 03:16:17 BST 2004 */
/* Test that a protocol is not equal to nil. */ /* Test that a protocol is not equal to nil. */
#include <objc/Protocol.h>
#include "../../objc-obj-c++-shared/Protocol1.h"
@protocol Foo @protocol Foo
- (void)foo; - (void)foo;
...@@ -8,7 +9,11 @@ ...@@ -8,7 +9,11 @@
int main (void) int main (void)
{ {
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
if (protocol_isEqual (@protocol(Foo), nil))
#else
if ([@protocol(Foo) isEqual: nil]) if ([@protocol(Foo) isEqual: nil])
#endif
{ {
abort (); abort ();
} }
......
/* Contributed by David Ayers - Fri Jun 4 03:16:17 BST 2004 */ /* Contributed by David Ayers - Fri Jun 4 03:16:17 BST 2004 */
/* Test that a protocol is not equal to something which is not a protocol. */ /* Test that a protocol is not equal to something which is not a protocol. */
#include <objc/Protocol.h>
#include "../../objc-obj-c++-shared/Protocol1.h"
@protocol Foo @protocol Foo
- (void)foo; - (void)foo;
...@@ -9,7 +10,11 @@ ...@@ -9,7 +10,11 @@
int main (void) int main (void)
{ {
/* A Protocol object should not be equal to a Class object. */ /* A Protocol object should not be equal to a Class object. */
#ifdef NEXT_OBJC_USE_NEW_INTERFACE
if (protocol_isEqual (@protocol(Foo), objc_getClass("Protocol")))
#else
if ([@protocol(Foo) isEqual: [Protocol class]]) if ([@protocol(Foo) isEqual: [Protocol class]])
#endif
{ {
abort (); abort ();
} }
......
/* Contributed by Nicola Pero - Thu Mar 8 16:27:46 CET 2001 */ /* Contributed by Nicola Pero - Thu Mar 8 16:27:46 CET 2001 */
#include <objc/objc.h>
#include "next_mapping.h" #import "../../objc-obj-c++-shared/next-mapping.h"
#import <objc/objc.h>
/* Test that instance methods of root classes are available as class /* Test that instance methods of root classes are available as class
methods to other classes as well */ methods to other classes as well */
......
/* Based on a test case contributed by Nicola Pero. */ /* Based on a test case contributed by Nicola Pero. */
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#ifdef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include "next_mapping.h"
#else
#include <objc/NXConstStr.h> #include <objc/NXConstStr.h>
#endif #endif
......
/* Based on a test case contributed by Nicola Pero. */ /* Based on a test case contributed by Nicola Pero. */
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#ifdef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include "next_mapping.h"
#else
#include <objc/NXConstStr.h> #include <objc/NXConstStr.h>
#endif #endif
......
/* Based on a test case contributed by Nicola Pero. */ /* Based on a test case contributed by Nicola Pero. */
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#ifdef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include "next_mapping.h"
#else
#include <objc/NXConstStr.h> #include <objc/NXConstStr.h>
#endif #endif
......
/* Based on a test case contributed by Nicola Pero. */ /* Based on a test case contributed by Nicola Pero. */
#import "../../objc-obj-c++-shared/next-mapping.h"
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#ifdef __NEXT_RUNTIME__ #ifndef __NEXT_RUNTIME__
#include "next_mapping.h"
#else
#include <objc/NXConstStr.h> #include <objc/NXConstStr.h>
#endif #endif
......
#import <objc/Object.h> #import "../../objc-obj-c++-shared/Object1.h"
int main(void) int main(void)
{ {
[Object class]; [Object class];
return 0; return 0;
} }
#import "../../objc-obj-c++-shared/Object1-implementation.h"
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment