diff options
| author | Carlo Zancanaro <carlo@pc-4w14-0.cs.usyd.edu.au> | 2012-10-15 17:10:06 +1100 | 
|---|---|---|
| committer | Carlo Zancanaro <carlo@pc-4w14-0.cs.usyd.edu.au> | 2012-10-15 17:10:06 +1100 | 
| commit | be1de4be954c80875ad4108e0a33e8e131b2f2c0 (patch) | |
| tree | 1fbbecf276bf7c7bdcbb4dd446099d6d90eaa516 /clang/test/SemaCXX/vtable-instantiation.cc | |
| parent | c4626a62754862d20b41e8a46a3574264ea80e6d (diff) | |
| parent | f1bd2e48c5324d3f7cda4090c87f8a5b6f463ce2 (diff) | |
Merge branch 'master' of ssh://bitbucket.org/czan/honours
Diffstat (limited to 'clang/test/SemaCXX/vtable-instantiation.cc')
| -rw-r--r-- | clang/test/SemaCXX/vtable-instantiation.cc | 68 | 
1 files changed, 68 insertions, 0 deletions
| diff --git a/clang/test/SemaCXX/vtable-instantiation.cc b/clang/test/SemaCXX/vtable-instantiation.cc new file mode 100644 index 0000000..2a1b989 --- /dev/null +++ b/clang/test/SemaCXX/vtable-instantiation.cc @@ -0,0 +1,68 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s + +namespace PR8640 { +  template<class T1> struct C1 { +    virtual void c1() { +      T1 t1 = 3;  // expected-error {{cannot initialize a variable}} +    } +  }; + +  template<class T2> struct C2 { +    void c2() { +      new C1<T2>();  // expected-note {{in instantiation of member function}} +    } +  }; + +  void f() { +    C2<int*> c2; +    c2.c2();  // expected-note {{in instantiation of member function}} +  } +} + +namespace PR9325 { +  template<typename T> +  class Target +  { +  public: +    virtual T Value() const +    { +      return 1; // expected-error{{cannot initialize return object of type 'int *' with an rvalue of type 'int'}} +    } +  }; + +  template<typename T> +  struct Provider +  { +    static Target<T> Instance; +  }; + +  template<typename T> +  Target<T> Provider<T>::Instance; // expected-note{{in instantiation of}} + +  void f() +  { +    Target<int*>* traits = &Provider<int*>::Instance; +  } +} + +namespace PR10020 { +  struct MG { +    virtual void Accept(int) = 0; +  }; + +  template <typename Type> +  struct GMG : MG { +    void Accept(int i) { +      static_cast<Type *>(0)->Accept(i); // expected-error{{member reference base}} +    } +    static GMG* Method() { return &singleton; } // expected-note{{in instantiation of}} +    static GMG singleton; +  }; + +  template <typename Type> +  GMG<Type> GMG<Type>::singleton; + +  void test(void) { +    GMG<int>::Method(); // expected-note{{in instantiation of}} +  } +} | 
