Mercurial > emacs
view test/cedet/tests/testpolymorph.cpp @ 104508:90ca5d588aa9
* cedet/semantic.el: Add autoloads for semantic/idle functions.
* cedet/semantic/util.el (semantic--completion-cache): New var.
(semantic-symbol-start, semantic-find-tag-for-completion)
(semantic-complete-symbol): New functions, adapted from Senator.
* bindings.el (complete-symbol): Try semantic-complete-symbol if
no tag table is active.
* cedet/semantic/idle.el (define-semantic-idle-service): Doc fix.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Mon, 21 Sep 2009 15:59:48 +0000 |
parents | e480034314ce |
children |
line wrap: on
line source
/** testpolymorph.cpp --- A sequence of polymorphism examples. * * Copyright (C) 2009 Eric M. Ludlam * * Author: Eric M. Ludlam <eric@siege-engine.com> * X-RCS: $Id: testpolymorph.cpp,v 1.2 2009/09/02 13:55:46 davenar Exp $ * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2, or (at * your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; see the file COPYING. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #include <cmath> // Test 1 - Functions w/ prototypes namespace proto { int pt_func1(int arg1); int pt_func1(int arg1) { return 0; } } // Test 2 - Functions w/ different arg lists. namespace fcn_poly { int pm_func(void) { return 0; } int pm_func(int a) { return a; } int pm_func(char a) { return int(a); } int pm_func(double a) { return int(floor(a)); } } // Test 3 - Methods w/ differet arg lists. class meth_poly { public: int pm_meth(void) { return 0; } int pm_meth(int a) { return a; } int pm_meth(char a) { return int(a); } int pm_meth(double a) { return int(floor(a)); } }; // Test 4 - Templates w/ partial specifiers. namespace template_partial_spec { template <typename T> class test { public: void doSomething(T t) { }; }; template <typename T> class test<T *> { public: void doSomething(T* t) { }; }; } // Test 5 - Templates w/ full specicialization which may or may not share // common functions. namespace template_full_spec { template <typename T> class test { public: void doSomething(T t) { }; void doSomethingElse(T t) { }; }; template <> class test<int> { public: void doSomethingElse(int t) { }; void doSomethingCompletelyDifferent(int t) { }; }; } // Test 6 - Dto., but for templates with multiple parameters. namespace template_multiple_spec { template <typename T1, typename T2> class test { public: void doSomething(T1 t) { }; void doSomethingElse(T2 t) { }; }; template <typename T2> class test<int, T2> { public: void doSomething(int t) { }; void doSomethingElse(T2 t) { }; }; template <> class test<float, int> { public: void doSomething(float t) { }; void doSomethingElse(int t) { }; void doNothing(void) { }; }; } // End of polymorphism test file.