What I would otherwise forget
Valid Sept 2017 with swift:master
This is a cache layer to avoid compiling the same file repeatedly.
Key difference here over request.structure – the file is properly compiled
up to Sema and type-checked, not just parsed.  Presence of USRs is giveaway.
Pulls attributes from the ValueDecl for propagation.  Note this means we
cannot be talking about an extension per se because that is further up the
hierarchy.
Doc comment handling: uses ide::getDocumentationCommentAsXML() which does the
parent lookup for class inheritance and protcol extensions, then does some
custom code to look up protocol conformance.  This routine creates all the XML
for the full_as_xml field including the declaration:
CommentToXMLConverter::visitCommentParts uses a very customized declaration
printer based on PrintOptions::printInterface().  In particular it shows most
decl attributes except @discardableResult.  Probably because that is on by
default on interfaces generated from ObjC.  Which makes no sense here.
Uses PrintOptions::printQuickHelpDeclaration() style for the annotated
declaration field, and also the fully-annotated declaration field.  In particular
this means ‘include decl attributes except @available’.
Uses ide::walkOverriddenDecls() to find USRs of swift + objC things that have
been overridden (functions and properties not nominals).
Related declarations code is incomplete but should return declarations with the same name in the same (or lower?) scope.
Group names. This looks to be something to do with module definitions and serialization. Ignore for now.
So then these fields are are returned in the cursorinfo:
And optionally:
ParamDecls)And never:
CursorInfo)