Start rewriting ObjC interfaces. As a start, we comment out all the methods. This involved refining how the parser/AST passes/manages SourceLocations for ObjcMethodDecl's.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43404 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Steve Naroff 2007-10-26 20:53:56 +00:00
Родитель 7780d2d52b
Коммит bef1185418
8 изменённых файлов: 59 добавлений и 20 удалений

Просмотреть файл

@ -58,6 +58,7 @@ namespace {
void RewriteInclude(SourceLocation Loc); void RewriteInclude(SourceLocation Loc);
void RewriteTabs(); void RewriteTabs();
void RewriteForwardClassDecl(ObjcClassDecl *Dcl); void RewriteForwardClassDecl(ObjcClassDecl *Dcl);
void RewriteInterfaceDecl(ObjcInterfaceDecl *Dcl);
// Expression Rewriting. // Expression Rewriting.
Stmt *RewriteFunctionBody(Stmt *S); Stmt *RewriteFunctionBody(Stmt *S);
@ -120,8 +121,9 @@ void RewriteTest::HandleTopLevelDecl(Decl *D) {
GetClassFunctionDecl = FD; GetClassFunctionDecl = FD;
else if (strcmp(FD->getName(), "sel_getUid") == 0) else if (strcmp(FD->getName(), "sel_getUid") == 0)
SelGetUidFunctionDecl = FD; SelGetUidFunctionDecl = FD;
} else if (ObjcInterfaceDecl *MD = dyn_cast<ObjcInterfaceDecl>(D)) {
RewriteInterfaceDecl(MD);
} }
// If we have a decl in the main file, see if we should rewrite it. // If we have a decl in the main file, see if we should rewrite it.
if (SM->getDecomposedFileLoc(Loc).first == MainFileID) if (SM->getDecomposedFileLoc(Loc).first == MainFileID)
return HandleDeclInMainFile(D); return HandleDeclInMainFile(D);
@ -263,6 +265,31 @@ void RewriteTest::RewriteForwardClassDecl(ObjcClassDecl *ClassDecl) {
typedefString.c_str(), typedefString.size()); typedefString.c_str(), typedefString.size());
} }
void RewriteTest::RewriteInterfaceDecl(ObjcInterfaceDecl *ClassDecl) {
int nInstanceMethods = ClassDecl->getNumInstanceMethods();
ObjcMethodDecl **instanceMethods = ClassDecl->getInstanceMethods();
for (int i = 0; i < nInstanceMethods; i++) {
ObjcMethodDecl *instanceMethod = instanceMethods[i];
SourceLocation Loc = instanceMethod->getLocStart();
Rewrite.ReplaceText(Loc, 0, "// ", 3);
// FIXME: handle methods that are declared across multiple lines.
}
int nClassMethods = ClassDecl->getNumClassMethods();
ObjcMethodDecl **classMethods = ClassDecl->getClassMethods();
for (int i = 0; i < nClassMethods; i++) {
ObjcMethodDecl *classMethod = classMethods[i];
SourceLocation Loc = classMethod->getLocStart();
Rewrite.ReplaceText(Loc, 0, "// ", 3);
// FIXME: handle methods that are declared across multiple lines.
}
}
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// Function Body / Expression rewriting // Function Body / Expression rewriting
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
@ -294,7 +321,7 @@ Stmt *RewriteTest::RewriteFunctionBody(Stmt *S) {
// FIXME: Missing definition of Rewrite.InsertText(clang::SourceLocation, char const*, unsigned int). // FIXME: Missing definition of Rewrite.InsertText(clang::SourceLocation, char const*, unsigned int).
// Rewrite.InsertText(startLoc, messString.c_str(), messString.size()); // Rewrite.InsertText(startLoc, messString.c_str(), messString.size());
// Tried this, but it didn't work either... // Tried this, but it didn't work either...
// Rewrite.ReplaceText(startLoc, 0, messString.c_str(), messString.size()); Rewrite.ReplaceText(startLoc, 0, messString.c_str(), messString.size());
return RewriteMessageExpr(MessExpr); return RewriteMessageExpr(MessExpr);
} }
// Return this stmt unmodified. // Return this stmt unmodified.

Просмотреть файл

