1
0
Fork 0
mirror of git://git.psyc.eu/libpsyc synced 2024-08-15 03:19:02 +00:00

methods & templates

This commit is contained in:
Gabor Adam Toth 2011-11-30 13:51:50 +01:00
parent 1aa08235b7
commit 5dd68d87fc
11 changed files with 197 additions and 92 deletions

View file

@ -94,14 +94,6 @@ typedef enum {
PSYC_LIST_BINARY = 2,
} PsycListType;
typedef enum PsycMessageFlag {
PSYC_MESSAGE_TEMPLATE = 1 << 0,
PSYC_MESSAGE_REPLY = 1 << 1,
PSYC_MESSAGE_VISIBLE = 1 << 2,
PSYC_MESSAGE_LOGGABLE = 1 << 3,
PSYC_MESSAGE_MANUAL = 1 << 4,
} PsycMessageFlag;
/**
* String struct.
*

65
include/psyc/method.h Normal file
View file

@ -0,0 +1,65 @@
#ifndef PSYC_METHOD_H
#define PSYC_METHOD_H
typedef enum PsycMethodFlag {
PSYC_METHOD_TEMPLATE = 1 << 0,
PSYC_METHOD_REPLY = 1 << 1,
PSYC_METHOD_VISIBLE = 1 << 2,
PSYC_METHOD_LOGGABLE = 1 << 3,
PSYC_METHOD_MANUAL = 1 << 4,
} PsycMethodFlag;
typedef enum PsycMethod {
PSYC_MC_UNKNOWN,
PSYC_MC_DATA,
PSYC_MC_ECHO,
PSYC_MC_ECHO_CONTEXT_ENTER,
PSYC_MC_ECHO_CONTEXT_LEAVE,
PSYC_MC_ERROR,
PSYC_MC_FAILURE,
PSYC_MC_INFO,
PSYC_MC_MESSAGE,
PSYC_MC_MESSAGE_ACTION,
PSYC_MC_MESSAGE_ECHO,
PSYC_MC_MESSAGE_ECHO_ACTION,
PSYC_MC_NOTICE,
PSYC_MC_NOTICE_CONTEXT_ENTER,
PSYC_MC_NOTICE_CONTEXT_LEAVE,
PSYC_MC_REQUEST,
PSYC_MC_REQUEST_CONTEXT_ENTER,
PSYC_MC_REQUEST_CONTEXT_LEAVE,
PSYC_MC_STATUS,
PSYC_MC_STATUS_CONTEXTS_ENTERED,
PSYC_MC_WARNING,
PSYC_METHODS_NUM,
} PsycMethod;
typedef union PsycTemplates {
PsycString a[PSYC_METHODS_NUM];
struct {
PsycString _;
PsycString _data;
PsycString _echo;
PsycString _echo_context_enter;
PsycString _echo_context_leave;
PsycString _error;
PsycString _failure;
PsycString _info;
PsycString _message;
PsycString _message_action;
PsycString _message_echo_action;
PsycString _notice;
PsycString _notice_context_enter;
PsycString _notice_context_leave;
PsycString _request;
PsycString _request_context_enter;
PsycString _request_context_leave;
PsycString _status;
PsycString _status_contexts_entered;
PsycString _warning;
} s;
} PsycTemplates;
#endif

View file

@ -16,10 +16,11 @@
* @{
*/
#include <psyc.h>
#include <psyc/syntax.h>
#include <math.h>
#include "syntax.h"
#include "method.h"
/** Modifier flags. */
typedef enum {
/// Modifier needs to be checked if it needs length.
@ -67,21 +68,6 @@ typedef enum {
PSYC_STATE_RESYNC = '?',
} PsycStateOp;
typedef enum PsycMethod {
PSYC_METHOD_UNKNOWN,
PSYC_METHOD_DATA,
PSYC_METHOD_ECHO,
PSYC_METHOD_ERROR,
PSYC_METHOD_FAILURE,
PSYC_METHOD_INFO,
PSYC_METHOD_MESSAGE,
PSYC_METHOD_MESSAGE_ECHO,
PSYC_METHOD_NOTICE,
PSYC_METHOD_REQUEST,
PSYC_METHOD_STATUS,
PSYC_METHOD_WARNING,
} PsycMethod;
/** Structure for a modifier. */
typedef struct {
char oper;

View file

@ -114,7 +114,8 @@
#include <stdint.h>
#include <string.h>
#include <psyc.h>
#include "../psyc.h"
typedef enum {
/// Default Flag. Parse everything.

View file

@ -1,7 +1,7 @@
#ifndef PSYC_RENDER_H
#define PSYC_RENDER_H
#include <psyc/packet.h>
#include "packet.h"
/**
* @file psyc/render.h

View file

@ -158,6 +158,16 @@ psyc_text_bytes_written (PsycTextState *state)
PsycTextRC
psyc_text (PsycTextState *state, PsycTextCB getValue, void *extra);
extern const PsycTemplates psyc_templates;
static inline const char *
psyc_template (PsycMethod mc, size_t *len) {
PsycString t = psyc_templates.a[mc];
if (len)
*len = t.length;
return t.data;
}
/** @} */ // end of text group
#endif

View file

@ -13,8 +13,12 @@ extern const PsycString psyc_routing_vars[];
// Variable types in alphabetical order.
extern const PsycDictInt psyc_var_types[];
/// Method names in alphabetical order.
extern const PsycDictInt psyc_methods[];
extern const size_t psyc_routing_vars_num;
extern const size_t psyc_var_types_num;
extern const size_t psyc_methods_num;
/**
* Is this a routing variable name?
@ -39,6 +43,6 @@ psyc_var_is_list (const char *name, size_t len)
}
PsycMethod
psyc_method_family (char *method, size_t methodlen, unsigned int *flag);
psyc_method (char *method, size_t methodlen, PsycMethod *family, unsigned int *flag);
#endif

12
src/templates.h Normal file
View file

@ -0,0 +1,12 @@
#define _ PSYC_C2STRI
._echo_context_enter =
_("You enter [_nick_place]" ),
._echo_context_leave =
_("You leave [_nick_place]"),
._notice_context_enter =
_("[_nick] enters [_nick_place]"),
._notice_context_leave =
_("[_nick] leaves [_nick_place]"),
._request_context_enter =
_("[_nick] asks for your permission to enter [_nick_place]"),

View file

@ -1,8 +1,12 @@
#include "lib.h"
#include <psyc/text.h>
const PsycTemplates psyc_templates = { .s = {
#include "templates.h"
}};
PsycTextRC
psyc_text (PsycTextState *state, PsycTextCB getValue, void *extra)
psyc_text (PsycTextState *state, PsycTextCB get_value, void *extra)
{
const char *start = state->tmpl.data, *end; // start & end of variable name
const char *prev = state->tmpl.data + state->cursor;
@ -34,7 +38,7 @@ psyc_text (PsycTextState *state, PsycTextCB getValue, void *extra)
continue; // [] is invalid, name can't be empty
}
ret = getValue(start + state->open.length,
ret = get_value(start + state->open.length,
end - start - state->open.length, &value, extra);
if (ret < 0)

View file

@ -9,7 +9,7 @@ const PsycString psyc_routing_vars[] = {
PSYC_C2STRI("_amount_fragments"),
PSYC_C2STRI("_context"),
//PSYC_C2STRI("_count"), // older PSYC
PSYC_C2STRI("_counter"), // the name for this is supposed to be _count, not _counter
PSYC_C2STRI("_counter"),
PSYC_C2STRI("_fragment"),
//PSYC_C2STRI("_length"), // older PSYC
PSYC_C2STRI("_source"),
@ -30,38 +30,46 @@ const PsycString psyc_routing_vars[] = {
// Variable types in alphabetical order.
const PsycDictInt psyc_var_types[] = {
{PSYC_C2STRI("_amount"), PSYC_TYPE_AMOUNT},
{PSYC_C2STRI("_color"), PSYC_TYPE_COLOR},
{PSYC_C2STRI("_date"), PSYC_TYPE_DATE},
{PSYC_C2STRI("_def"), PSYC_TYPE_DEF},
{PSYC_C2STRI("_degree"), PSYC_TYPE_DEGREE},
{PSYC_C2STRI("_entity"), PSYC_TYPE_ENTITY},
{PSYC_C2STRI("_flag"), PSYC_TYPE_FLAG},
{PSYC_C2STRI("_language"), PSYC_TYPE_LANGUAGE},
{PSYC_C2STRI("_list"), PSYC_TYPE_LIST},
{PSYC_C2STRI("_nick"), PSYC_TYPE_NICK},
{PSYC_C2STRI("_page"), PSYC_TYPE_PAGE},
{PSYC_C2STRI("_table"), PSYC_TYPE_TABLE},
{PSYC_C2STRI("_time"), PSYC_TYPE_TIME},
{PSYC_C2STRI("_uniform"), PSYC_TYPE_UNIFORM},
{ PSYC_C2STRI("_amount"), PSYC_TYPE_AMOUNT },
{ PSYC_C2STRI("_color"), PSYC_TYPE_COLOR },
{ PSYC_C2STRI("_date"), PSYC_TYPE_DATE },
{ PSYC_C2STRI("_def"), PSYC_TYPE_DEF },
{ PSYC_C2STRI("_degree"), PSYC_TYPE_DEGREE },
{ PSYC_C2STRI("_entity"), PSYC_TYPE_ENTITY },
{ PSYC_C2STRI("_flag"), PSYC_TYPE_FLAG },
{ PSYC_C2STRI("_language"), PSYC_TYPE_LANGUAGE },
{ PSYC_C2STRI("_list"), PSYC_TYPE_LIST },
{ PSYC_C2STRI("_nick"), PSYC_TYPE_NICK },
{ PSYC_C2STRI("_page"), PSYC_TYPE_PAGE },
{ PSYC_C2STRI("_table"), PSYC_TYPE_TABLE },
{ PSYC_C2STRI("_time"), PSYC_TYPE_TIME },
{ PSYC_C2STRI("_uniform"), PSYC_TYPE_UNIFORM },
};
const PsycDictInt psyc_method_families[] = {
{PSYC_C2STRI("_data"), PSYC_METHOD_DATA},
{PSYC_C2STRI("_echo"), PSYC_METHOD_ECHO},
{PSYC_C2STRI("_failure"), PSYC_METHOD_FAILURE},
{PSYC_C2STRI("_info"), PSYC_METHOD_INFO},
{PSYC_C2STRI("_message"), PSYC_METHOD_MESSAGE},
{PSYC_C2STRI("_message_echo"), PSYC_METHOD_MESSAGE_ECHO},
{PSYC_C2STRI("_notice"), PSYC_METHOD_NOTICE},
{PSYC_C2STRI("_request"), PSYC_METHOD_REQUEST},
{PSYC_C2STRI("_status"), PSYC_METHOD_STATUS},
{PSYC_C2STRI("_warning"), PSYC_METHOD_WARNING},
/// Method names in alphabetical order.
const PsycDictInt psyc_methods[] = {
{ PSYC_C2STRI("_data"), PSYC_MC_DATA },
{ PSYC_C2STRI("_echo_context_enter"), PSYC_MC_ECHO_CONTEXT_ENTER },
{ PSYC_C2STRI("_echo_context_leave"), PSYC_MC_ECHO_CONTEXT_LEAVE },
{ PSYC_C2STRI("_echo"), PSYC_MC_ECHO },
{ PSYC_C2STRI("_failure"), PSYC_MC_FAILURE },
{ PSYC_C2STRI("_info"), PSYC_MC_INFO },
{ PSYC_C2STRI("_message_echo"), PSYC_MC_MESSAGE_ECHO },
{ PSYC_C2STRI("_message"), PSYC_MC_MESSAGE },
{ PSYC_C2STRI("_notice_context_enter"), PSYC_MC_NOTICE_CONTEXT_ENTER },
{ PSYC_C2STRI("_notice_context_leave"), PSYC_MC_NOTICE_CONTEXT_LEAVE },
{ PSYC_C2STRI("_notice"), PSYC_MC_NOTICE },
{ PSYC_C2STRI("_request_context_enter"), PSYC_MC_REQUEST_CONTEXT_ENTER },
{ PSYC_C2STRI("_request_context_leave"), PSYC_MC_REQUEST_CONTEXT_LEAVE },
{ PSYC_C2STRI("_request"), PSYC_MC_REQUEST },
{ PSYC_C2STRI("_status_contexts_entered"), PSYC_MC_STATUS_CONTEXTS_ENTERED },
{ PSYC_C2STRI("_status"), PSYC_MC_STATUS },
{ PSYC_C2STRI("_warning"), PSYC_MC_WARNING },
};
const size_t psyc_routing_vars_num = PSYC_NUM_ELEM(psyc_routing_vars);
const size_t psyc_var_types_num = PSYC_NUM_ELEM(psyc_var_types);
const size_t psyc_method_families_num = PSYC_NUM_ELEM(psyc_method_families);
const size_t psyc_methods_num = PSYC_NUM_ELEM(psyc_methods);
/**
* Get the type of variable name.
@ -115,57 +123,76 @@ psyc_var_type (const char *name, size_t len)
}
/**
* Get the family and flags for a method.
* Get the method, its family and its flags.
*/
PsycMethod
psyc_method_family (char *method, size_t methodlen, unsigned int *flag)
psyc_method (char *method, size_t methodlen, PsycMethod *family, unsigned int *flag)
{
int8_t tmp[PSYC_NUM_ELEM(psyc_method_families)];
int mc = psyc_dict_lookup_int(psyc_method_families, psyc_method_families_num,
int8_t tmp[PSYC_NUM_ELEM(psyc_methods)];
int mc = psyc_dict_lookup_int(psyc_methods, psyc_methods_num,
method, methodlen, PSYC_YES, tmp);
if (!flag)
return mc;
switch (mc) {
case PSYC_METHOD_DATA:
case PSYC_MC_DATA:
*family = PSYC_MC_DATA;
*flag = 0;
break;
case PSYC_METHOD_ECHO:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE;
case PSYC_MC_ECHO:
case PSYC_MC_ECHO_CONTEXT_ENTER:
case PSYC_MC_ECHO_CONTEXT_LEAVE:
*family = PSYC_MC_ECHO;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE;
break;
case PSYC_METHOD_ERROR:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE
| PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_ERROR:
*family = PSYC_MC_ERROR;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE
| PSYC_METHOD_LOGGABLE;
break;
case PSYC_METHOD_FAILURE:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE
| PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_FAILURE:
*family = PSYC_MC_FAILURE;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE
| PSYC_METHOD_LOGGABLE;
break;
case PSYC_METHOD_INFO:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE
| PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_INFO:
*family = PSYC_MC_INFO;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE
| PSYC_METHOD_LOGGABLE;
break;
case PSYC_METHOD_MESSAGE:
*flag = PSYC_MESSAGE_VISIBLE | PSYC_MESSAGE_LOGGABLE | PSYC_MESSAGE_MANUAL;
case PSYC_MC_MESSAGE:
*family = PSYC_MC_MESSAGE;
*flag = PSYC_METHOD_VISIBLE | PSYC_METHOD_LOGGABLE | PSYC_METHOD_MANUAL;
break;
case PSYC_METHOD_MESSAGE_ECHO:
*flag = PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE | PSYC_MESSAGE_LOGGABLE
| PSYC_MESSAGE_MANUAL;
case PSYC_MC_MESSAGE_ECHO:
*family = PSYC_MC_MESSAGE_ECHO;
*flag = PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE | PSYC_METHOD_LOGGABLE
| PSYC_METHOD_MANUAL;
break;
case PSYC_METHOD_NOTICE:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_VISIBLE | PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_NOTICE:
case PSYC_MC_NOTICE_CONTEXT_ENTER:
case PSYC_MC_NOTICE_CONTEXT_LEAVE:
*family = PSYC_MC_NOTICE;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_VISIBLE | PSYC_METHOD_LOGGABLE;
break;
case PSYC_METHOD_REQUEST:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_VISIBLE | PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_REQUEST:
case PSYC_MC_REQUEST_CONTEXT_ENTER:
case PSYC_MC_REQUEST_CONTEXT_LEAVE:
*family = PSYC_MC_REQUEST;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_VISIBLE | PSYC_METHOD_LOGGABLE;
break;
case PSYC_METHOD_STATUS:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE
| PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_STATUS:
case PSYC_MC_STATUS_CONTEXTS_ENTERED:
*family = PSYC_MC_STATUS;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE
| PSYC_METHOD_LOGGABLE;
break;
case PSYC_METHOD_WARNING:
*flag = PSYC_MESSAGE_TEMPLATE | PSYC_MESSAGE_REPLY | PSYC_MESSAGE_VISIBLE
| PSYC_MESSAGE_LOGGABLE;
case PSYC_MC_WARNING:
*family = PSYC_MC_WARNING;
*flag = PSYC_METHOD_TEMPLATE | PSYC_METHOD_REPLY | PSYC_METHOD_VISIBLE
| PSYC_METHOD_LOGGABLE;
break;
default:
*family = mc;
*flag = 0;
}
return mc;

View file

@ -99,7 +99,11 @@ main (int argc, char **argv)
return 10 + i;
}
puts("psyc_text passed all tests.");
size_t tlen = 0;
char *t = psyc_template(PSYC_MC_NOTICE_CONTEXT_ENTER, &tlen);
printf("_notice_context_enter = %s, %ld\n", t, tlen);
printf("psyc_text passed all tests.\n");
return 0;
}