aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2011-08-19 18:19:22 +0000
committerChristopher Faylor <me@cgf.cx>2011-08-19 18:19:22 +0000
commitc8a66289e45bbbc915a92f443745e3f8dea2947e (patch)
tree19e4390ecaca78b43b06547104b3ffcc1aba6dc9
parent34dc27f95d2a95c5d978ac747677cfd8a195fea5 (diff)
downloadnewlib-c8a66289e45bbbc915a92f443745e3f8dea2947e.zip
newlib-c8a66289e45bbbc915a92f443745e3f8dea2947e.tar.gz
newlib-c8a66289e45bbbc915a92f443745e3f8dea2947e.tar.bz2
* dtable.cc: Mark some const variables as static.
* environ.cc (conv_start_chars): Move to shared cygwin region and initialize at compile time. (match_first_char): New generic function for querying conv_start_chars. (posify_maybe): Rename from posify. (environ_init): Remove conv_envvars initialization. Don't check conv_start_chars, just allow posify_maybe to make the decision. * fhandler_console.cc (__vt100_conv): Fix formatting. Mark as const.
-rw-r--r--winsup/cygwin/ChangeLog11
-rw-r--r--winsup/cygwin/dtable.cc8
-rw-r--r--winsup/cygwin/environ.cc62
-rw-r--r--winsup/cygwin/fhandler_console.cc2
4 files changed, 65 insertions, 18 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index f4af08b..d4fb55f 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,14 @@
+2011-08-19 Christopher Faylor <me.cygwin2011@cgf.cx>
+
+ * dtable.cc: Mark some const variables as static.
+ * environ.cc (conv_start_chars): Move to shared cygwin region and
+ initialize at compile time.
+ (match_first_char): New generic function for querying conv_start_chars.
+ (posify_maybe): Rename from posify.
+ (environ_init): Remove conv_envvars initialization. Don't check
+ conv_start_chars, just allow posify_maybe to make the decision.
+ * fhandler_console.cc (__vt100_conv): Fix formatting. Mark as const.
+
2011-08-19 Corinna Vinschen <corinna@vinschen.de>
* fhandler_console.cc (fhandler_console::read): Recognize backspace key
diff --git a/winsup/cygwin/dtable.cc b/winsup/cygwin/dtable.cc
index d5ae001..d780136 100644
--- a/winsup/cygwin/dtable.cc
+++ b/winsup/cygwin/dtable.cc
@@ -38,12 +38,12 @@ static const NO_COPY DWORD std_consts[] = {STD_INPUT_HANDLE, STD_OUTPUT_HANDLE,
static bool handle_to_fn (HANDLE, char *);
#define WCLEN(x) ((sizeof (x) / sizeof (WCHAR)) - 1)
-char unknown_file[] = "some disk file";
-const WCHAR DEV_NULL[] = L"\\Device\\Null";
+static const char unknown_file[] = "some disk file";
+static const WCHAR DEV_NULL[] = L"\\Device\\Null";
static const WCHAR DEV_SOCKET[] = L"\\Device\\Afd";
-const WCHAR DEVICE_PREFIX[] = L"\\device\\";
-const size_t DEVICE_PREFIX_LEN WCLEN (DEVICE_PREFIX);
+static const WCHAR DEVICE_PREFIX[] = L"\\device\\";
+static const size_t DEVICE_PREFIX_LEN WCLEN (DEVICE_PREFIX);
static const WCHAR DEV_NAMED_PIPE[] = L"\\Device\\NamedPipe\\";
static const size_t DEV_NAMED_PIPE_LEN = WCLEN (DEV_NAMED_PIPE);
diff --git a/winsup/cygwin/environ.cc b/winsup/cygwin/environ.cc
index 3a075f8..9e83a78 100644
--- a/winsup/cygwin/environ.cc
+++ b/winsup/cygwin/environ.cc
@@ -268,7 +268,49 @@ static win_env conv_envvars[] =
{NULL, 0, NULL, NULL, 0, 0}
};
-static unsigned char conv_start_chars[256] = {0};
+#define WC ((unsigned char) 1)
+/* Note: You *must* fill in this array setting the ordinal value of the first
+ character of the above environment variable names to 1.
+ This table is intended to speed up lookup of these variables. */
+
+static const unsigned char conv_start_chars[256]
+ __attribute__((section (".cygwin_dll_common"), shared)) =
+ {
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+/* A B C D E F G */
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ /* 72 */
+/* H I J K L M N O */
+ WC, 0, 0, 0, WC, 0, 0, 0,
+ /* 80 */
+/* P Q R S T U V W */
+ WC, 0, 0, 0, WC, 0, 0, 0,
+ /* 88 */
+/* x Y Z */
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ /* 96 */
+/* a b c d e f g */
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ /* 104 */
+/* h i j k l m n o */
+ WC, 0, 0, 0, WC, 0, 0, 0,
+ /* 112 */
+/* p q r s t u v w */
+ WC, 0, 0, 0, WC, 0, 0, 0,
+ };
+
+static inline char
+match_first_char (const char *s, unsigned char m)
+{
+ return conv_start_chars[(unsigned) *s] & m;
+}
struct win_env&
win_env::operator = (struct win_env& x)
@@ -332,7 +374,7 @@ win_env::add_cache (const char *in_posix, const char *in_native)
win_env * __stdcall
getwinenv (const char *env, const char *in_posix, win_env *temp)
{
- if (!conv_start_chars[(unsigned char)*env])
+ if (!match_first_char (env, WC))
return NULL;
for (int i = 0; conv_envvars[i].name != NULL; i++)
@@ -359,8 +401,8 @@ getwinenv (const char *env, const char *in_posix, win_env *temp)
/* Convert windows path specs to POSIX, if appropriate.
*/
-static void __stdcall
-posify (char **here, const char *value, char *outenv)
+inline static void
+posify_maybe (char **here, const char *value, char *outenv)
{
char *src = *here;
win_env *conv;
@@ -653,6 +695,7 @@ static struct renv {
{ NL("WINDIR=") } // 22
};
#define RENV_SIZE (sizeof (renv_arr) / sizeof (renv_arr[0]))
+
/* Set of first characters of the above list of variables. */
static const char idx_arr[] = "ACHNOPSTW";
/* Index into renv_arr at which the variables with this specific character
@@ -729,13 +772,6 @@ environ_init (char **envp, int envc)
if (efault.faulted ())
api_fatal ("internal error reading the windows environment - too many environment variables?");
- if (!conv_start_chars[0])
- for (int i = 0; conv_envvars[i].name != NULL; i++)
- {
- conv_start_chars[(int) cyg_tolower (conv_envvars[i].name[0])] = 1;
- conv_start_chars[(int) cyg_toupper (conv_envvars[i].name[0])] = 1;
- }
-
char *tmpbuf = tp.t_get ();
got_something_from_registry = regopt (L"default", tmpbuf);
if (myself->progname[0])
@@ -795,8 +831,8 @@ environ_init (char **envp, int envc)
sawTERM = 1;
else if (*newp == 'C' && strncmp (newp, "CYGWIN=", 7) == 0)
parse_options (newp + 7);
- if (*eq && conv_start_chars[(unsigned char) envp[i][0]])
- posify (envp + i, *++eq ? eq : --eq, tmpbuf);
+ if (*eq)
+ posify_maybe (envp + i, *++eq ? eq : --eq, tmpbuf);
debug_printf ("%p: %s", envp[i], envp[i]);
}
diff --git a/winsup/cygwin/fhandler_console.cc b/winsup/cygwin/fhandler_console.cc
index 6364e64..b7e4e26 100644
--- a/winsup/cygwin/fhandler_console.cc
+++ b/winsup/cygwin/fhandler_console.cc
@@ -1208,7 +1208,7 @@ fhandler_console::cursor_get (int *x, int *y)
/* VT100 line drawing graphics mode maps `abcdefghijklmnopqrstuvwxyz{|}~ to
graphical characters */
-static wchar_t __vt100_conv [31] = {
+static const wchar_t __vt100_conv[31] = {
0x25C6, /* Black Diamond */
0x2592, /* Medium Shade */
0x2409, /* Symbol for Horizontal Tabulation */