X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Fregex%2Fperf-regex.c;h=3f1e771154dcbc1defbcff28e7b7cca95cd44e7e;hb=d94c5185fcdf47c6a57d3233b946fa7e621f7ad9;hp=4e339d2282193c6b3a7c6f7dabefa28d09bbc528;hpb=8b58c505a14bfe2efe46f67f04594c812df154c2;p=oweals%2Fgnunet.git diff --git a/src/regex/perf-regex.c b/src/regex/perf-regex.c index 4e339d228..3f1e77115 100644 --- a/src/regex/perf-regex.c +++ b/src/regex/perf-regex.c @@ -26,20 +26,45 @@ #include #include #include "platform.h" -#include "gnunet_regex_lib.h" +#include "regex_internal_lib.h" #include "regex_test_lib.h" -static const char *exe; +/** + * Print information about the given node and its edges + * to stdout. + * + * @param cls closure, unused. + * @param key hash for current state. + * @param proof proof for current state. + * @param accepting GNUNET_YES if this is an accepting state, GNUNET_NO if not. + * @param num_edges number of edges leaving current state. + * @param edges edges leaving current state. + */ static void -usage(void) +print_edge (void *cls, + const struct GNUNET_HashCode *key, + const char *proof, + int accepting, + unsigned int num_edges, + const struct REGEX_BLOCK_Edge *edges) { - fprintf (stderr, "Usage: %s REGEX_FILE COMPRESSION\n", exe); + unsigned int i; + + printf ("%s: %s, proof: `%s'\n", + GNUNET_h2s (key), + accepting ? "ACCEPTING" : "", + proof); + for (i = 0; i < num_edges; i++) + printf (" `%s': %s\n", + edges[i].label, + GNUNET_h2s (&edges[i].destination)); } + /** * The main function of the regex performace test. - * + * * Read a set of regex from a file, combine them and create a DFA from the * resulting combined regex. * @@ -50,7 +75,7 @@ usage(void) int main (int argc, char *const *argv) { - struct GNUNET_REGEX_Automaton* dfa; + struct REGEX_INTERNAL_Automaton* dfa; char **regexes; char *buffer; char *regex; @@ -58,32 +83,40 @@ main (int argc, char *const *argv) long size; GNUNET_log_setup ("perf-regex", "DEBUG", NULL); - exe = argv[0]; if (3 != argc) { - usage(); + fprintf (stderr, + "Usage: %s REGEX_FILE COMPRESSION\n", + argv[0]); return 1; } - regexes = GNUNET_REGEX_read_from_file (argv[1]); - + regexes = REGEX_TEST_read_from_file (argv[1]); if (NULL == regexes) { - usage(); + fprintf (stderr, + "Failed to read regexes from `%s'\n", + argv[1]); return 2; } - buffer = GNUNET_REGEX_combine (regexes); + compression = atoi (argv[2]); - GNUNET_asprintf (®ex, "GNVPN-0001-PAD(%s)(0|1)*", buffer); + buffer = REGEX_TEST_combine (regexes); + GNUNET_asprintf (®ex, "GNUNET_REGEX_PROFILER_(%s)(0|1)*", buffer); size = strlen (regex); - fprintf (stderr, "Combined regex (%ld bytes):\n%s\n", size, regex); - // return 0; - - compression = atoi (argv[2]); - dfa = GNUNET_REGEX_construct_dfa (regex, size, compression); - GNUNET_REGEX_automaton_destroy (dfa); + fprintf (stderr, + "Combined regex (%ld bytes):\n%s\n", + size, + regex); + dfa = REGEX_INTERNAL_construct_dfa (regex, size, compression); + printf ("********* ALL EDGES *********'\n"); + REGEX_INTERNAL_iterate_all_edges (dfa, &print_edge, NULL); + printf ("\n\n********* REACHABLE EDGES *********'\n"); + REGEX_INTERNAL_iterate_reachable_edges (dfa, &print_edge, NULL); + REGEX_INTERNAL_automaton_destroy (dfa); GNUNET_free (buffer); - GNUNET_REGEX_free_from_file (regexes); + REGEX_TEST_free_from_file (regexes); + GNUNET_free (regex); return 0; }