/* * * k e y w o r d . c -- Keywords management * * Copyright © 1993-1999 Erick Gallesio - I3S-CNRS/ESSI * * * Permission to use, copy, modify, distribute,and license this * software and its documentation for any purpose is hereby granted, * provided that existing copyright notices are retained in all * copies and that this notice is included verbatim in any * distributions. No written agreement, license, or royalty fee is * required for any of the authorized uses. * This software is provided ``AS IS'' without express or implied * warranty. * * Author: Erick Gallesio [eg@kaolin.unice.fr] * Creation date: 19-Nov-1993 16:12 * Last file update: 3-Sep-1999 20:20 (eg) */ #include "stk.h" static Tcl_HashTable k_table; void STk_initialize_keyword_table(void) { Tcl_InitHashTable(&k_table, TCL_STRING_KEYS); } void STk_free_keyword(SCM keyword) { Tcl_DeleteHashEntry(Tcl_FindHashEntry(&k_table, KEYVAL(keyword))); } SCM STk_makekey(char *token) { Tcl_HashEntry *p; *token = '-'; /* because keywords corresponds to Tk options */ if ((p = Tcl_FindHashEntry(&k_table, token))) return (SCM) Tcl_GetHashValue(p); else { SCM keyword; int absent; /* Be careful with GC: Create hash entry after the new cell to avoid * partially initialized table entry */ NEWCELL(keyword, tc_keyword); p = Tcl_CreateHashEntry(&k_table, token, &absent); KEYVAL(keyword) = Tcl_GetHashKey(&k_table, p); Tcl_SetHashValue(p, (ClientData) keyword); return keyword; } } PRIMITIVE STk_make_keyword(SCM str) { SCM z; char *s, *copy; switch (TYPE(str)) { case tc_string: s = CHARS(str); break; case tc_symbol: s = PNAME(str); break; default: Err("make-keyword: Bad parameter", str); } copy = must_malloc(strlen(s)+2); strcpy(copy+1, s); /* copy[0] will be set to '-' in STk_makekey */ z = STk_makekey(copy); free(copy); return z; } PRIMITIVE STk_keywordp(SCM obj) { return KEYWORDP(obj)? Truth : Ntruth; } PRIMITIVE STk_keyword2string(SCM obj) { SCM res; if (NKEYWORDP(obj)) Err("keyword->string: bad keyword", obj); res = STk_makestring(KEYVAL(obj)); CHARS(res)[0] = ':'; return res; } PRIMITIVE STk_get_keyword(SCM key, SCM l, SCM default_value) { if (NKEYWORDP(key)) Err("get-keyword: bad keyword", key); if (CONSP(l) || NULLP(l)) { int i, len = STk_llength(l); if (len< 0 || len&1) goto Error; for (i = 0; i < len; i+=2) { if (NKEYWORDP(CAR(l))) Err("get-keyword: bad keyword", CAR(l)); if (strcmp(KEYVAL(CAR(l)), KEYVAL(key)) == 0) return CAR(CDR(l)); l = CDR(CDR(l)); } if (default_value == UNBOUND) Err("get-keyword: value not found for", key); return default_value; } Error: Err("get-keyword: bad list", l); return UNDEFINED; /* never reached */ }