/* This file is part of GNUnet. Copyright (C) 2012 GNUnet e.V. GNUnet is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, 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 Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . SPDX-License-Identifier: AGPL3.0-or-later */ /** * @file src/regex/perf-regex.c * @brief Test how long it takes to create a automaton from a string regex. * @author Bartlomiej Polot */ #include #include #include "platform.h" #include "regex_internal_lib.h" #include "regex_test_lib.h" /** * 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 print_edge (void *cls, const struct GNUNET_HashCode *key, const char *proof, int accepting, unsigned int num_edges, const struct REGEX_BLOCK_Edge *edges) { 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. * * @param argc number of arguments from the command line * @param argv command line arguments * @return 0 ok, 1 on error */ int main (int argc, char *const *argv) { struct REGEX_INTERNAL_Automaton* dfa; char **regexes; char *buffer; char *regex; int compression; unsigned int alphabet_size; long size; GNUNET_log_setup ("perf-regex", "DEBUG", NULL); if (4 != argc) { fprintf (stderr, "Usage: %s REGEX_FILE ALPHABET_SIZE COMPRESSION\n", argv[0]); return 1; } regexes = REGEX_TEST_read_from_file (argv[1]); if (NULL == regexes) { fprintf (stderr, "Failed to read regexes from `%s'\n", argv[1]); return 2; } alphabet_size = atoi (argv[2]); compression = atoi (argv[3]); printf ("********* PERF-REGEX *********'\n"); printf ("Using:\n file '%s'\n Alphabet size %u\n compression %d\n", argv[1], alphabet_size, compression); fflush(stdout); buffer = REGEX_TEST_combine (regexes, alphabet_size); GNUNET_asprintf (®ex, "GNUNET_REGEX_PROFILER_(%s)(0|1)*", buffer); size = strlen (regex); 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); REGEX_TEST_free_from_file (regexes); GNUNET_free (regex); return 0; } /* end of prof-regex.c */