libsigc++: libsigc++ Reference Manual
Description
libsigc++ provides a typesafe (at compile time) callback system for standard C++. It allows you to define signals and to connect those signals to any callback function, either a global or a member function, regardless of whether it is static or virtual. It also contains adaptor classes for connection of dissimilar callbacks.
For instance, see the Signals, Functors, Slots and Adaptors.
See also the libsigc++ tutorial, the libsigc++ website, and the Signals appendix of the Programming with gtkmm book.
Features
- Compile-time typesafe callbacks (also faster than run time checks)
- Type-safety violations report the line number correctly with template names (no tracing template failures into headers)
- No compiler extensions or meta compilers required
- Proper handling of dynamic objects and signals (deleted objects will not cause crashes)
- Extendable API at any level: signal, slot, connection and trackable
- Extensions do not require alteration of basic components
- User-definable accumulators
- A variety of adaptors to change the callback signature: bind, hide, retype, and compose
Basic Usage
Include the libsigc++ header:
(You may include individual headers, such as sigc++/bind
.h instead.)
If your source file is program.cc
, you can compile it with:
Using Autotools
Alternatively, if using autoconf, use the following in configure.ac:
Then use the generated DEPS_CFLAGS
and DEPS_LIBS
variables in the project Makefile.am
files. For example:
Your PKG_CHECK_MODULES()
call should also mention any other libraries that you need to use via pkg-config.
Using CMake
If using CMake, use the following in CMakeList.txt:
Your pkg_check_modules()
call should also mention any other libraries that you need to use via pkg-config.