@ -379,9 +379,9 @@ Parser::DeclTy *Parser::ParseObjCMethodPrototype(DeclTy *IDecl,
assert((Tok.is(tok::minus) || Tok.is(tok::plus)) && "expected +/-"); assert((Tok.is(tok::minus) || Tok.is(tok::plus)) && "expected +/-");
tok::TokenKind methodType = Tok.getKind(); tok::TokenKind methodType = Tok.getKind();
ConsumeToken(); SourceLocation mLoc = ConsumeToken();
DeclTy *MDecl = ParseObjCMethodDecl(methodType, MethodImplKind); DeclTy *MDecl = ParseObjCMethodDecl(mLoc, methodType, MethodImplKind);
// Since this rule is used for both method declarations and definitions, // Since this rule is used for both method declarations and definitions,
// the caller is (optionally) responsible for consuming the ';'. // the caller is (optionally) responsible for consuming the ';'.
return MDecl; return MDecl;
@ -526,15 +526,16 @@ Parser::TypeTy *Parser::ParseObjCTypeName() {
/// objc-keyword-attributes: [OBJC2] /// objc-keyword-attributes: [OBJC2]
/// __attribute__((unused)) /// __attribute__((unused))
/// ///
Parser::DeclTy *Parser::ParseObjCMethodDecl(tok::TokenKind mType, Parser::DeclTy *Parser::ParseObjCMethodDecl(SourceLocation mLoc,
tok::TokenKind mType,
tok::ObjCKeywordKind MethodImplKind) tok::ObjCKeywordKind MethodImplKind)
{ {
// Parse the return type. // Parse the return type.
TypeTy *ReturnType = 0; TypeTy *ReturnType = 0;
if (Tok.is(tok::l_paren)) if (Tok.is(tok::l_paren))
ReturnType = ParseObjCTypeName(); ReturnType = ParseObjCTypeName();
SourceLocation mLoc; SourceLocation selLoc;
IdentifierInfo *SelIdent = ParseObjCSelector(mLoc); IdentifierInfo *SelIdent = ParseObjCSelector(selLoc);
if (Tok.isNot(tok::colon)) { if (Tok.isNot(tok::colon)) {
if (!SelIdent) { if (!SelIdent) {
Diag(Tok, diag::err_expected_ident); // missing selector name. Diag(Tok, diag::err_expected_ident); // missing selector name.
@ -548,7 +549,8 @@ Parser::DeclTy *Parser::ParseObjCMethodDecl(tok::TokenKind mType,
MethodAttrs = ParseAttributes(); MethodAttrs = ParseAttributes();
Selector Sel = PP.getSelectorTable().getNullarySelector(SelIdent); Selector Sel = PP.getSelectorTable().getNullarySelector(SelIdent);
return Actions.ActOnMethodDeclaration(mLoc, mType, ReturnType, Sel, return Actions.ActOnMethodDeclaration(mLoc, Tok.getLocation(),
mType, ReturnType, Sel,
0, 0, MethodAttrs, MethodImplKind); 0, 0, MethodAttrs, MethodImplKind);
} }
@ -614,7 +616,8 @@ Parser::DeclTy *Parser::ParseObjCMethodDecl(tok::TokenKind mType,
Selector Sel = PP.getSelectorTable().getSelector(KeyIdents.size(), Selector Sel = PP.getSelectorTable().getSelector(KeyIdents.size(),
&KeyIdents[0]); &KeyIdents[0]);
return Actions.ActOnMethodDeclaration(mLoc, mType, ReturnType, Sel, return Actions.ActOnMethodDeclaration(mLoc, Tok.getLocation(),
mType, ReturnType, Sel,
&KeyTypes[0], &ArgNames[0], &KeyTypes[0], &ArgNames[0],
MethodAttrs, MethodImplKind); MethodAttrs, MethodImplKind);
} }

Просмотреть файл

@ -516,7 +516,9 @@ public:
virtual void ActOnAddMethodsToObjcDecl(Scope* S, DeclTy *ClassDecl, virtual void ActOnAddMethodsToObjcDecl(Scope* S, DeclTy *ClassDecl,
DeclTy **allMethods, unsigned allNum); DeclTy **allMethods, unsigned allNum);
virtual DeclTy *ActOnMethodDeclaration(SourceLocation MethodLoc, virtual DeclTy *ActOnMethodDeclaration(
SourceLocation BeginLoc, // location of the + or -.
SourceLocation EndLoc, // location of the ; or {.
tok::TokenKind MethodType, TypeTy *ReturnType, Selector Sel, tok::TokenKind MethodType, TypeTy *ReturnType, Selector Sel,
// optional arguments. The number of types/arguments is obtained // optional arguments. The number of types/arguments is obtained
// from the Sel.getNumArgs(). // from the Sel.getNumArgs().

Просмотреть файл

@ -1941,7 +1941,8 @@ void Sema::ActOnAddMethodsToObjcDecl(Scope* S, DeclTy *classDecl,
} }
} }
Sema::DeclTy *Sema::ActOnMethodDeclaration(SourceLocation MethodLoc, Sema::DeclTy *Sema::ActOnMethodDeclaration(
SourceLocation MethodLoc, SourceLocation EndLoc,
tok::TokenKind MethodType, TypeTy *ReturnType, Selector Sel, tok::TokenKind MethodType, TypeTy *ReturnType, Selector Sel,
// optional arguments. The number of types/arguments is obtained // optional arguments. The number of types/arguments is obtained
// from the Sel.getNumArgs(). // from the Sel.getNumArgs().
@ -1968,7 +1969,7 @@ Sema::DeclTy *Sema::ActOnMethodDeclaration(SourceLocation MethodLoc,
else // get the type for "id". else // get the type for "id".
resultDeclType = GetObjcIdType(MethodLoc); resultDeclType = GetObjcIdType(MethodLoc);
ObjcMethodDecl* ObjcMethod = new ObjcMethodDecl(MethodLoc, Sel, ObjcMethodDecl* ObjcMethod = new ObjcMethodDecl(MethodLoc, EndLoc, Sel,
resultDeclType, 0, -1, AttrList, resultDeclType, 0, -1, AttrList,
MethodType == tok::minus, MethodType == tok::minus,
MethodDeclKind == tok::objc_optional ? MethodDeclKind == tok::objc_optional ?

Просмотреть файл

@ -756,7 +756,6 @@
08FB7793FE84155DC02AAC07 /* Project object */ = { 08FB7793FE84155DC02AAC07 /* Project object */ = {
isa = PBXProject; isa = PBXProject;
buildConfigurationList = 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "clang" */; buildConfigurationList = 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "clang" */;
compatibilityVersion = "Xcode 2.4";
hasScannedForEncodings = 1; hasScannedForEncodings = 1;
mainGroup = 08FB7794FE84155DC02AAC07 /* clang */; mainGroup = 08FB7794FE84155DC02AAC07 /* clang */;
projectDirPath = ""; projectDirPath = "";

Просмотреть файл

@ -219,19 +219,25 @@ private:
/// List of attributes for this method declaration. /// List of attributes for this method declaration.
AttributeList *MethodAttrs; AttributeList *MethodAttrs;
SourceLocation EndLoc; // the location of the ';' or '{'.
public: public:
ObjcMethodDecl(SourceLocation L, Selector SelInfo, QualType T, ObjcMethodDecl(SourceLocation beginLoc, SourceLocation endLoc,
Selector SelInfo, QualType T,
ParmVarDecl **paramInfo = 0, int numParams=-1, ParmVarDecl **paramInfo = 0, int numParams=-1,
AttributeList *M = 0, bool isInstance = true, AttributeList *M = 0, bool isInstance = true,
ImplementationControl impControl = None, ImplementationControl impControl = None,
Decl *PrevDecl = 0) Decl *PrevDecl = 0)
: Decl(ObjcMethod, L), : Decl(ObjcMethod, beginLoc),
IsInstance(isInstance), DeclImplementation(impControl), IsInstance(isInstance), DeclImplementation(impControl),
SelName(SelInfo), MethodDeclType(T), SelName(SelInfo), MethodDeclType(T),
ParamInfo(paramInfo), NumMethodParams(numParams), ParamInfo(paramInfo), NumMethodParams(numParams),
MethodAttrs(M) {} MethodAttrs(M), EndLoc(endLoc) {}
virtual ~ObjcMethodDecl(); virtual ~ObjcMethodDecl();
// Location information, modeled after the Stmt API.
SourceLocation getLocStart() const { return getLocation(); }
SourceLocation getLocEnd() const { return EndLoc; }
Selector getSelector() const { return SelName; } Selector getSelector() const { return SelName; }
QualType getResultType() const { return MethodDeclType; } QualType getResultType() const { return MethodDeclType; }

Просмотреть файл

@ -519,7 +519,8 @@ public:
} }
// ActOnMethodDeclaration - called for all method declarations. // ActOnMethodDeclaration - called for all method declarations.
virtual DeclTy *ActOnMethodDeclaration( virtual DeclTy *ActOnMethodDeclaration(
SourceLocation MethodLoc, SourceLocation BeginLoc, // location of the + or -.
SourceLocation EndLoc, // location of the ; or {.
tok::TokenKind MethodType, // tok::minus for instance, tok::plus for class. tok::TokenKind MethodType, // tok::minus for instance, tok::plus for class.
TypeTy *ReturnType, // the method return type. TypeTy *ReturnType, // the method return type.
Selector Sel, // a unique name for the method. Selector Sel, // a unique name for the method.

Просмотреть файл

@ -295,7 +295,7 @@ private:
void ParseObjCMethodRequirement(); void ParseObjCMethodRequirement();
DeclTy *ParseObjCMethodPrototype(DeclTy *classOrCat, DeclTy *ParseObjCMethodPrototype(DeclTy *classOrCat,
tok::ObjCKeywordKind MethodImplKind = tok::objc_not_keyword); tok::ObjCKeywordKind MethodImplKind = tok::objc_not_keyword);
DeclTy *ParseObjCMethodDecl(tok::TokenKind mType, DeclTy *ParseObjCMethodDecl(SourceLocation mLoc, tok::TokenKind mType,
tok::ObjCKeywordKind MethodImplKind = tok::objc_not_keyword); tok::ObjCKeywordKind MethodImplKind = tok::objc_not_keyword);
void ParseObjCPropertyAttribute(DeclTy *interfaceDecl); void ParseObjCPropertyAttribute(DeclTy *interfaceDecl);
void ParseObjCPropertyDecl(DeclTy *interfaceDecl); void ParseObjCPropertyDecl(DeclTy *interfaceDecl);