Next: Vague details of the GNU APL implementation, Up: (dir)
The following main facilities are provided:
apl_execpass a C string to the interpreter for immediate execution as APL code.
apl_commandpass an APL command to the command processor and return its output.
APL_valuea pointer to an opaque structure Value, supported by over 30 functions allowing one to construct a new Value and to gain access to its rank, shape and ravel. In this document, the terms "Value" and "APL value" are not interchangeable; they refer respectively to a structure and to a pointer.
get_var_valuereturn an APL value pointing to the contents of a variable in the current workspace.
set_var_valueset the contents of a variable in the workspace to that of the given APL value.
No other GNU APL header is exposed.
This document will not tell you much about APL. For more details about the language, consult an APL reference manual such as those recommended in the file README-7-more-info, which are probably installed in /usr/share/doc/apl or /usr/local/share/doc/apl.
| • Vague details of the GNU APL implementation: | ||
| • Summary of functions: | ||
| • Programming notes: | 
Next: Summary of functions, Previous: Top, Up: Top
Although the implementation is hidden from the API, the programmer needs to know a little about it.
Only one workspace, simply known as "the workspace", is active at any time. The workspace may be cleared, named, saved and restored by calls to apl_command.
The workspace contains a collection of symbols of various kinds. Apart from apl_exec and apl_command, which behave as if entered from the keyboard in an interactive APL session, this API gives access only to APL variables, i.e. symbols associated with Values.
A Value is a multidimensional array of cells. It has three visible components: rank, shape and ravel.
The shape is a vector of integers, giving the number of elements along each axis of the array. The number of shape items is known as the rank. There is an upper bound to the rank, configurable when GNU APL is built, which is displayed as a message by apl_exec("⎕SYL[7;]").
The ravel is a vector of cells, accessed in APL by a multi-index but in the API by a single index starting at 0. As one progresses along the ravel, the multi-index is ordered lexicographically, e.g. in a clear workspace, the multi-index of an array of shape 2 3 would successively be 1 1, 1 2, 1 3, 2 1, 2 2, 2 3. The index origin in APL may be changed by apl_exec("⎕IO←0"), but in the API the ravel is always indexed from 0.
The number of elements in the ravel is given by the product of the shape items. An empty product is of course equal to 1, thus this calculation is also valid for a scalar, which has rank 0.
A cell can hold any of several kinds of objects:
double, or a complex<double>.
The API does not give direct access to cell objects. The user must know what is in a particular cell and retrieve it by supplying its position in the ravel, using a specialized access method for cells of that particular type. To this end, the cell type can be queried. This is an integer treated as a bit string. The bits denoting cells accessible from the API have predefined names.
CCT_CHAR = 0x02 CCT_POINTER = 0x04 CCT_INT = 0x10 CCT_FLOAT = 0x20 CCT_COMPLEX = 0x40 CCT_NUMERIC = CCT_INT | CCT_FLOAT | CCT_COMPLEX
Attempting to retrieve the contents of a cell by the wrong access method is an error that will crash the program.
| • Lifespan of Values: | 
release_value when the Value is no longer needed. Failure to do so will cause memory leaks.
res_callback (see Interface to APL interpreter) has a particularly brief lifespan. The execution of that function is your only chance of accessing it. Its reference count is not increased before the call, so you must not release it.
set_ functions change one element only. Other references to the Value concerned will also reflect the change; for example, if the APL value was returned by get_var_value, a following call to get_var_value with the same variable name will show the change.
set_value and set_var_value make a new deep copy of a non-scalar Value. The reference count of the original Value is not increased. Cloning (which is deliberately discouraged in the API by not providing a copy constructor) can be simulated with the aid of either of these. The details are left to the persevering user.
Next: Programming notes, Previous: Vague details of the GNU APL implementation, Up: Top
This section is an aide-memoire, not a manual: consult the comments preceding each function for details. See Programming notes for information on the loc parameter.
The other parameter values have the following types:
| val | The main APL value | 
| pval | A secondary APL value | 
| cval | A 32-bit Unicode character | 
| ival | A 64-bit integer | 
| xval,yval | A 64-bit double | 
| sval | A UTF-8 encoded char* | 
| i | A 64-bit index | 
| k,n1,n2,n2 | A 32-bit index | 
| • Constructor functions: | ||
| • Read access to Values: | ||
| • Write access to cells: | ||
| • Interface to APL interpreter: | ||
| • Destructor function: | ||
| • Print support: | 
Next: Read access to Values, Up: Summary of functions
Each of these functions returns an APL value and has a name descriptive of its argument list.
int_scalar(ival,loc), double_scalar(xval,loc), complex_scalar(xval,yval,loc) and char_scalar(cval,loc) initialize to a given C value.
char_vector(sval,loc) initializes from a UTF-8 encoded C string to an array of rank 1 containing Unicode characters.
apl_scalar(loc), apl_vector(n1), apl_matrix(n1,n2) and apl_cube(n1,n2,n3) initialize to arrays of rank 0,1,2,3; apl_value(shape,loc) initializes to an array of arbitrary shape. All cells in these arrays are initialized to 0.
Next: Write access to cells, Previous: Constructor functions, Up: Summary of functions
get_rank(val), get_axis(val,k) and get_element_count(val) give information about the shape,
get_type(val,i) returns the cell type of a ravel element. The predefined names can be used in e.g. a switch statement on the cell type.
is_char(val,i), is_int(val,i), is_double(val,i), is_complex(val,i) and is_value(val,i) are conveniently named front-ends to get_type that do not require the user to examine the cell type.
is_string(val) tests whether the entire value is a simple character vector. If so, print_value_to_string can be used to convert it to a UTF-8 encoded C string.
get_char(val,i), get_int(val,i), get_real(val,i), get_imag(val,i) and get_value(val,i) retrieve the actual contents of a cell of which the type is already known, if necessary by having called get_type or one of its front-ends. For example get_real can be used if get_type(val,i) & (CCT_FLOAT | CCT_COMPLEX) is nonzero.
Next: Interface to APL interpreter, Previous: Read access to Values, Up: Summary of functions
Cells can be accessed only via an APL value pointing to their containing Value.
set_char(cval,val,i), set_int(ival,val,i), set_real(xval,val,i), set_imag(yval,val,i) and set_value(pval,val,i) replace the contents of cell i of val.
It is not possible to change the shape of an APL value.
Next: Destructor function, Previous: Write access to cells, Up: Summary of functions
set_var_value(name,val,loc) and get_var_value(name,val,loc) save and retrieve values to the workspace under specified names.
An external function pointer res_callback is called just before apl_exec exits. To exploit it, assign a suitable user-written function to it, e.g.
/* callback to print every value */
static int always_print(const APL_value apl,int committed) {
  return 1;
}
/* callback to save a copy in the workspace under the name "_" */
static int save_to_workspace(const APL_value apl,int committed) {
  set_var_value("_",apl,LOC);
  return !committed;
}
/* One-off declaration statement, must not be inside a function */
result_callback res_callback = always_print_it;
...
/* A later assignment statement may be anywhere */
res_callback = save_to_workspace;  
...
res_callback = NULL;      /* disables callback feature */
Here apl is the anonymous value to which the APL expression evaluates. You are granted access to it just before its brief lifespan expires. committed is a C boolean (only 0 is false) reporting whether that value was stored to a variable. Your return value is a C boolean telling whether the value should be printed by the APL interpreter.
The value *apl (which the API cannot see) will be scheduled for destruction as soon as you exit res_callback. Don’t release it yourself.
Next: Print support, Previous: Interface to APL interpreter, Up: Summary of functions
release_value(val,loc) decrements the reference count of *val as explained in Lifespan of Values/
Previous: Destructor function, Up: Summary of functions
print_value(value,file), print_value_to_string(value) filter an APL value through the APL formatting routines. Their behaviour depends on several system variables, such as ⎕FC, ⎕PP, ⎕PW.
UTF8_to_Unicode, Unicode_to_UTF8 are provided because get_char and set_char work with 32-bit Unicode, whereas many other user interfaces use UTF-8.
Previous: Summary of functions, Up: Top
The typical application would start with:
#include <stdio.h> #include <stdint.h> #include <apl/libapl.h>
This interface can be called from C, but since GNU APL is a C++ package. the C++ library must be explicitly loaded, e.g. in Linux:
cc myprog.c -lapl -lstdc++ -o myprog
| • The loc parameter and LOC macro: | 
loc parameter and LOC macroAll the functions that return APL values, as well as release_value and set_var_value, contain a parameter const char* loc. This parameter is used to keep track of changes to a Value and may be displayed by certain debugging services. You can put in anything you like, but most convenient is LOC, a macro that expands to the file name and line number.