forked from OSchip/llvm-project
Minor whitespace and comment fixes. No functionality change.
llvm-svn: 120266
This commit is contained in:
parent
02d6b7e093
commit
20c9f1db48
|
@ -134,7 +134,7 @@ struct EffectiveContext {
|
|||
bool Dependent;
|
||||
};
|
||||
|
||||
/// Like sema:;AccessedEntity, but kindly lets us scribble all over
|
||||
/// Like sema::AccessedEntity, but kindly lets us scribble all over
|
||||
/// it.
|
||||
struct AccessTarget : public AccessedEntity {
|
||||
AccessTarget(const AccessedEntity &Entity)
|
||||
|
|
|
@ -131,7 +131,7 @@ Sema::SetParamDefaultArgument(ParmVarDecl *Param, Expr *Arg,
|
|||
EqualLoc);
|
||||
InitializationSequence InitSeq(*this, Entity, Kind, &Arg, 1);
|
||||
ExprResult Result = InitSeq.Perform(*this, Entity, Kind,
|
||||
MultiExprArg(*this, &Arg, 1));
|
||||
MultiExprArg(*this, &Arg, 1));
|
||||
if (Result.isInvalid())
|
||||
return true;
|
||||
Arg = Result.takeAs<Expr>();
|
||||
|
|
|
@ -3839,8 +3839,8 @@ ExprResult Sema::ActOnMemberAccessExpr(Scope *S, Expr *Base,
|
|||
}
|
||||
|
||||
ExprResult Sema::BuildCXXDefaultArgExpr(SourceLocation CallLoc,
|
||||
FunctionDecl *FD,
|
||||
ParmVarDecl *Param) {
|
||||
FunctionDecl *FD,
|
||||
ParmVarDecl *Param) {
|
||||
if (Param->hasUnparsedDefaultArg()) {
|
||||
Diag(CallLoc,
|
||||
diag::err_use_of_default_argument_to_function_declared_later) <<
|
||||
|
@ -3857,12 +3857,20 @@ ExprResult Sema::BuildCXXDefaultArgExpr(SourceLocation CallLoc,
|
|||
MultiLevelTemplateArgumentList ArgList
|
||||
= getTemplateInstantiationArgs(FD, 0, /*RelativeToPrimary=*/true);
|
||||
|
||||
std::pair<const TemplateArgument *, unsigned> Innermost
|
||||
std::pair<const TemplateArgument *, unsigned> Innermost
|
||||
= ArgList.getInnermost();
|
||||
InstantiatingTemplate Inst(*this, CallLoc, Param, Innermost.first,
|
||||
Innermost.second);
|
||||
|
||||
ExprResult Result = SubstExpr(UninstExpr, ArgList);
|
||||
ExprResult Result;
|
||||
{
|
||||
// C++ [dcl.fct.default]p5:
|
||||
// The names in the [default argument] expression are bound, and
|
||||
// the semantic constraints are checked, at the point where the
|
||||
// default argument expression appears.
|
||||
ContextRAII SavedContext(*this, FD->getDeclContext());
|
||||
Result = SubstExpr(UninstExpr, ArgList);
|
||||
}
|
||||
if (Result.isInvalid())
|
||||
return ExprError();
|
||||
|
||||
|
|
|
@ -2271,7 +2271,7 @@ void Sema::InstantiateStaticDataMemberDefinition(
|
|||
|
||||
VarDecl *OldVar = Var;
|
||||
Var = cast_or_null<VarDecl>(SubstDecl(Def, Var->getDeclContext(),
|
||||
getTemplateInstantiationArgs(Var)));
|
||||
getTemplateInstantiationArgs(Var)));
|
||||
CurContext = PreviousContext;
|
||||
|
||||
if (Var) {
|
||||
|
|
|
@ -79,3 +79,36 @@ namespace test5 {
|
|||
|
||||
struct B { friend void B(); };
|
||||
}
|
||||
|
||||
// PR8479
|
||||
namespace test6_1 {
|
||||
class A {
|
||||
public:
|
||||
private:
|
||||
friend class vectorA;
|
||||
A() {}
|
||||
};
|
||||
class vectorA {
|
||||
public:
|
||||
vectorA(int i, const A& t = A()) {}
|
||||
};
|
||||
void f() {
|
||||
vectorA v(1);
|
||||
}
|
||||
}
|
||||
namespace test6_2 {
|
||||
template<class T>
|
||||
class vector {
|
||||
public:
|
||||
vector(int i, const T& t = T()) {}
|
||||
};
|
||||
class A {
|
||||
public:
|
||||
private:
|
||||
friend class vector<A>;
|
||||
A() {}
|
||||
};
|
||||
void f() {
|
||||
vector<A> v(1);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue