📄 uniqstr.c
字号:
/* Keep a unique copy of strings. Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc. This file is part of Bison, the GNU Compiler Compiler. Bison 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 2, or (at your option) any later version. Bison 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 Bison; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */#include "system.h"#include <error.h>#include <hash.h>#include <quotearg.h>#include "uniqstr.h"/*-----------------------.| A uniqstr hash table. |`-----------------------*//* Initial capacity of uniqstr hash table. */#define HT_INITIAL_CAPACITY 257static struct hash_table *uniqstrs_table = NULL;/*-------------------------------------.| Create the uniqstr for S if needed. |`-------------------------------------*/uniqstruniqstr_new (char const *str){ uniqstr res = hash_lookup (uniqstrs_table, str); if (!res) { /* First insertion in the hash. */ res = xstrdup (str); hash_insert (uniqstrs_table, res); } return res;}/*------------------------------.| Abort if S is not a uniqstr. |`------------------------------*/voiduniqstr_assert (char const *str){ if (!hash_lookup (uniqstrs_table, str)) { error (0, 0, "not a uniqstr: %s", quotearg (str)); abort (); }}/*--------------------.| Print the uniqstr. |`--------------------*/static inline booluniqstr_print (uniqstr ustr){ fprintf (stderr, "%s\n", ustr); return true;}static booluniqstr_print_processor (void *ustr, void *null ATTRIBUTE_UNUSED){ return uniqstr_print (ustr);}/*-----------------------.| A uniqstr hash table. |`-----------------------*/static boolhash_compare_uniqstr (void const *m1, void const *m2){ return strcmp (m1, m2) == 0;}static size_thash_uniqstr (void const *m, size_t tablesize){ return hash_string (m, tablesize);}/*----------------------------.| Create the uniqstrs table. |`----------------------------*/voiduniqstrs_new (void){ uniqstrs_table = hash_initialize (HT_INITIAL_CAPACITY, NULL, hash_uniqstr, hash_compare_uniqstr, free);}/*-------------------------------------.| Perform a task on all the uniqstrs. |`-------------------------------------*/static voiduniqstrs_do (Hash_processor processor, void *processor_data){ hash_do_for_each (uniqstrs_table, processor, processor_data);}/*-----------------.| Print them all. |`-----------------*/voiduniqstrs_print (void){ uniqstrs_do (uniqstr_print_processor, NULL);}/*--------------------.| Free the uniqstrs. |`--------------------*/voiduniqstrs_free (void){ hash_free (uniqstrs_table);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -