1
  
2
  
3
  
4
  
5
  
6
  
7
  
8
  
9
  
10
  
11
  
12
  
13
  
14
  
15
  
16
  
17
  
18
  
19
  
20
  
21
  
22
  
23
  
24
  
25
  
26
  
27
  
28
  
29
  
30
  
31
  
32
  
33
  
34
  
35
  
36
  
37
  
38
  
39
  
40
  
41
  
42
  
43
  
44
  
45
  
46
  
47
  
48
  
49
  
50
  
51
  
52
  
53
  
54
  
55
  
56
  
57
  
58
  
59
  
60
  
61
  
62
  
63
  
64
  
65
  
66
  
67
  
68
  
69
  
70
  
71
  
72
  
73
  
74
  
75
  
76
  
77
  
78
  
79
  
80
  
81
  
82
  
83
  
84
  
85
  
86
  
87
  
88
  
89
  
90
  
91
  
92
  
93
  
94
  
95
  
96
  
97
  
98
  
99
  
100
  
101
  
102
  
103
  
104
  
105
  
106
  
107
  
108
  
109
  
110
  
111
  
112
  
113
  
114
  
115
  
116
  
117
  
118
  
119
  
120
  
/* 
|| This file is part of Pike. For copyright information see COPYRIGHT. 
|| Pike is distributed under GPL, LGPL and MPL. See the file COPYING 
|| for more information. 
|| $Id: module.c,v 1.25 2004/04/14 19:07:31 grubba Exp $ 
*/ 
 
#include "global.h" 
#include "module.h" 
#include "pike_macros.h" 
#include "pike_error.h" 
#include "builtin_functions.h" 
#include "main.h" 
#include "svalue.h" 
#include "interpret.h" 
#include "stralloc.h" 
#include "object.h" 
#include "mapping.h" 
#include "program_id.h" 
#include "lex.h" 
 
#include "modules/modlist_headers.h" 
#include "post_modules/modlist_headers.h" 
 
RCSID("$Id: module.c,v 1.25 2004/04/14 19:07:31 grubba Exp $"); 
 
/* Define this to trace the initialization and cleanup of static modules. */ 
/* #define TRACE_MODULE */ 
 
#if defined(TRACE_MAIN) || defined(TRACE_MODULE) 
#define TRACE(X)    fprintf X 
#else /* !TRACE_MAIN */ 
#define TRACE(X) 
#endif /* TRACE_MAIN */ 
 
typedef void (*modfun)(void); 
 
struct static_module 
{ 
  char *name; 
  modfun init; 
  modfun exit; 
}; 
 
static struct static_module module_list[] = { 
  { "Builtin", low_init_main, low_exit_main } 
#include "modules/modlist.h" 
#include "post_modules/modlist.h" 
}; 
 
void init_modules(void) 
{ 
  struct program *p = NULL; 
  unsigned int e; 
  struct lex save_lex; 
 
  save_lex = lex; 
  lex.current_line=1; 
  lex.current_file=make_shared_string("-"); 
 
  start_new_program(); 
  Pike_compiler->new_program->id=PROG___BUILTIN_ID; 
 
  for(e=0;e<NELEM(module_list);e++) 
  { 
    JMP_BUF recovery; 
    if (!p) { 
      start_new_program(); 
      p = Pike_compiler.new_program; 
    } 
    if(SETJMP(recovery)) { 
      /* FIXME: We could loop here until we find p. */ 
      free_program(end_program()); 
      p = NULL; 
      call_handle_error(); 
    } else { 
      TRACE((stderr, "Initializing static module #%d: \"%s\"...\n", 
             e, module_list[e].name)); 
      module_list[e].init(); 
      if (Pike_compiler.new_program->num_identifier_references) { 
        debug_end_class(module_list[e].name,strlen(module_list[e].name),0); 
        p = NULL; 
      } else { 
        /* No identifier references -- Disabled module. */ 
      } 
    } 
    UNSETJMP(recovery); 
  } 
  if (p) free_program(end_program()); 
  push_text("_static_modules"); 
  push_object(low_clone(p=end_program())); 
  f_add_constant(2); 
  free_program(p); 
  free_string(lex.current_file); 
  lex = save_lex; 
 
  init_main(); 
} 
 
void exit_modules(void) 
{ 
  JMP_BUF recovery; 
  int e; 
 
  exit_main(); 
 
  for(e=NELEM(module_list)-1;e>=0;e--) 
  { 
    if(SETJMP(recovery)) 
      call_handle_error(); 
    else { 
      TRACE((stderr, "Exiting static module #%d: \"%s\"...\n", 
             e, module_list[e].name)); 
      module_list[e].exit(); 
    } 
    UNSETJMP(recovery); 
  } 
}