|
Packit Service |
db8eaa |
/*
|
|
Packit Service |
db8eaa |
* ALSA lisp implementation
|
|
Packit Service |
db8eaa |
* Copyright (c) 2003 by Jaroslav Kysela <perex@perex.cz>
|
|
Packit Service |
db8eaa |
*
|
|
Packit Service |
db8eaa |
* Based on work of Sandro Sigala (slisp-1.2)
|
|
Packit Service |
db8eaa |
*
|
|
Packit Service |
db8eaa |
*
|
|
Packit Service |
db8eaa |
* This library is free software; you can redistribute it and/or modify
|
|
Packit Service |
db8eaa |
* it under the terms of the GNU Lesser General Public License as
|
|
Packit Service |
db8eaa |
* published by the Free Software Foundation; either version 2.1 of
|
|
Packit Service |
db8eaa |
* the License, or (at your option) any later version.
|
|
Packit Service |
db8eaa |
*
|
|
Packit Service |
db8eaa |
* This program is distributed in the hope that it will be useful,
|
|
Packit Service |
db8eaa |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
db8eaa |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
Packit Service |
db8eaa |
* GNU Lesser General Public License for more details.
|
|
Packit Service |
db8eaa |
*
|
|
Packit Service |
db8eaa |
* You should have received a copy of the GNU Lesser General Public
|
|
Packit Service |
db8eaa |
* License along with this library; if not, write to the Free Software
|
|
Packit Service |
db8eaa |
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
Packit Service |
db8eaa |
*
|
|
Packit Service |
db8eaa |
*/
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
#include "list.h"
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
enum alisp_tokens {
|
|
Packit Service |
db8eaa |
ALISP_IDENTIFIER,
|
|
Packit Service |
db8eaa |
ALISP_INTEGER,
|
|
Packit Service |
db8eaa |
ALISP_FLOAT,
|
|
Packit Service |
db8eaa |
ALISP_FLOATE,
|
|
Packit Service |
db8eaa |
ALISP_STRING
|
|
Packit Service |
db8eaa |
};
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
enum alisp_objects {
|
|
Packit Service |
db8eaa |
ALISP_OBJ_INTEGER,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_FLOAT,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_IDENTIFIER,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_STRING,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_POINTER,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_CONS,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_LAST_SEARCH = ALISP_OBJ_CONS,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_NIL,
|
|
Packit Service |
db8eaa |
ALISP_OBJ_T,
|
|
Packit Service |
db8eaa |
};
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
struct alisp_object;
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
#define ALISP_TYPE_MASK 0xf0000000
|
|
Packit Service |
db8eaa |
#define ALISP_TYPE_SHIFT 28
|
|
Packit Service |
db8eaa |
#define ALISP_REFS_MASK 0x0fffffff
|
|
Packit Service |
db8eaa |
#define ALISP_REFS_SHIFT 0
|
|
Packit Service |
db8eaa |
#define ALISP_MAX_REFS (ALISP_REFS_MASK>>ALISP_REFS_SHIFT)
|
|
Packit Service |
db8eaa |
#define ALISP_MAX_REFS_LIMIT ((ALISP_MAX_REFS + 1) / 2)
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
struct alisp_object {
|
|
Packit Service |
db8eaa |
struct list_head list;
|
|
Packit Service |
db8eaa |
unsigned int type_refs; /* type and count of references */
|
|
Packit Service |
db8eaa |
union {
|
|
Packit Service |
db8eaa |
char *s;
|
|
Packit Service |
db8eaa |
long i;
|
|
Packit Service |
db8eaa |
double f;
|
|
Packit Service |
db8eaa |
const void *ptr;
|
|
Packit Service |
db8eaa |
struct {
|
|
Packit Service |
db8eaa |
struct alisp_object *car;
|
|
Packit Service |
db8eaa |
struct alisp_object *cdr;
|
|
Packit Service |
db8eaa |
} c;
|
|
Packit Service |
db8eaa |
} value;
|
|
Packit Service |
db8eaa |
};
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline enum alisp_objects alisp_get_type(struct alisp_object *p)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
return (p->type_refs >> ALISP_TYPE_SHIFT);
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline void alisp_set_type(struct alisp_object *p, enum alisp_objects type)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
p->type_refs &= ~ALISP_TYPE_MASK;
|
|
Packit Service |
db8eaa |
p->type_refs |= (unsigned int)type << ALISP_TYPE_SHIFT;
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline int alisp_compare_type(struct alisp_object *p, enum alisp_objects type)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
return ((unsigned int)type << ALISP_TYPE_SHIFT) ==
|
|
Packit Service |
db8eaa |
(p->type_refs & ALISP_TYPE_MASK);
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline void alisp_set_refs(struct alisp_object *p, unsigned int refs)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
p->type_refs &= ~ALISP_REFS_MASK;
|
|
Packit Service |
db8eaa |
p->type_refs |= refs & ALISP_REFS_MASK;
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline unsigned int alisp_get_refs(struct alisp_object *p)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
return p->type_refs & ALISP_REFS_MASK;
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline unsigned int alisp_inc_refs(struct alisp_object *p)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
unsigned r = alisp_get_refs(p) + 1;
|
|
Packit Service |
db8eaa |
alisp_set_refs(p, r);
|
|
Packit Service |
db8eaa |
return r;
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
static inline unsigned int alisp_dec_refs(struct alisp_object *p)
|
|
Packit Service |
db8eaa |
{
|
|
Packit Service |
db8eaa |
unsigned r = alisp_get_refs(p) - 1;
|
|
Packit Service |
db8eaa |
alisp_set_refs(p, r);
|
|
Packit Service |
db8eaa |
return r;
|
|
Packit Service |
db8eaa |
}
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
struct alisp_object_pair {
|
|
Packit Service |
db8eaa |
struct list_head list;
|
|
Packit Service |
db8eaa |
const char *name;
|
|
Packit Service |
db8eaa |
struct alisp_object *value;
|
|
Packit Service |
db8eaa |
};
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
#define ALISP_LEX_BUF_MAX 16
|
|
Packit Service |
db8eaa |
#define ALISP_OBJ_PAIR_HASH_SHIFT 4
|
|
Packit Service |
db8eaa |
#define ALISP_OBJ_PAIR_HASH_SIZE (1<
|
|
Packit Service |
db8eaa |
#define ALISP_OBJ_PAIR_HASH_MASK (ALISP_OBJ_PAIR_HASH_SIZE-1)
|
|
Packit Service |
db8eaa |
#define ALISP_FREE_OBJ_POOL 512 /* free objects above this pool */
|
|
Packit Service |
db8eaa |
|
|
Packit Service |
db8eaa |
struct alisp_instance {
|
|
Packit Service |
db8eaa |
int verbose: 1,
|
|
Packit Service |
db8eaa |
warning: 1,
|
|
Packit Service |
db8eaa |
debug: 1;
|
|
Packit Service |
db8eaa |
/* i/o */
|
|
Packit Service |
db8eaa |
snd_input_t *in;
|
|
Packit Service |
db8eaa |
snd_output_t *out;
|
|
Packit Service |
db8eaa |
snd_output_t *eout; /* error output */
|
|
Packit Service |
db8eaa |
snd_output_t *vout; /* verbose output */
|
|
Packit Service |
db8eaa |
snd_output_t *wout; /* warning output */
|
|
Packit Service |
db8eaa |
snd_output_t *dout; /* debug output */
|
|
Packit Service |
db8eaa |
/* lexer */
|
|
Packit Service |
db8eaa |
int charno;
|
|
Packit Service |
db8eaa |
int lineno;
|
|
Packit Service |
db8eaa |
int lex_buf[ALISP_LEX_BUF_MAX];
|
|
Packit Service |
db8eaa |
int *lex_bufp;
|
|
Packit Service |
db8eaa |
char *token_buffer;
|
|
Packit Service |
db8eaa |
int token_buffer_max;
|
|
Packit Service |
db8eaa |
int thistoken;
|
|
Packit Service |
db8eaa |
/* object allocator / storage */
|
|
Packit Service |
db8eaa |
long free_objs;
|
|
Packit Service |
db8eaa |
long used_objs;
|
|
Packit Service |
db8eaa |
long max_objs;
|
|
Packit Service |
db8eaa |
struct list_head free_objs_list;
|
|
Packit Service |
db8eaa |
struct list_head used_objs_list[ALISP_OBJ_PAIR_HASH_SIZE][ALISP_OBJ_LAST_SEARCH + 1];
|
|
Packit Service |
db8eaa |
/* set object */
|
|
Packit Service |
db8eaa |
struct list_head setobjs_list[ALISP_OBJ_PAIR_HASH_SIZE];
|
|
Packit Service |
db8eaa |
};
|