File: qualifier.c

package info (click to toggle)
codelite 17.0.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 136,204 kB
  • sloc: cpp: 491,547; ansic: 280,393; php: 10,259; sh: 8,930; lisp: 7,664; vhdl: 6,518; python: 6,020; lex: 4,920; yacc: 3,123; perl: 2,385; javascript: 1,715; cs: 1,193; xml: 1,110; makefile: 804; cobol: 741; sql: 709; ruby: 620; f90: 566; ada: 534; asm: 464; fortran: 350; objc: 289; tcl: 258; java: 157; erlang: 61; pascal: 51; ml: 49; awk: 44; haskell: 36
file content (114 lines) | stat: -rw-r--r-- 1,698 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
*   Copyright (c) 2016, Masatake YAMATO
*   Copyright (c) 2016, Red Hat, Inc.
*
*   This source code is released for free distribution under the terms of the
*   GNU General Public License version 2 or (at your option) any later version.
*/

/*
 * INCLUDES
 */
#include "qualifier.h"
#include "dsl.h"
#include "es.h"

#include <stdlib.h>

/*
 * TYPES
 */
struct sQCode
{
	DSLCode *dsl;
};


/*
 * DATA DEFINITIONS
 */


/*
 * FUNCTION DEFINITIONS
 */
static int initialize (void)
{
	static int initialized;

	if (initialized)
		return 1;

	if (!dsl_init (DSL_QUALIFIER, NULL, 0))
	{
		fprintf(stderr, "MEMORY EXHAUSTED\n");
		return 0;
	}

	initialized = 1;
	return 1;
}

QCode  *q_compile (EsObject *exp)
{
	QCode *code;

	if (!initialize ())
		exit (1);

	code = malloc (sizeof (QCode));
	if (code == NULL)
	{
		fprintf(stderr, "MEMORY EXHAUSTED\n");
		return NULL;
	}

	code->dsl = dsl_compile (DSL_QUALIFIER, exp);
	if (code->dsl == NULL)
	{
		fprintf(stderr, "MEMORY EXHAUSTED or SYNTAX ERROR\n");
		free (code);
		return NULL;
	}
	return code;
}

enum QRESULT q_is_acceptable  (QCode *code, tagEntry *entry)
{
	EsObject *r;
	int i;

	DSLEnv env = {
		.engine = DSL_QUALIFIER,
		.entry  = entry,
	};
	es_autounref_pool_push ();
	r = dsl_eval (code->dsl, &env);
	if (es_object_equal (r, es_false))
		i = Q_REJECT;
	else if (es_error_p (r))
	{
		dsl_report_error ("GOT ERROR in QUALIFYING", r);
		i = Q_ERROR;
	}
	else
		i = Q_ACCEPT;
	es_autounref_pool_pop ();

	dsl_cache_reset (DSL_QUALIFIER);

	return i;
}

void q_destroy (QCode *code)
{
	dsl_release (DSL_QUALIFIER, code->dsl);
	free (code);
}

void q_help (FILE *fp)
{
	if (!initialize ())
		exit (1);
	dsl_help (DSL_QUALIFIER, fp);
}