swig/Examples
William S Fulton dcf69d3e0f Ocaml - add STRING LENGTH multi-argument typemaps 2025-07-28 23:03:15 +01:00
..
android
c Fix extension of filename in comments in examples 2024-09-16 16:51:44 +12:00
csharp Cleanup C# vcxproj files removing warnings 2024-10-19 15:36:08 +01:00
d Tidy up EXTRA_ build flags 2024-03-24 18:12:21 +00:00
go Update examples to recommend compiling with -fPIC instead of -fpic 2024-07-22 17:46:29 -04:00
guile Remove redundant NULL checks before free()/delete (#2184) 2022-01-29 22:03:48 +13:00
java Java compiler lint warnings fixes in test code 2025-04-02 22:52:30 +01:00
javascript [js] Clean up obsolete V8_VERSION machinery 2024-09-18 18:28:59 +12:00
lua Fix extension of filename in comments in examples 2024-09-16 16:51:44 +12:00
ocaml [ocaml] Avoid non-unit-statement warnings in examples 2024-02-24 08:27:48 +13:00
octave Fix extension of filename in comments in examples 2024-09-16 16:51:44 +12:00
perl5 Remove legacy Visual C++ 6 project files 2024-10-19 23:50:32 +01:00
php Fix extension of filename in comments in examples 2024-09-16 16:51:44 +12:00
python Python external_runtime example fixup 2025-04-10 08:13:07 +01:00
r Remove legacy Visual C++ 6 project files 2024-10-19 23:50:32 +01:00
ruby Remove legacy Visual C++ 6 project files 2024-10-19 23:50:32 +01:00
scilab Add support for Scilab 2025.x.0 2025-06-07 07:23:07 +12:00
tcl Update Tcl examples to Visual Studio 2019 project files 2024-10-19 23:43:25 +01:00
test-suite Ocaml - add STRING LENGTH multi-argument typemaps 2025-07-28 23:03:15 +01:00
Makefile.in Add -nogil opt-in flag to remove need for PYTHON_GIL=0 2025-07-18 22:41:36 +01:00
README
index.html [MzScheme/Racket] Drop support 2025-04-01 14:05:28 +13:00

README

SWIG Examples

The subdirectories of "Examples" named after SWIG's language backends
contain a number of simple examples that are primarily used for testing.

The file 'index.html' is the top of a hyperlinked document that
contains information about all of the examples along with various
notes related to each example.

Note: All of the examples rely upon the Makefile in this directory.
You may need to edit it to reflect the configuration of your machine
in case the configure script guesses incorrect settings.


*** Special note concerning C++ ***

The configure script is currently unable to handle all of the possible
options for producing dynamically loadable C++ extensions.  Here are
the rules of thumb for making C++ work:

 -  Try using the C++ as the linker for the shared library.  For example:

         g++ -shared $(OBJS) -o module.so

 -  If that doesn't work, you may need to explicitly link against some
    kind of C++ runtime library.  For example:

         ld -G $(OBJS) -L/opt/SUNWspro/lib -lCrun -o module.so

    This can be set by modifying the setting of CPP_DLLIBS in the
    Makefile.


*** Special note for SWIG Maintainers ***

When you add an example, consider arranging for the example to be also
useful as part of the SWIG testing framework.  To do this, include in
the example makefile a target "check" ("check: all" is sufficient for a
first pass), and add an invocation to ../Makefile.in under target
"check-examples" (or whatever is appropriate).  Later, we can add or
expand the actions under target "check" to do more in-depth testing.