annotate doc/manual/manual_dyncallback_api.tex @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children 1d68b4778979
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
1 %//////////////////////////////////////////////////////////////////////////////
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
2 %
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
3 % Copyright (c) 2007,2013 Daniel Adler <dadler@uni-goettingen.de>,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
4 % Tassilo Philipp <tphilipp@potion-studios.com>
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 %
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 % Permission to use, copy, modify, and distribute this software for any
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
7 % purpose with or without fee is hereby granted, provided that the above
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
8 % copyright notice and this permission notice appear in all copies.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
9 %
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10 % THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11 % WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 % MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 % ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
14 % WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
15 % ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
16 % OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
17 %
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
18 %//////////////////////////////////////////////////////////////////////////////
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
19
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
20 \newpage
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
21 \section{\emph{Dyncallback} C library API}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
22
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
23 This library extends \product{dyncall} with function callback support, allowing
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
24 the user to dynamically create a callback object that can be called directly,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
25 or passed to functions expecting a function-pointer as argument.\\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
26 \\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27 Invoking a \product{dyncallback} calls into a user-defined unified handler that
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 permits iteration and thus dynamic handling over the called-back-function's
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29 parameters.\\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30 \\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31 The flexibility is constrained by the set of supported types, though.\\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 \\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 For style conventions and supported types, see \product{dyncall} API section.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 In order to use \product{dyncallback}, include {\tt "dyncall\_callback.h"}.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 \subsection{Callback Object}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 The \emph{Callback Object} is the core component to this library.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 \paragraph{Types}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 \begin{lstlisting}[language=c]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 typedef struct DCCallback DCCallback;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44 \end{lstlisting}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46 \paragraph{Details}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47 The \emph{Callback Object} is an object that mimics a fully typed function
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48 call to another function (a generic callback handler, in this case).\\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 \\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
50 This means, a pointer to this object is passed to a function accepting a pointer
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51 to a callback function \emph{as the very callback function pointer itself}.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 Or, if called directly, cast a pointer to this object to a function pointer and
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 issue a call.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 \subsection{Allocation}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 \paragraph{Functions}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 \begin{lstlisting}[language=c]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 DCCallback* dcbNewCallback(const char* signature,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62 DCCallbackHandler* funcptr,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 void* userdata);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 void dcbFreeCallback(DCCallback* pcb);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 \end{lstlisting}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 \lstinline{dcbNewCallback} creates and initializes a new \emph{Callback} object,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68 where \lstinline{signature} is the needed function signature (format is the
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 one outlined in the language bindings-section of this manual, see \ref{sigchar})
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70 of the function to mimic, \lstinline{funcptr} is a pointer to a callback handler,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71 and \lstinline{userdata} a pointer to custom data that might be useful in the
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 handler.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 Use \lstinline{dcbFreeCallback} to destroy the \emph{Callback} object.\\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 \\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75 As with \capi{dcNewCallVM}/\capi{dcFree}, this will allocate memory using the
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 system allocators or custom overrides.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79 \subsection{Callback handler}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81 The unified callback handler's declaration used when creating a \capi{DCCallback}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82 is:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
84 \begin{lstlisting}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 char cbHandler(DCCallback* cb,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 DCArgs* args,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87 DCValue* result,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
88 void* userdata);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
89 \end{lstlisting}
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
90
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
91 \capi{cb} is a pointer to the \capi{DCCallback} object in use, \capi{args} allows
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
92 for dynamic iteration over the called-back-function's arguments (input) and
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
93 \capi{result} is a pointer to a \capi{DCValue} object in order to store the
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
94 callback's return value (output, to be set by handler).\\
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
95 Finally, \capi{userdata} is a pointer to some user defined data that can be
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
96 set when creating the callback object.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
97 The handler itself returns a signature character (see \ref{sigchar}) specifying the
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
98 data type used for \capi{result}.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
99