diff options
Diffstat (limited to 'erts/etc/common')
| -rw-r--r-- | erts/etc/common/Makefile.in | 11 | ||||
| -rw-r--r-- | erts/etc/common/ct_run.c | 11 | ||||
| -rw-r--r-- | erts/etc/common/dialyzer.c | 12 | ||||
| -rw-r--r-- | erts/etc/common/erlc.c | 16 | ||||
| -rw-r--r-- | erts/etc/common/erlexec.c | 76 | ||||
| -rw-r--r-- | erts/etc/common/escript.c | 12 | ||||
| -rw-r--r-- | erts/etc/common/etc_common.h | 65 | ||||
| -rw-r--r-- | erts/etc/common/typer.c | 12 | 
8 files changed, 113 insertions, 102 deletions
| diff --git a/erts/etc/common/Makefile.in b/erts/etc/common/Makefile.in index 5b1b9119ce..1f35cef669 100644 --- a/erts/etc/common/Makefile.in +++ b/erts/etc/common/Makefile.in @@ -56,7 +56,7 @@ ERTS_INCL = -I$(ERL_TOP)/erts/include \  CC        = @CC@  WFLAGS    = @WFLAGS@ -CFLAGS    = @CFLAGS@ @DEFS@ $(TYPE_FLAGS) @WFLAGS@ -I$(SYSDIR) -I$(EMUDIR) \ +CFLAGS    = @CFLAGS@ @DEFS@ $(TYPE_FLAGS) @WFLAGS@ -I$(SYSOSDIR) -I$(EMUDIR) -I. \              -I$(COMSYSDIR) $(ERTS_INCL) -DOTP_SYSTEM_VERSION=\"$(SYSTEM_VSN)\"  LD        = @LD@  LIBS      = @LIBS@ @@ -69,9 +69,9 @@ endif  ifeq ($(TARGET),win32)  ifeq ($(TYPE),debug) -CFLAGS = $(subst -O2,-g,@CFLAGS@ @DEFS@ $(TYPE_FLAGS) @WFLAGS@ -I$(SYSDIR) \ -            -I$(EMUDIR) -I$(COMSYSDIR) $(ERTS_INCL) \ -            -DOTP_SYSTEM_VERSION=\"$(SYSTEM_VSN)\") +CFLAGS = $(subst -O2,-g,@CFLAGS@ @DEFS@ $(TYPE_FLAGS) @WFLAGS@ -I$(SYSOSDIR) \ +	-I$(EMUDIR) -I$(COMSYSDIR) $(ERTS_INCL) \ +	-DOTP_SYSTEM_VERSION=\"$(SYSTEM_VSN)\")  LDFLAGS += -g  endif  endif @@ -81,7 +81,8 @@ OBJDIR    = $(ERL_TOP)/erts/obj$(TYPEMARKER)/$(TARGET)  EMUDIR    = $(ERL_TOP)/erts/emulator/beam  COMSYSDIR = $(ERL_TOP)/erts/emulator/sys/common  EMUOSDIR  = $(ERL_TOP)/erts/emulator/@ERLANG_OSTYPE@ -SYSDIR    = $(ERL_TOP)/erts/emulator/sys/@ERLANG_OSTYPE@ +SYSDIR    = $(ERL_TOP)/erts/emulator/sys/common +SYSOSDIR  = $(ERL_TOP)/erts/emulator/sys/@ERLANG_OSTYPE@  DRVDIR    = $(ERL_TOP)/erts/emulator/drivers/@ERLANG_OSTYPE@  UXETC     = ../unix  WINETC	  = ../win32 diff --git a/erts/etc/common/ct_run.c b/erts/etc/common/ct_run.c index 6639c83778..efa7ac3493 100644 --- a/erts/etc/common/ct_run.c +++ b/erts/etc/common/ct_run.c @@ -20,16 +20,7 @@  /*   * Purpose: Common Test front-end.   */ -#ifdef HAVE_CONFIG_H -#  include "config.h" -#endif - -#include "sys.h" -#ifdef __WIN32__ -#include <winbase.h> -#endif - -#include <ctype.h> +#include "etc_common.h"  #define NO 0  #define YES 1 diff --git a/erts/etc/common/dialyzer.c b/erts/etc/common/dialyzer.c index c8d977f6de..b45d5c7ca7 100644 --- a/erts/etc/common/dialyzer.c +++ b/erts/etc/common/dialyzer.c @@ -20,16 +20,8 @@  /*   * Purpose: Dialyzer front-end.   */ -#ifdef HAVE_CONFIG_H -#  include "config.h" -#endif - -#include "sys.h" -#ifdef __WIN32__ -#include <winbase.h> -#endif -#include <ctype.h> +#include "etc_common.h"  #define NO 0  #define YES 1 @@ -263,7 +255,7 @@ int main(int argc, char** argv)      }      PUSH("+B"); -    PUSH2("-boot", "start_clean"); +    PUSH2("-boot", "no_dot_erlang");      PUSH3("-run", "dialyzer", "plain_cl");      PUSH("-extra"); diff --git a/erts/etc/common/erlc.c b/erts/etc/common/erlc.c index cbbd2a37cd..aa99c69100 100644 --- a/erts/etc/common/erlc.c +++ b/erts/etc/common/erlc.c @@ -20,19 +20,7 @@  /*   * Purpose: Common compiler front-end.   */ -#ifdef HAVE_CONFIG_H -#  include "config.h" -#endif - -#include "sys.h" -#ifdef __WIN32__ -#include <winbase.h> -/* FIXE ME config_win32.h? */ -#define HAVE_STRERROR 1 -#define snprintf _snprintf -#endif - -#include <ctype.h> +#include "etc_common.h"  #define NO 0  #define YES 1 @@ -246,7 +234,7 @@ int main(int argc, char** argv)      PUSH("+A0");      PUSH("-noinput");      PUSH2("-mode", "minimal"); -    PUSH2("-boot", "start_clean"); +    PUSH2("-boot", "no_dot_erlang");      PUSH3("-s", "erl_compile", "compile_cmdline");      PUSH("-extra"); diff --git a/erts/etc/common/erlexec.c b/erts/etc/common/erlexec.c index eaa94cd5e4..08e326b33b 100644 --- a/erts/etc/common/erlexec.c +++ b/erts/etc/common/erlexec.c @@ -23,14 +23,9 @@   * additions required for Windows NT.   */ -#ifdef HAVE_CONFIG_H -#  include "config.h" -#endif +#include "etc_common.h" -#include "sys.h"  #include "erl_driver.h" -#include <stdlib.h> -#include <stdarg.h>  #include "erl_misc_utils.h"  #ifdef __WIN32__ @@ -195,9 +190,7 @@ void error(char* format, ...);   * Local functions.   */ -#if !defined(ERTS_HAVE_SMP_EMU) || !defined(ERTS_HAVE_PLAIN_EMU)  static void usage_notsup(const char *switchname, const char *alt); -#endif  static char **build_args_from_env(char *env_var);  static char **build_args_from_string(char *env_var);  static void initial_argv_massage(int *argc, char ***argv); @@ -245,7 +238,7 @@ static int verbose = 0;		/* If non-zero, print some extra information. */  static int start_detached = 0;	/* If non-zero, the emulator should be  				 * started detached (in the background).  				 */ -static int start_smp_emu = 0;   /* Start the smp emulator. */ +static int start_smp_emu = 1;   /* Start the smp emulator. */  static const char* emu_type = 0; /* Type of emulator (lcnt, valgrind, etc) */  #ifdef __WIN32__ @@ -468,10 +461,6 @@ int main(int argc, char **argv)       * Construct the path of the executable.       */      cpuinfo = erts_cpu_info_create(); -    /* '-smp auto' is default */  -#ifdef ERTS_HAVE_SMP_EMU -    start_smp_emu = 1; -#endif  #if defined(__WIN32__) && defined(WIN32_ALWAYS_DEBUG)      emu_type = "debug"; @@ -503,23 +492,13 @@ int main(int argc, char **argv)  		    i++;  		smp_enable:                      ; -#if !defined(ERTS_HAVE_SMP_EMU) -		    usage_notsup("-smp enable", ""); -#endif  		} else if (strcmp(argv[i+1], "disable") == 0) {  		    i++;  		smp_disable: -#ifdef ERTS_HAVE_PLAIN_EMU -                    start_smp_emu = 0; -#else                      usage_notsup("-smp disable", " Use \"+S 1\" instead."); -#endif  		} else {  		smp:                      ; -#if !defined(ERTS_HAVE_SMP_EMU) -		    usage_notsup("-smp", ""); -#endif  		}  	    } else if (strcmp(argv[i], "-smpenable") == 0) {  		goto smp_enable; @@ -832,6 +811,28 @@ int main(int argc, char **argv)  		      add_Eargs(argv[i+1]);  		      i++;  		      break; +		  case 'I': +                      if (argv[i][2] == 'O' && (argv[i][3] == 't' || argv[i][3] == 'p')) { +                          if (argv[i][4] != '\0') +                              goto the_default; +                          argv[i][0] = '-'; +                          add_Eargs(argv[i]); +                          add_Eargs(argv[i+1]); +                          i++; +                          break; +                      } +                      if (argv[i][2] == 'O' && argv[i][3] == 'P' && +                          (argv[i][4] == 't' || argv[i][4] == 'p')) { +                          if (argv[i][5] != '\0') +                              goto the_default; +                          argv[i][0] = '-'; +                          add_Eargs(argv[i]); +                          add_Eargs(argv[i+1]); +                          i++; +                          break; +                      } +                      usage(argv[i]); +                      break;  		  case 'S':  		      if (argv[i][2] == 'P') {  			  if (argv[i][3] != '\0') @@ -887,8 +888,8 @@ int main(int argc, char **argv)  		  case 'c':  		      argv[i][0] = '-';  		      if (argv[i][2] == '\0' && i+1 < argc) { -			  if (sys_strcmp(argv[i+1], "true") == 0 -			      || sys_strcmp(argv[i+1], "false") == 0) { +			  if (strcmp(argv[i+1], "true") == 0 +			      || strcmp(argv[i+1], "false") == 0) {  			      add_Eargs(argv[i]);  			      add_Eargs(argv[i+1]);  			      i++; @@ -1160,15 +1161,6 @@ usage_aux(void)  #ifdef __WIN32__  	  "[-start_erl [datafile]] "  #endif -	  "[-smp [auto" -#ifdef ERTS_HAVE_SMP_EMU -	  "|enable" -#endif -#ifdef ERTS_HAVE_PLAIN_EMU -	  "|disable" -#endif -	  "]" -	  "] "  	  "[-make] [-man [manopts] MANPAGE] [-x] [-emu_args] [-start_epmd BOOLEAN] "  	  "[-args_file FILENAME] [+A THREADS] [+a SIZE] [+B[c|d|i]] [+c [BOOLEAN]] "  	  "[+C MODE] [+h HEAP_SIZE_OPTION] [+K BOOLEAN] " @@ -1189,14 +1181,12 @@ usage(const char *switchname)      usage_aux();  } -#if !defined(ERTS_HAVE_SMP_EMU) || !defined(ERTS_HAVE_PLAIN_EMU)  static void  usage_notsup(const char *switchname, const char *alt)  {      fprintf(stderr, "Argument \'%s\' not supported.%s\n", switchname, alt);      usage_aux();  } -#endif  static void  usage_format(char *format, ...) @@ -2195,18 +2185,18 @@ static WCHAR *utf8_to_utf16(unsigned char *bytes)      res = target = emalloc((num + 1) * sizeof(WCHAR));      while (*bytes) {  	if (((*bytes) & ((unsigned char) 0x80)) == 0) { -	    unipoint = (Uint) *bytes; +	    unipoint = (unsigned int) *bytes;  	    ++bytes;  	} else if (((*bytes) & ((unsigned char) 0xE0)) == 0xC0) {  	    unipoint =  -		(((Uint) ((*bytes) & ((unsigned char) 0x1F))) << 6) | -		((Uint) (bytes[1] & ((unsigned char) 0x3F))); 	 +		(((unsigned int) ((*bytes) & ((unsigned char) 0x1F))) << 6) | +		((unsigned int) (bytes[1] & ((unsigned char) 0x3F)));  	    bytes += 2;  	} else if (((*bytes) & ((unsigned char) 0xF0)) == 0xE0) {  	    unipoint =  -		(((Uint) ((*bytes) & ((unsigned char) 0xF))) << 12) | -		(((Uint) (bytes[1] & ((unsigned char) 0x3F))) << 6) | -		((Uint) (bytes[2] & ((unsigned char) 0x3F))); +		(((unsigned int) ((*bytes) & ((unsigned char) 0xF))) << 12) | +		(((unsigned int) (bytes[1] & ((unsigned char) 0x3F))) << 6) | +		((unsigned int) (bytes[2] & ((unsigned char) 0x3F)));  	    if (unipoint > 0xFFFF) {  		 unipoint = (unsigned int) '?';  	    } @@ -2225,7 +2215,7 @@ static WCHAR *utf8_to_utf16(unsigned char *bytes)  static int put_utf8(WCHAR ch, unsigned char *target, int sz, int *pos)  { -    Uint x = (Uint) ch; +    unsigned int x = (unsigned int) ch;      if (x < 0x80) {      if (*pos >= sz) {  	return -1; diff --git a/erts/etc/common/escript.c b/erts/etc/common/escript.c index 9cd5dd3fab..d739d21f12 100644 --- a/erts/etc/common/escript.c +++ b/erts/etc/common/escript.c @@ -20,16 +20,8 @@  /*   * Purpose: escript front-end.   */ -#ifdef HAVE_CONFIG_H -#  include "config.h" -#endif - -#include "sys.h" -#ifdef __WIN32__ -#include <winbase.h> -#endif -#include <ctype.h> +#include "etc_common.h"  static int debug = 0;		/* Bit flags for debug printouts. */ @@ -529,7 +521,7 @@ main(int argc, char** argv)      free_env_val(env);      PUSH("+B"); -    PUSH2("-boot", "start_clean"); +    PUSH2("-boot", "no_dot_erlang");      PUSH("-noshell");      /* diff --git a/erts/etc/common/etc_common.h b/erts/etc/common/etc_common.h new file mode 100644 index 0000000000..3f26064a9e --- /dev/null +++ b/erts/etc/common/etc_common.h @@ -0,0 +1,65 @@ +/* + * %CopyrightBegin% + * + * Copyright Ericsson AB 2017. All Rights Reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + *     http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * %CopyrightEnd% + */ +/* + * Purpose: common includes for all etc programs + */ +#ifdef HAVE_CONFIG_H +#  include "config.h" +#endif + +#if !defined(__WIN32__) +#  include <dirent.h> +#  include <limits.h> +#  include <sys/stat.h> +#  include <sys/types.h> +#  include <unistd.h> +#else +#  include <windows.h> +#  include <io.h> +#  include <winbase.h> +#  include <process.h> +#endif + +#include <errno.h> +#include <fcntl.h> +#include <stdarg.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <ctype.h> + +/* + * Make sure that MAXPATHLEN is defined. + */ +#ifndef MAXPATHLEN +#   ifdef PATH_MAX +#       define MAXPATHLEN PATH_MAX +#   else +#       define MAXPATHLEN 2048 +#   endif +#endif + +#include "erl_printf.h" + +#ifdef __WIN32__ +/* FIXE ME config_win32.h? */ +#define HAVE_STRERROR 1 +#define snprintf _snprintf +#endif diff --git a/erts/etc/common/typer.c b/erts/etc/common/typer.c index 6bae9f96b7..f13135d883 100644 --- a/erts/etc/common/typer.c +++ b/erts/etc/common/typer.c @@ -20,16 +20,8 @@  /*   * Purpose: Typer front-end.   */ -#ifdef HAVE_CONFIG_H -#  include "config.h" -#endif - -#include "sys.h" -#ifdef __WIN32__ -#include <winbase.h> -#endif -#include <ctype.h> +#include "etc_common.h"  #define NO 0  #define YES 1 @@ -185,7 +177,7 @@ main(int argc, char** argv)      }      PUSH("+B"); -    PUSH2("-boot", "start_clean"); +    PUSH2("-boot", "no_dot_erlang");      PUSH3("-run", "typer", "start");      PUSH("-extra"); | 
