diff options
| author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2009-08-18 20:56:02 +0000 |
|---|---|---|
| committer | Lorry <lorry@roadtrain.codethink.co.uk> | 2012-09-25 16:59:08 +0000 |
| commit | 9f8a09ed743cedd9547bf0661d518647966ab114 (patch) | |
| tree | 9c7803d3b27a8ec22e91792ac7f7932efa128b20 /Examples/test-suite/typedef_inherit.i | |
| download | swig-tarball-master.tar.gz | |
Imported from /srv/lorry/lorry-area/swig-tarball/swig-1.3.40.tar.gz.HEADswig-1.3.40master
Diffstat (limited to 'Examples/test-suite/typedef_inherit.i')
| -rw-r--r-- | Examples/test-suite/typedef_inherit.i | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/Examples/test-suite/typedef_inherit.i b/Examples/test-suite/typedef_inherit.i new file mode 100644 index 0000000..48821a1 --- /dev/null +++ b/Examples/test-suite/typedef_inherit.i @@ -0,0 +1,49 @@ +// Inheritance through a typedef name +%module typedef_inherit + + +%inline %{ +class Foo { +public: + virtual ~Foo () { } + + virtual char *blah() { + return (char *) "Foo::blah"; + } +}; + +typedef Foo FooObj; + +class Bar : public FooObj { + public: + virtual char *blah() { + return (char *) "Bar::blah"; + }; +}; + +char *do_blah(FooObj *f) { + return f->blah(); +} + +typedef struct spam { + virtual ~spam() + { + } + + virtual char *blah() { + return (char *) "Spam::blah"; + } +} Spam; + +struct Grok : public Spam { + virtual ~Grok() { } + virtual char *blah() { + return (char *) "Grok::blah"; + } +}; + +static char * do_blah2(Spam *s) { + return s->blah(); +} +%} + |
