wapi stands for “WING API”
wapi is a C language API for Behringer’s WING Digital Mixing Consoles (Standard, Compact and Rack). Its current version ia: 3.0.6-5
This section contains a repository of wapi. The API and its contents (libraries, include files) are being made available for Windows, MacOS and Linux platforms at no charge, enabling anyone with programming knowledge to create applications for the WING consoles. wapi is provided under the wapi software licence agreement.
The API uses UDP and TCP networking to establish a connection to the WING console. Typical communication take place over TCP/IP on port 2222.
The API enable managing (Get, Set, etc.) all 35k+ parameters of the WING consoles. Parameters can be nodes, int, float or string; Get functions can be attended, timed, or unattended (such as in event programming/loops). Set functions are… set 🙂
Using wapi
At the API level, WING data can be 32 bits int or float or string data. All API data in little-endian, enabling easy use in standard programming languages.
Besides this document, wapi consists of two include files, a library and several example source files. wapi.h is the main include file containing enumerated types for errors, token types, and wapi abstraction enumerated tokens. wext.h is a file containing the definitions of external library calls to libwapi.a the actual library of API functions. libwapi.a is s static-link library for linking with your application. The library contains all wapi functions currently available.
A typical program accessing WING starts with an ‘open’ function and ends with a ‘close’ function. These two functions establish the communication path to WING on your local network and ensure data is properly cleaned when leaving the program.
Programs communicate with WING over network. The API call wOpen() is used to establish communication link between WING and the application.
WING supports multiple formats, including integers, floats, and strings types. The API will ensure conversions as best as possible in order to match the requested format either by WING or by the API command. For example, if you request float data from a WING token which is an integer, the API will convert the integer to float before returning the data. Similarly, if you set a WING token of type string by sending it a float value, the float data will be changed to string before being sent to WING.
All WING tokens are identified by their name, based on the JSON structure that represents WING’s hierarchical data tree we already presented in the wapi document. For example the identifier for channel 1 parametric equalizer, setting frequency 2 control, a.k.a “ch.1.peq.2f” in the JSON tree is known as token CH_1_PEQ_2F. The respective data in WING is a float and as written above, it can be modified from an integer, a float or even a string value, and can be returned to the application as an integer, a float of even a string.
Some tokens are read-only; trying to change their value will result in an error returned to the application.
WING tokens are listed in an include file: wapi.h that must be included in your program. The include file also contains the status or error codes that can be returned by the API function calls. The wext.h include file contains function calls definitions to be used.
wapi library
All function calls are regrouped in a binary library: libwapi.a, that you must include at link time. A typical compilation of a source file wtest.c in a Windows environment can be as follows:
gcc -O3 -Wall -c -o wtest.o "wtest.c"
gcc -o wtest.exe wtest.o -lwapi -lws2_32
Don’t forget to add the correct paths to wapi.h, wext.h and libwapi.a files in the above compilation/link lines!
WING parameters can be set (or modified) using the wSetxxx API family of calls; Similarly, the parameters can be retrieved from WING using the wGetxxx API family of calls.
Documentation and pre-compiled applications
Full documentation on wapi is available as a pdf file an covers more than just wapi. OSC, MIDI, and several user-guide like chapters cover many aspects of the consoles, their programming and use. This site proposes several applications developed using wapi, or applications using OSC.
x32ram commercial applications (OSC or wapi based) are available here, under the Products tab.
Licence Agreement
By using wapi in your programs, you agree to comply and apply the wapi SLA.
Downloads
By clicking on the links below, you will be downloading a single zip file containing the library and include files needed for building wapi based applications.
Windows, MacOS, Linux
The link below will download several C source code files of wapi-based applications, giving a panel of examples of what can be done using wapi as well as providing a first step to programming with wapi for WING consoles.
Program examples
                            
                         
												                    
wapi stands for “WING API”
wapi is a C language API for Behringer’s WING Digital Mixing Consoles (Standard, Compact and Rack). Its current version ia: 3.0.6-5
This section contains a repository of wapi. The API and its contents (libraries, include files) are being made available for Windows, MacOS and Linux platforms at no charge, enabling anyone with programming knowledge to create applications for the WING consoles. wapi is provided under the wapi software licence agreement.
The API uses UDP and TCP networking to establish a connection to the WING console. Typical communication take place over TCP/IP on port 2222.
The API enable managing (Get, Set, etc.) all 35k+ parameters of the WING consoles. Parameters can be nodes, int, float or string; Get functions can be attended, timed, or unattended (such as in event programming/loops). Set functions are… set 🙂
Using wapi
At the API level, WING data can be 32 bits int or float or string data. All API data in little-endian, enabling easy use in standard programming languages.
Besides this document, wapi consists of two include files, a library and several example source files.
wapi.his the main include file containing enumerated types for errors, token types, and wapi abstraction enumerated tokens.wext.his a file containing the definitions of external library calls tolibwapi.athe actual library of API functions.libwapi.ais s static-link library for linking with your application. The library contains all wapi functions currently available.A typical program accessing WING starts with an ‘
open’ function and ends with a ‘close’ function. These two functions establish the communication path to WING on your local network and ensure data is properly cleaned when leaving the program.Programs communicate with WING over network. The API call
wOpen()is used to establish communication link between WING and the application.WING supports multiple formats, including integers, floats, and strings types. The API will ensure conversions as best as possible in order to match the requested format either by WING or by the API command. For example, if you request float data from a WING token which is an integer, the API will convert the integer to float before returning the data. Similarly, if you set a WING token of type string by sending it a float value, the float data will be changed to string before being sent to WING.
All WING tokens are identified by their name, based on the JSON structure that represents WING’s hierarchical data tree we already presented in the wapi document. For example the identifier for channel 1 parametric equalizer, setting frequency 2 control, a.k.a “
ch.1.peq.2f” in the JSON tree is known as tokenCH_1_PEQ_2F. The respective data in WING is a float and as written above, it can be modified from an integer, a float or even a string value, and can be returned to the application as an integer, a float of even a string.Some tokens are read-only; trying to change their value will result in an error returned to the application.
WING tokens are listed in an include file:
wapi.hthat must be included in your program. The include file also contains the status or error codes that can be returned by the API function calls. Thewext.hinclude file contains function calls definitions to be used.wapi library
All function calls are regrouped in a binary library:
libwapi.a, that you must include at link time. A typical compilation of a source file wtest.c in a Windows environment can be as follows:gcc -O3 -Wall -c -o wtest.o "wtest.c"gcc -o wtest.exe wtest.o -lwapi -lws2_32
Don’t forget to add the correct paths to
wapi.h,wext.handlibwapi.afiles in the above compilation/link lines!WING parameters can be set (or modified) using the
wSetxxxAPI family of calls; Similarly, the parameters can be retrieved from WING using thewGetxxxAPI family of calls.Documentation and pre-compiled applications
Full documentation on wapi is available as a pdf file an covers more than just wapi. OSC, MIDI, and several user-guide like chapters cover many aspects of the consoles, their programming and use. This site proposes several applications developed using wapi, or applications using OSC.
x32ram commercial applications (OSC or wapi based) are available here, under the Products tab.
Licence Agreement
By using wapi in your programs, you agree to comply and apply the wapi SLA.
Downloads
By clicking on the links below, you will be downloading a single zip file containing the library and include files needed for building wapi based applications.
Windows, MacOS, Linux
The link below will download several C source code files of wapi-based applications, giving a panel of examples of what can be done using wapi as well as providing a first step to programming with wapi for WING consoles.
Program examples