This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Remove old Linux+threads segfault degugging kludge.
[perl5.git] / miniperlmain.c
index 44c3d71..190c7fb 100644 (file)
@@ -2,50 +2,71 @@
  * "The Road goes ever on and on, down from the door where it began."
  */
 
-#include "INTERN.h"
+#ifdef OEMVS
+#pragma runopts(HEAP(1M,32K,ANYWHERE,KEEP,8K,4K))
+#endif
+
+
+#include "EXTERN.h"
 #include "perl.h"
 
 static void xs_init _((void));
 static PerlInterpreter *my_perl;
 
-/* This value may be raised by extensions for testing purposes */
-int perl_destruct_level = 0; /* 0=none, 1=full, 2=full with checks */
-
 int
+#ifdef CAN_PROTOTYPE
+main(int argc, char **argv, char **env)
+#else
 main(argc, argv, env)
 int argc;
 char **argv;
 char **env;
+#endif
 {
     int exitstatus;
 
-#ifdef VMS
-    getredirection(&argc,&argv);
+#ifdef PERL_GLOBAL_STRUCT
+#define PERLVAR(var,type) /**/
+#define PERLVARI(var,type,init) Perl_Vars.var = init;
+#define PERLVARIC(var,type,init) Perl_Vars.var = init;
+#include "perlvars.h"
+#undef PERLVAR
+#undef PERLVARI
+#undef PERLVARIC
 #endif
 
+    PERL_SYS_INIT(&argc,&argv);
+
+    perl_init_i18nl10n(1);
+
     if (!do_undump) {
        my_perl = perl_alloc();
        if (!my_perl)
            exit(1);
        perl_construct( my_perl );
+       perl_destruct_level = 0;
     }
 
-    exitstatus = perl_parse( my_perl, xs_init, argc, argv, env );
-    if (exitstatus)
-       exit( exitstatus );
-
-    exitstatus = perl_run( my_perl );
+    exitstatus = perl_parse( my_perl, xs_init, argc, argv, (char **) NULL );
+    if (!exitstatus) {
+       exitstatus = perl_run( my_perl );
+    }
 
-    perl_destruct( my_perl, perl_destruct_level );
+    perl_destruct( my_perl );
     perl_free( my_perl );
 
+    PERL_SYS_TERM();
+
     exit( exitstatus );
+    return exitstatus;
 }
 
 /* Register any extra external extensions */
 
+/* Do not delete this line--writemain depends on it */
+
 static void
-xs_init()
+xs_init(void)
 {
-    /* Do not delete this line--writemain depends on it */
+  dXSUB_SYS;
 }