aboutsummaryrefslogtreecommitdiff
path: root/src/regex/test_regex_iterate_api.c
blob: a4cef5a5149783d9ee0cc8984df5965fd58693b8 (plain) (blame)
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
/*
     This file is part of GNUnet
     (C) 2012 Christian Grothoff (and other contributing authors)

     GNUnet is free software; you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published
     by the Free Software Foundation; either version 3, or (at your
     option) any later version.

     GNUnet is distributed in the hope that it will be useful, but
     WITHOUT ANY WARRANTY; without even the implied warranty of
     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     General Public License for more details.

     You should have received a copy of the GNU General Public License
     along with GNUnet; see the file COPYING.  If not, write to the
     Free Software Foundation, Inc., 59 Temple Place - Suite 330,
     Boston, MA 02111-1307, USA.
*/
/**
 * @file regex/test_regex_iterate_api.c
 * @brief test for regex.c
 * @author Maximilian Szengel
 */
#include <regex.h>
#include <time.h>
#include "platform.h"
#include "gnunet_regex_lib.h"

void
key_iterator (void *cls, const struct GNUNET_HashCode * key, const char *proof,
              int accepting, unsigned int num_edges,
              const struct GNUNET_REGEX_Edge *edges)
{
  int i;

  GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Iterating...\n");
  for (i = 0; i < num_edges; i++)
  {
    GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Edge %i: %s\n", i, edges[i].label);
  }

  if (NULL != proof)
    GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, "Proof: %s\n", proof);
}

int
main (int argc, char *argv[])
{
  GNUNET_log_setup ("test-regex",
#if VERBOSE
                    "DEBUG",
#else
                    "WARNING",
#endif
                    NULL);

  int error;
  const char *regex;
  struct GNUNET_REGEX_Automaton *dfa;

  error = 0;
  regex = "ab(c|d)+c*(a(b|c)+d)+(bla)+";
  /*regex = "(bla)+"; */
  /*regex = "b(lab)*la"; */
  /*regex = "(bla)*"; */
  /*regex = "ab(c|d)+c*(a(b|c)+d)+(bla)(bla)*"; */
  /*regex = "z(abc|def)?xyz"; */
  /*regex = "1*0(0|1)*"; */
  /*regex = "a+X*y+c|p|R|Z*K*y*R+w|Y*6+n+h*k*w+V*F|W*B*e*"; */
  /*regex = "abcd:(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)(0|1)"; */
  /*regex = "abc(1|0)*def"; */
  /*regex = "ab|ac"; */
  /*regex = "(ab)(ab)*"; */
  /*regex = "ab|cd|ef|gh"; */
  /*regex = "a|b|c|d|e|f|g"; */
  /*regex = "(ab)|(ac)"; */
  /*regex = "a(b|c)"; */
  /*regex = "a*a"; */
  /*regex = "ab?(abcd)?"; */
  /*regex = "(ab)+"; */
  /*regex = "(abcsdfsdf)+"; */
  dfa = GNUNET_REGEX_construct_dfa (regex, strlen (regex));
  GNUNET_REGEX_automaton_save_graph (dfa, "dfa.dot");
  GNUNET_REGEX_iterate_all_edges (dfa, key_iterator, NULL);
  GNUNET_REGEX_automaton_destroy (dfa);

  return error;
}