Python function annotations containing C/C++ types are no longer
generated when using the -py3 option. Function annotations support
has been moved to a feature to provide finer grained control.
It can be turned on globally by adding:
%feature("python:annotations", "c");
or by using the command line argument:
-features python:annotations=c
The implementation is designed to be expandable to support different
annotations implementations. Future implementations could implement
something like the following for generating pure Python types:
%feature("python:annotations", "python");
or typing module types to conform to PEP-484:
%feature("python:annotations", "typing");
Closes #1561
Issue #735
26 lines
877 B
OpenEdge ABL
26 lines
877 B
OpenEdge ABL
%module python_annotations_c
|
|
|
|
// Tests the C/C++ annotations that were automatically added by using -py3 before swig-4.1.0
|
|
// In swig-4.1.0 and later, the feature below is needed as annotations are no longer generated with -py3
|
|
%feature("python:annotations", "c") mymethod;
|
|
%feature("python:annotations", "c") makeT<short>;
|
|
%feature("python:annotations", "c") global_ints;
|
|
|
|
%inline %{
|
|
namespace Space {
|
|
template<class T>
|
|
struct Template {
|
|
void mymethod(int, Template* tt) {}
|
|
};
|
|
}
|
|
template<typename T>
|
|
Space::Template<T> makeT(int x) {
|
|
return Space::Template<T>();
|
|
};
|
|
int *global_ints(int &ri, Space::Template<short> t) { return &ri; }
|
|
int *global_overloaded(int &ri) { return &ri; }
|
|
int *global_overloaded() { return NULL; }
|
|
int *no_annotations(int &ri, const char *c) { return NULL; }
|
|
%}
|
|
%template(TemplateShort) Space::Template<short>;
|
|
%template(MakeShort) makeT<short>;
|