56 lines
1.3 KiB
C
56 lines
1.3 KiB
C
#include <jsgf.h>
|
|
#include <fsg_model.h>
|
|
#include <string.h>
|
|
|
|
#include "test_macros.h"
|
|
|
|
int
|
|
main(int argc, char *argv[])
|
|
{
|
|
logmath_t *lmath;
|
|
fsg_model_t *fsg;
|
|
jsgf_t *jsgf;
|
|
jsgf_rule_t *rule;
|
|
|
|
lmath = logmath_init(1.0001, 0, 0);
|
|
|
|
/* Test loading */
|
|
jsgf = jsgf_parse_file(LMDIR "/polite.gram", NULL);
|
|
TEST_ASSERT(jsgf);
|
|
rule = jsgf_get_rule(jsgf, "polite.startPolite");
|
|
TEST_ASSERT(rule);
|
|
fsg = jsgf_build_fsg(jsgf, rule, lmath, 7.5);
|
|
TEST_ASSERT(fsg);
|
|
TEST_EQUAL_STRING("polite", jsgf_grammar_name(jsgf));
|
|
|
|
TEST_ASSERT(fsg_model_add_silence(fsg, "<sil>", -1, 0.3));
|
|
TEST_ASSERT(fsg_model_add_silence(fsg, "++NOISE++", -1, 0.3));
|
|
TEST_ASSERT(fsg_model_add_alt(fsg, "please", "please(2)"));
|
|
|
|
jsgf_grammar_free(jsgf);
|
|
fsg_model_write(fsg, stdout);
|
|
fsg_model_free(fsg);
|
|
|
|
/* Or do everything at once */
|
|
fsg = jsgf_read_file(LMDIR "/public.gram", lmath, 1.0);
|
|
fsg_model_free(fsg);
|
|
|
|
/* Test grammar with keywords inside */
|
|
jsgf = jsgf_parse_file(LMDIR "/public.gram", NULL);
|
|
TEST_ASSERT(jsgf);
|
|
jsgf_grammar_free(jsgf);
|
|
|
|
jsgf = jsgf_parse_string("#JSGF V1.0; grammar test; public <choice> = yes | no;", NULL);
|
|
TEST_ASSERT(jsgf);
|
|
rule = jsgf_get_rule(jsgf, "test.choice");
|
|
TEST_ASSERT(rule);
|
|
fsg = jsgf_build_fsg(jsgf, rule, lmath, 7.5);
|
|
fsg_model_write(fsg, stdout);
|
|
fsg_model_free(fsg);
|
|
jsgf_grammar_free(jsgf);
|
|
|
|
logmath_free(lmath);
|
|
|
|
return 0;
|
|
}
|