a change in /etc.
* cygheap.h (struct init_cygheap): Add member `etc_changed_h'
and method `etc_changed'.
* grp.cc (enum grp_state): Eliminate.
(class grp_check): Ditto.
(group_state): Define as `class pwdgrp_check'.
(parse_grp): Remeber path and modification time of /etc/group file.
* passwd.cc (enum_pwd_state): Eliminate.
(class pwd_check): Ditto.
(passwd_state): Define as `class pwdgrp_check'.
(read_etc_passwd): Remember path and modification time of /etc/passwd
file.
* pwdgrp.h: New file.
(enum pwdgrp_state): Substitutes `pwd_state' and `grp_state'.
(class pwdgrp_check): Substitutes `pwd_check' and `grp_check'.
+Sun Sep 9 18:36:00 2001 Corinna Vinschen <corinna@vinschen.de>
+ Christopher Faylor <cgf@cygnus.com>
+
+ * cygheap.cc (init_cygheap::etc_changed): New method to signal
+ a change in /etc.
+ * cygheap.h (struct init_cygheap): Add member `etc_changed_h'
+ and method `etc_changed'.
+ * grp.cc (enum grp_state): Eliminate.
+ (class grp_check): Ditto.
+ (group_state): Define as `class pwdgrp_check'.
+ (parse_grp): Remeber path and modification time of /etc/group file.
+ * passwd.cc (enum_pwd_state): Eliminate.
+ (class pwd_check): Ditto.
+ (passwd_state): Define as `class pwdgrp_check'.
+ (read_etc_passwd): Remember path and modification time of /etc/passwd
+ file.
+ * pwdgrp.h: New file.
+ (enum pwdgrp_state): Substitutes `pwd_state' and `grp_state'.
+ (class pwdgrp_check): Substitutes `pwd_check' and `grp_check'.
+
Sun Sep 9 14:31:00 2001 Corinna Vinschen <corinna@vinschen.de>
* include/cygwin/version.h: Bump API minor version to 45 according
#include "security.h"
#include "fhandler.h"
#include "dtable.h"
+#include "path.h"
#include "cygheap.h"
#include "child_info.h"
#include "heap.h"
return p;
}
+bool
+init_cygheap::etc_changed ()
+{
+ bool res = 0;
+
+ if (!etc_changed_h)
+ {
+ path_conv pwd ("/etc");
+ etc_changed_h = FindFirstChangeNotification (pwd, FALSE,
+ FILE_NOTIFY_CHANGE_LAST_WRITE);
+ if (etc_changed_h == INVALID_HANDLE_VALUE)
+ system_printf ("Can't open /etc for checking, %E", (char *) pwd,
+ etc_changed_h);
+ else if (!DuplicateHandle (hMainProc, etc_changed_h, hMainProc,
+ &etc_changed_h, 0, TRUE,
+ DUPLICATE_SAME_ACCESS | DUPLICATE_CLOSE_SOURCE))
+ {
+ system_printf ("Can't inherit /etc handle, %E", (char *) pwd,
+ etc_changed_h);
+ etc_changed_h = INVALID_HANDLE_VALUE;
+ }
+ }
+
+ if (etc_changed_h != INVALID_HANDLE_VALUE
+ && WaitForSingleObject (etc_changed_h, 0) == WAIT_OBJECT_0)
+ {
+ (void) FindNextChangeNotification (etc_changed_h);
+ res = 1;
+ }
+
+ return res;
+}
+
void
cygheap_root::set (const char *posix, const char *native)
{
mode_t umask;
HANDLE shared_h;
HANDLE console_h;
+ HANDLE etc_changed_h;
cwdstuff cwd;
dtable fdtab;
+
+ bool etc_changed ();
};
#define CYGHEAPSIZE (sizeof (init_cygheap) + (4000 * sizeof (fhandler_union)) + (2 * 65536))
#include "path.h"
#include "cygheap.h"
#include "cygerrno.h"
+#include "pwdgrp.h"
/* Read /etc/group only once for better performance. This is done
on the first call that needs information from it. */
static int grp_pos = 0;
#endif
-/* Set to loaded when /etc/passwd has been read in by read_etc_passwd ().
- Set to emulated if passwd is emulated. */
-/* Functions in this file need to check the value of passwd_state
- and read in the password file if it isn't set. */
-enum grp_state {
- uninitialized = 0,
- initializing,
- emulated,
- loaded
-};
-class grp_check {
- grp_state state;
- FILETIME last_modified;
- char grp_w32[MAX_PATH];
-
-public:
- grp_check () : state (uninitialized)
- {
- last_modified.dwLowDateTime = last_modified.dwHighDateTime = 0;
- grp_w32[0] = '\0';
- }
- operator grp_state ()
- {
- HANDLE h;
- WIN32_FIND_DATA data;
-
- if (!grp_w32[0]) /* First call. */
- {
- path_conv g ("/etc/group", PC_SYM_FOLLOW | PC_FULL);
- if (!g.error)
- strcpy (grp_w32, g.get_win32 ());
- }
-
- if ((h = FindFirstFile (grp_w32, &data)) != INVALID_HANDLE_VALUE)
- {
- if (CompareFileTime (&data.ftLastWriteTime, &last_modified) > 0)
- {
- state = uninitialized;
- last_modified = data.ftLastWriteTime;
- }
- FindClose (h);
- }
- return state;
- }
- void operator = (grp_state nstate)
- {
- state = nstate;
- }
-};
-
-static grp_check group_state;
+static pwdgrp_check group_state;
static int
parse_grp (struct group &grp, const char *line)
add_grp_line (linebuf);
}
+ group_state.set_last_modified (f);
fclose (f);
group_state = loaded;
}
/* passwd.cc: getpwnam () and friends
- Copyright 1996, 1997, 1998 Cygnus Solutions.
+ Copyright 1996, 1997, 1998, 2001 Cygnus Solutions.
This file is part of Cygwin.
#include "pinfo.h"
#include "cygheap.h"
#include <sys/termios.h>
+#include "pwdgrp.h"
/* Read /etc/passwd only once for better performance. This is done
on the first call that needs information from it. */
static int curr_lines;
static int max_lines;
-/* Set to loaded when /etc/passwd has been read in by read_etc_passwd ().
- Set to emulated if passwd is emulated. */
-/* Functions in this file need to check the value of passwd_state
- and read in the password file if it isn't set. */
-enum pwd_state {
- uninitialized = 0,
- initializing,
- emulated,
- loaded
-};
-class pwd_check {
- pwd_state state;
- FILETIME last_modified;
- char pwd_w32[MAX_PATH];
-
-public:
- pwd_check () : state (uninitialized)
- {
- last_modified.dwLowDateTime = last_modified.dwHighDateTime = 0;
- pwd_w32[0] = '\0';
- }
- operator pwd_state ()
- {
- HANDLE h;
- WIN32_FIND_DATA data;
-
- if (!pwd_w32[0]) /* First call. */
- {
- path_conv p ("/etc/passwd", PC_SYM_FOLLOW | PC_FULL);
- if (!p.error)
- strcpy (pwd_w32, p.get_win32 ());
- }
-
- if ((h = FindFirstFile (pwd_w32, &data)) != INVALID_HANDLE_VALUE)
- {
- if (CompareFileTime (&data.ftLastWriteTime, &last_modified) > 0)
- {
- state = uninitialized;
- last_modified = data.ftLastWriteTime;
- }
- FindClose (h);
- }
- return state;
- }
- void operator = (pwd_state nstate)
- {
- state = nstate;
- }
-};
-
-static pwd_check passwd_state;
+static pwdgrp_check passwd_state;
/* Position in the passwd cache */
add_pwd_line (linebuf);
}
+ passwd_state.set_last_modified (f);
fclose (f);
passwd_state = loaded;
}
--- /dev/null
+/* pwdgrp.h
+
+ Copyright 2001 Red Hat inc.
+
+ Stuff common to pwd and grp handling.
+
+This file is part of Cygwin.
+
+This software is a copyrighted work licensed under the terms of the
+Cygwin license. Please consult the file "CYGWIN_LICENSE" for
+details. */
+
+enum pwdgrp_state {
+ uninitialized = 0,
+ initializing,
+ emulated,
+ loaded
+};
+
+class pwdgrp_check {
+ pwdgrp_state state;
+ FILETIME last_modified;
+ char file_w32[MAX_PATH];
+
+public:
+ pwdgrp_check () : state (uninitialized) {}
+ operator pwdgrp_state ()
+ {
+ if (state != uninitialized && file_w32[0] && cygheap->etc_changed ())
+ {
+ HANDLE h;
+ WIN32_FIND_DATA data;
+
+ if ((h = FindFirstFile (file_w32, &data)) != INVALID_HANDLE_VALUE)
+ {
+ if (CompareFileTime (&data.ftLastWriteTime, &last_modified) > 0)
+ state = uninitialized;
+ FindClose (h);
+ }
+ }
+ return state;
+ }
+ void operator = (pwdgrp_state nstate)
+ {
+ state = nstate;
+ }
+ void set_last_modified (FILE *f)
+ {
+ if (!file_w32[0])
+ strcpy (file_w32, cygheap->fdtab[fileno (f)]->get_win32_name ());
+
+ BY_HANDLE_FILE_INFORMATION inf;
+ if (GetFileInformationByHandle (cygheap->fdtab[fileno (f)]->get_handle (),
+ &inf))
+ last_modified = inf.ftLastWriteTime;
+ }
+};
extern "C" void __malloc_lock (struct _reent *);
extern "C" void __malloc_unlock (struct _reent *);
+extern "C" void __malloc_lock (struct _reent *);
+extern "C" void __malloc_unlock (struct _reent *);
+
/**************************** Exports ******************************/
extern "C" {