source: lmdz_wrf/WRFV3/tools/CodeBase/sym.c @ 1

Last change on this file since 1 was 1, checked in by lfita, 10 years ago
  • -- --- Opening of the WRF+LMDZ coupling repository --- -- -

WRF: version v3.3
LMDZ: version v1818

More details in:

File size: 4.6 KB
Line 
1/***********************************************************************
2     
3                              COPYRIGHT
4     
5     The following is a notice of limited availability of the code and
6     Government license and disclaimer which must be included in the
7     prologue of the code and in all source listings of the code.
8     
9     Copyright notice
10       (c) 1977  University of Chicago
11     
12     Permission is hereby granted to use, reproduce, prepare
13     derivative works, and to redistribute to others at no charge.  If
14     you distribute a copy or copies of the Software, or you modify a
15     copy or copies of the Software or any portion of it, thus forming
16     a work based on the Software and make and/or distribute copies of
17     such work, you must meet the following conditions:
18     
19          a) If you make a copy of the Software (modified or verbatim)
20             it must include the copyright notice and Government       
21             license and disclaimer.
22     
23          b) You must cause the modified Software to carry prominent   
24             notices stating that you changed specified portions of   
25             the Software.
26     
27     This software was authored by:
28     
29     Argonne National Laboratory
30     J. Michalakes: (630) 252-6646; email: michalak@mcs.anl.gov
31     Mathematics and Computer Science Division
32     Argonne National Laboratory, Argonne, IL  60439
33     
34     ARGONNE NATIONAL LABORATORY (ANL), WITH FACILITIES IN THE STATES
35     OF ILLINOIS AND IDAHO, IS OWNED BY THE UNITED STATES GOVERNMENT,
36     AND OPERATED BY THE UNIVERSITY OF CHICAGO UNDER PROVISION OF A
37     CONTRACT WITH THE DEPARTMENT OF ENERGY.
38     
39                      GOVERNMENT LICENSE AND DISCLAIMER
40     
41     This computer code material was prepared, in part, as an account
42     of work sponsored by an agency of the United States Government.
43     The Government is granted for itself and others acting on its
44     behalf a paid-up, nonexclusive, irrevocable worldwide license in
45     this data to reproduce, prepare derivative works, distribute
46     copies to the public, perform publicly and display publicly, and
47     to permit others to do so.  NEITHER THE UNITED STATES GOVERNMENT
48     NOR ANY AGENCY THEREOF, NOR THE UNIVERSITY OF CHICAGO, NOR ANY OF
49     THEIR EMPLOYEES, MAKES ANY WARRANTY, EXPRESS OR IMPLIED, OR
50     ASSUMES ANY LEGAL LIABILITY OR RESPONSIBILITY FOR THE ACCURACY,
51     COMPLETENESS, OR USEFULNESS OF ANY INFORMATION, APPARATUS,
52     PRODUCT, OR PROCESS DISCLOSED, OR REPRESENTS THAT ITS USE WOULD
53     NOT INFRINGE PRIVATELY OWNED RIGHTS.
54
55***************************************************************************/
56/* sym.c
57
58    Implementation dependent routines for using symtab_gen.c
59    in N32 .
60
61*/
62
63#include <stdio.h>
64#include "sym.h"
65
66extern sym_nodeptr symget() ;
67
68static char ** symtab ;  /* 2-19-90 */
69
70int
71sym_init() /* 2-19-90, initialize symbol table package */
72{
73    create_ht( &symtab ) ;
74    if (symtab == NULL) 
75    {
76        fprintf(stderr,"init_sym(): could not create hash table") ;
77        exit(1) ;
78    }
79    return(0) ;
80}
81
82sym_nodeptr
83sym_add( name )
84char * name ;
85{
86    sym_nodeptr new_sym_node(); 
87    char **node_name() ;
88    sym_nodeptr *node_next() ;
89    return( symget( name, new_sym_node, node_name, node_next, symtab, 1 ) ) ;
90}
91
92sym_nodeptr
93sym_get( name )
94char * name ;
95{
96    sym_nodeptr new_sym_node(); 
97    char **node_name() ;
98    sym_nodeptr *node_next() ;
99    return( symget( name, new_sym_node, node_name, node_next, symtab, 0 ) ) ;
100}
101
102sym_nodeptr
103new_sym_node()
104{
105    void * malloc() ;
106    sym_nodeptr p ;
107    p = (sym_nodeptr) malloc( sizeof( struct sym_node ) ) ;
108    p->name = NULL ;
109    p->next = NULL ;
110
111    return( p ) ;
112}
113
114char **
115node_name(p)
116sym_nodeptr p ;
117{
118    char ** x ;
119    x = &(p->name) ;
120    return( x ) ;
121}
122
123sym_nodeptr *
124node_next(p)
125sym_nodeptr p ;
126{
127    sym_nodeptr *x ;
128    x = &(p->next) ;
129    return( x ) ;
130}
131
132int
133show_entry(x)
134sym_nodeptr x ;
135{
136  int i ;
137  if ( x == NULL ) return(0) ;
138  printf("Symbol table entry:\n") ;
139  printf("lexeme %s\n", x->name ) ;
140  printf("   dim %s\n", (x->dim==1?"M":(x->dim==2?"N":"O")) ) ;
141  printf(" ndims %d\n", x->ndims ) ;
142  for ( i = 0 ; i < x->ndims && i < 7 ; i++ )
143    printf(" dim %d -> %s\n",i,(x->dims[i]==1?"M":(x->dims[i]==2?"N":"O")) ) ;
144  return(0) ;
145}
146
147/* MEMORY LEAK !!!! -- this just abandons the old table and leaves on the heap. */
148/* The registry mechanism is not a long-running program and is not apt to
149   run into memory problems.  Might want to fix this anyway, though, someday. */
150int
151sym_forget() 
152{
153  create_ht( &symtab ) ;
154  if (symtab == NULL)
155  {
156      fprintf(stderr,"init_sym(): could not create hash table") ;
157      exit(1) ;
158  }
159  return(0) ;
160}
161
Note: See TracBrowser for help on using the repository browser.