aboutsummaryrefslogtreecommitdiffstats
path: root/bindings/tutorial/tuto-1.c
blob: 433a4ebb04802a7b033b193e4cfd5bb7b0107cb6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#define AFB_BINDING_VERSION 2
#include <afb/afb-binding.h>

void hello(afb_req req)
{
	AFB_REQ_DEBUG(req, "hello world");
	afb_req_success(req, NULL, "hello world");
}

const afb_verb_v2 verbs[] = {
	{ .verb="hello", .callback=hello },
	{ .verb=NULL }
};

const afb_binding_v2 afbBindingV2 = {
	.api = "tuto-1",
	.verbs = verbs
};
voked with a new target name. So, typical usage defining a target is: ```cmake PROJECT_TARGET_ADD(SuperExampleName) --> Adding target to your project add_executable/add_library(${TARGET_NAME}.... --> defining your target sources SET_TARGET_PROPERTIES(${TARGET_NAME} PROPERTIES.... --> fit target properties for macros usage INSTALL(TARGETS ${TARGET_NAME}.... ``` ## Targets PROPERTIES You should set properties on your targets that will be used to package your apps in a widget file that could be installed on an AGL system. Specify what is the type of your targets that you want to be included in the widget package with the property **LABELS**: Choose between: - **BINDING**: Shared library that be loaded by the AGL Application Framework - **BINDINGV2**: Shared library that be loaded by the AGL Application Framework. This has to be accompagnied with a JSON file named like the *${OUTPUT_NAME}-apidef* of the target that describe the API with OpenAPI syntax (e.g: *mybinding-apidef*). Or you can choose the name by setting the *CACHE* cmake variable *OPENAPI_DEF* (***CAUTION***: setting a CACHE variable is needed, or set a normal variable with the *PARENT_SCOPE* option to make it visible for the parent scope where the target is defined) JSON file will be used to generate header file using `afb-genskel` tool. - **HTDOCS**: Root directory of a web app. This target has to build its directory and puts its files in the ${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME} - **DATA**: Resources used by your application. This target has to build its directory and puts its files in the ${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME} - **EXECUTABLE**: Entry point of your application executed by the AGL Application Framework > **TIP** you should use the prefix _afb-_ with your **BINDING* targets which > stand for **Application Framework Binding**. ```cmake SET_TARGET_PROPERTIES(${TARGET_NAME} PREFIX "afb-" LABELS "BINDING" OUTPUT_NAME "file_output_name") ``` > **NOTE**: You doesn't need to specify an **INSTALL** command for these > targets. This is already handle by template and will be installed in the > following path : **${CMAKE_INSTALL_PREFIX}/${PROJECT_NAME}**