⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 name.c

📁 gcc-2.95.3 Linux下最常用的C编译器
💻 C
字号:
/* name.c -- Implementation File (module.c template V1.0)   Copyright (C) 1995 Free Software Foundation, Inc.   Contributed by James Craig Burley.This file is part of GNU Fortran.GNU Fortran is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2, or (at your option)any later version.GNU Fortran is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU Fortran; see the file COPYING.  If not, write tothe Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA02111-1307, USA.   Related Modules:      None.   Description:      Name and name space abstraction.   Modifications:*//* Include files. */#include "proj.h"#include "bad.h"#include "name.h"#include "lex.h"#include "malloc.h"#include "src.h"#include "where.h"/* Externals defined here. *//* Simple definitions and enumerations. *//* Internal typedefs. *//* Private include files. *//* Internal structure definitions. *//* Static objects accessed by functions in this module. *//* Static functions (internal). */static ffename ffename_lookup_ (ffenameSpace ns, ffelexToken t, bool *found);/* Internal macros. *//* Searches for and returns the matching ffename object, or returns a   pointer to the name before which the new name should go.  */static ffenameffename_lookup_ (ffenameSpace ns, ffelexToken t, bool *found){  ffename n;  for (n = ns->first; n != (ffename) &ns->first; n = n->next)    {      if (ffelex_token_strcmp (t, n->t) == 0)	{	  *found = TRUE;	  return n;	}    }  *found = FALSE;  return n;			/* (n == (ffename) &ns->first) */}/* Searches for and returns the matching ffename object, or creates a new   one (with a NULL ffesymbol) and returns that.  If last arg is TRUE,   check whether token meets character-content requirements (such as   "all characters must be uppercase", as determined by   ffesrc_bad_char_symbol (), issue diagnostic if it doesn't.  */ffenameffename_find (ffenameSpace ns, ffelexToken t){  ffename n;  ffename newn;  bool found;  assert (ns != NULL);  assert ((t != NULL) && ((ffelex_token_type (t) == FFELEX_typeNAME)			  || (ffelex_token_type (t) == FFELEX_typeNAMES)));  n = ffename_lookup_ (ns, t, &found);  if (found)    return n;  newn = (ffename) malloc_new_ks (ns->pool, "FFENAME name", sizeof (*n));  newn->next = n;  newn->previous = n->previous;  n->previous = newn;  newn->previous->next = newn;  newn->t = ffelex_token_use (t);  newn->u.s = NULL;  return newn;}/* ffename_kill -- Kill name from name space   ffenameSpace ns;   ffename s;   ffename_kill(ns,s);   Removes the name from the name space.  */voidffename_kill (ffenameSpace ns, ffename n){  assert (ns != NULL);  assert (n != NULL);  ffelex_token_kill (n->t);  n->next->previous = n->previous;  n->previous->next = n->next;  malloc_kill_ks (ns->pool, n, sizeof (*n));}/* ffename_lookup -- Look up name in name space   ffenameSpace ns;   ffelexToken t;   ffename s;   n = ffename_lookup(ns,t);   Searches for and returns the matching ffename object, or returns NULL.  */ffenameffename_lookup (ffenameSpace ns, ffelexToken t){  ffename n;  bool found;  assert (ns != NULL);  assert ((t != NULL) && ((ffelex_token_type (t) == FFELEX_typeNAME)			  || (ffelex_token_type (t) == FFELEX_typeNAMES)));  n = ffename_lookup_ (ns, t, &found);  return found ? n : NULL;}/* ffename_space_drive_global -- Call given fn for each global in name space   ffenameSpace ns;   ffeglobal (*fn)();   ffename_space_drive_global(ns,fn);  */voidffename_space_drive_global (ffenameSpace ns, ffeglobal (*fn) (ffeglobal)){  ffename n;  if (ns == NULL)    return;  for (n = ns->first; n != (ffename) &ns->first; n = n->next)    {      if (n->u.g != NULL)	n->u.g = (*fn) (n->u.g);    }}/* ffename_space_drive_symbol -- Call given fn for each symbol in name space   ffenameSpace ns;   ffesymbol (*fn)();   ffename_space_drive_symbol(ns,fn);  */voidffename_space_drive_symbol (ffenameSpace ns, ffesymbol (*fn) (ffesymbol)){  ffename n;  if (ns == NULL)    return;  for (n = ns->first; n != (ffename) &ns->first; n = n->next)    {      if (n->u.s != NULL)	n->u.s = (*fn) (n->u.s);    }}/* ffename_space_kill -- Kill name space   ffenameSpace ns;   ffename_space_kill(ns);   Removes the names from the name space; kills the name space.	 */voidffename_space_kill (ffenameSpace ns){  assert (ns != NULL);  while (ns->first != (ffename) &ns->first)    ffename_kill (ns, ns->first);  malloc_kill_ks (ns->pool, ns, sizeof (*ns));}/* ffename_space_new -- Create name space   ffenameSpace ns;   ns = ffename_space_new(malloc_pool_image());   Create new name space.  */ffenameSpaceffename_space_new (mallocPool pool){  ffenameSpace ns;  ns = (ffenameSpace) malloc_new_ks (pool, "FFENAME space",				     sizeof (*ns));  ns->first = (ffename) &ns->first;  ns->last = (ffename) &ns->first;  ns->pool = pool;  return ns;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -