esignal/doc/tutorial.md

4.0 KiB

Tutorial

@tableofcontents

Declare a Signal:

Declaring a signal is really simple, just include the esignal file:

@snippet sampleAll.cpp esignal_sample_declare

You can now declare your signals. We have basicly declare some basic signal type:

  • void
  • bool
  • std::string / std::u32string
  • int8_t / int16_t / int32_t / int64_t
  • uint8_t / uint16_t / uint32_t / uint64_t
  • float / double
  • vec2 / bvec2 / ivec2 / uivec2
  • vec3 / bvec3 / ivec3 / uivec3
  • etk::Color<unsigned char,4>
  • etk::Color<unsigned char,3>
  • etk::Color<float,4>
  • etk::Color<float,3>

To declare a signal with 'void' type: @snippet sampleAll.cpp esignal_sample_declare_void

To declare a signal with 'int32_t' type: @snippet sampleAll.cpp esignal_sample_declare_int

To declare a signal with 'string' type: @snippet sampleAll.cpp esignal_sample_declare_string

Connecting on a signal

We have some way to connect on a signals depending on where we do the connection.

Connection and basic emition

Declare the signal: @snippet sampleAll.cpp esignal_sample_connection_simple_connection_declare

Declare a generic fuction: @snippet sampleAll.cpp esignal_sample_connection_simple_extern_function

Connect a generic function: @snippet sampleAll.cpp esignal_sample_connection_simple_connection_function

Or simply connect a lambda function: @snippet sampleAll.cpp esignal_sample_connection_simple_connection_lambda

And now, we can emit a simple signal: @snippet sampleAll.cpp esignal_sample_connection_simple_emit

You can see that all connection return a esignal::Connection value. This is an handle that can not be copiable, but only movable, While this handle is alive, the connection is allive too. The to remove a connection, we only need to remive the handle or call the esignal::Connection::disconnect fucntion.

To disconnect a signal, it is very simple: @snippet sampleAll.cpp esignal_sample_connection_simple_disconnect

This Will generate this simple sample code: @snippet sampleAll.cpp esignal_sample_connection_simple

Connection on class member function

Declare class fuction: @snippet sampleAll.cpp esignal_sample_class_connection_callback

For direct connection, you need to have a 'const ref' on the parameter (internal helper design) to bind on the signal

Now you can nonnect the functions: @snippet sampleAll.cpp esignal_sample_class_connection_callback_connect

This Will generate this simple sample code: @snippet sampleAll.cpp esignal_sample_class_connection

Connection on std::shared_ptr member function

std::hared_ptr have intrinsec knoledge of alive pointer, then, if you do not need to remove connection while the shared_ptr is alive, just connect it like: @snippet sampleAll.cpp esignal_sample_shared_connection

Create new Signal

If the signal is not in the list: @ref esignal_declare, you need to declare it yourself. This is due to optimise the compilation time, in C++ when we inserte many template with all the implementation, the compilation time increase, the we decide to optimise the build time.

Create a new custum signal: @snippet sampleAll.cpp esignal_sample_new_declare

Connect on the Signal: @snippet sampleAll.cpp esignal_sample_new_lambda

Emit a Signal: @snippet sampleAll.cpp esignal_sample_new_emit

This might work good, but at this point the compilation is OK, but not the linking ==> we need to declare the implementation of the signal: @snippet sampleAll.cpp esignal_sample_new_register

This Will generate this simple sample code: @snippet sampleAll.cpp esignal_sample_new