diff options
Diffstat (limited to 'libbanshee/engine/flowrow-sort.h')
-rw-r--r-- | libbanshee/engine/flowrow-sort.h | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/libbanshee/engine/flowrow-sort.h b/libbanshee/engine/flowrow-sort.h new file mode 100644 index 00000000000..8d79b42c29d --- /dev/null +++ b/libbanshee/engine/flowrow-sort.h @@ -0,0 +1,133 @@ +/* + * Copyright (c) 2000-2001 + * The Regents of the University of California. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + */ + +#ifndef FLOWROW_SORT_H +#define FLOWROW_SORT_H + + +#include "stdio.h" +#include "banshee.h" +#include "termhash.h" +#include "flow-var.h" + +struct flowrow_field +{ + char *label; + gen_e expr; +}; + +typedef struct flowrow_field *flowrow_field; + +DECLARE_LIST(flowrow_map,flowrow_field) + +extern region flowrow_region; + +void flowrow_inclusion(fresh_fn_ptr fresh, get_stamp_fn_ptr get_stamp, + incl_fn_ptr field_incl,gen_e zero_elem, gen_e e1, + gen_e e2) deletes; + +gen_e flowrow_row(get_stamp_fn_ptr get_stamp,flowrow_map fields, gen_e rest) deletes; + +gen_e flowrow_extract_field(const char *name, gen_e e); +gen_e flowrow_extract_rest(gen_e e); +flowrow_map flowrow_extract_fields(gen_e e); + +stamp flowrow_get_stamp(gen_e e); + +#ifndef NONSPEC +gen_e flowrow_zero(void); +gen_e flowrow_one(void); +gen_e flowrow_abs(void); +gen_e flowrow_wild(void); +gen_e flowrow_fresh(const char *name); +gen_e flowrow_fresh_small(const char *name); +gen_e flowrow_fresh_large(const char *name); +#else +sort_kind flowrow_base_sort(gen_e e); +gen_e flowrow_zero(sort_kind base_sort); +gen_e flowrow_one(sort_kind base_sort); +gen_e flowrow_abs(sort_kind base_sort); +gen_e flowrow_wild(sort_kind base_sort); +gen_e flowrow_fresh(sort_kind base_sort); +gen_e flowrow_fresh_small(sort_kind base_sort); +gen_e flowrow_fresh_large(sort_kind base_sort); +#endif + +bool flowrow_is_zero(gen_e e); +bool flowrow_is_one(gen_e e); +bool flowrow_is_abs(gen_e e); +bool flowrow_is_wild(gen_e e); +bool flowrow_is_var(gen_e e); +bool flowrow_is_row(gen_e e); +bool flowrow_is_alias(gen_e e); + + +void flowrow_init(void); +void flowrow_reset(void) deletes; + +typedef void (* field_print_fn_ptr) (FILE *f,gen_e e) deletes; + +void flowrow_print(FILE *f,get_stamp_fn_ptr get_stamp, + field_print_fn_ptr field_print,gen_e e) deletes; +void flowrow_print_stats(FILE *f); + +extern struct flowrow_stats flowrow_stats; + +struct flowrow_stats +{ + int fresh; + int fresh_small; + int fresh_large; + + int rows_disjoint_wild; + int rows_equal; + int rows_zero_one_wild; + int rows_l_inductive; + int rows_r_inductive; + int rows_disjoint_r1_minimal; + int rows_disjoint_r1_var_r2_minimal; + int rows_disjoint_r1_var_r2_maximal; + int rows_disjoint_r1_var_r2_closed; + int rows_disjoint_r1_var_r2_var_lt; + int rows_disjoint_r1_var_r2_var_gt; + int rows_equal_domains; + int rows_nonempty_intersection; + int rows_fresh; + int rows_fresh_large; +}; + +#endif /* FLOWROW_H */ + + + + + + + |