llvm-project/clang
Ted Kremenek a4bd9a0c0e Add new attribute 'objc_suppress_protocol' to suppress protocol conformance for a class.
The idea is to allow a class to stipulate that its methods (and those
of its parents) cannot be used for protocol conformance in a subclass.
A subclass is then explicitly required to re-implement those methods
of they are present in the class marked with this attribute.

Currently the attribute can only be applied to an @interface, and
not a category or class extension.  This is by design.  Unlike
protocol conformance, where a category can add explicit conformance
of a protocol to class, this anti-conformance really needs to be
observed uniformly by all clients of the class.  That's because
the absence of the attribute implies more permissive checking of
protocol conformance.

This unfortunately required changing method lookup in ObjCInterfaceDecl
to take an optional protocol parameter.  This should not slow down
method lookup in most cases, and is just used for protocol conformance.

llvm-svn: 195323
2013-11-21 07:20:42 +00:00
..
INPUTS
bindings Documentation parsing: add support for \throws \throw \exception commands 2013-11-12 22:16:08 +00:00
docs Update to next release numbers. 2013-11-20 10:13:37 +00:00
examples Add irreader to the component list, because ParseIR is called. 2013-10-19 08:33:11 +00:00
include Add new attribute 'objc_suppress_protocol' to suppress protocol conformance for a class. 2013-11-21 07:20:42 +00:00
lib Add new attribute 'objc_suppress_protocol' to suppress protocol conformance for a class. 2013-11-21 07:20:42 +00:00
runtime Darwin(ish): enable embedded compiler-rt builds on Darwin. 2013-11-15 23:12:44 +00:00
test Add new attribute 'objc_suppress_protocol' to suppress protocol conformance for a class. 2013-11-21 07:20:42 +00:00
tools Install clang-format's editor integrations in $PREFIX/share/clang/ 2013-11-14 22:48:06 +00:00
unittests clang-format: Improve formatting of ObjC method expressions. 2013-11-21 01:46:33 +00:00
utils Implemented DefaultIntArgument in the table generator and start using it in semantic analysis. Removes some magic numbers. 2013-11-21 00:28:23 +00:00
www Tests for core issues 251-270. 2013-11-18 05:24:03 +00:00
.arcconfig
.clang-format Switch the default mode for clang-format to '-file'. Make 'LLVM' the 2013-09-02 07:42:02 +00:00
.gitignore
CMakeLists.txt [libclang] Some changes on the linker options for libclang on a CMake build. 2013-11-06 08:37:50 +00:00
CODE_OWNERS.TXT Update contact information. 2013-11-15 17:35:53 +00:00
INSTALL.txt Reverting test commit 2013-06-07 05:33:21 +00:00
LICENSE.TXT
Makefile
ModuleInfo.txt
NOTES.txt
README.txt

README.txt

//===----------------------------------------------------------------------===//
// C Language Family Front-end
//===----------------------------------------------------------------------===//

Welcome to Clang.  This is a compiler front-end for the C family of languages
(C, C++, Objective-C, and Objective-C++) which is built as part of the LLVM
compiler infrastructure project.

Unlike many other compiler frontends, Clang is useful for a number of things
beyond just compiling code: we intend for Clang to be host to a number of
different source level tools.  One example of this is the Clang Static Analyzer.

If you're interested in more (including how to build Clang) it is best to read
the relevant web sites.  Here are some pointers:

Information on Clang:              http://clang.llvm.org/
Building and using Clang:          http://clang.llvm.org/get_started.html
Clang Static Analyzer:             http://clang-analyzer.llvm.org/
Information on the LLVM project:   http://llvm.org/

If you have questions or comments about Clang, a great place to discuss them is
on the Clang development mailing list:
  http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev

If you find a bug in Clang, please file it in the LLVM bug tracker:
  http://llvm.org/bugs/