(wininfo::itv): Ditto. (wininfo::start_time): Ditto. (wininfo::window_started): Ditto. (wininfo::getitimer): Ditto. (wininfo::setitimer): Ditto. (wininfo::wininfo): Ditto. (wininfo::lock): New method. (wininfo::release): Ditto. * window.cc: Use new lock/acquire wininfo methods throughout. (wininfo::wininfo): Delete (wininfo::getitimer): Ditto. (wininfo::setitimer): Ditto. (getitimer): Ditto. (setitimer): Ditto. (ualarm): Ditto. (alarm): Ditto. (wininfo::lock): Define new function. (wininfo::release): Ditto. (wininfo::process): Delete WM_TIMER handling. * timer.cc (struct timetracker): Delete it, flags. Add it_interval, interval_us, sleepto_us, running, init_muto(), syncthread, and gettime(). (ttstart): Make NO_COPY. (lock_timer_tracker): New class. (timer_tracker::timer_tracker): Distinguish ttstart case. (timer_tracker::~timer_tracker): New destructor. Clean out events, and reset magic. (timer_tracker::init_muto): New method. (to_us): Round up as per POSIX. (timer_thread): Reorganize to match timer_tracker::settime and timer_tracker::gettime. Call sig_send without wait. Call auto_release. (timer_tracker::settime): Reorganize logic to avoid race. Call gettime to recover old value. (timer_tracker::gettime): New method. (timer_create): Properly set errno on invalid timerid. Use new lock_timer_tracker method. (timer_delete): Ditto. Simplify code slightly. (timer_gettime): New function. (fixup_timers_after_fork): Reinit ttstart. (getitimer): New implementation. (setitimer): Ditto. (ualarm): Ditto. (alarm): Ditto. * cygwin.din: Export timer_gettime. * winsup.h: Remove has has_visible_window_station declaration. * Makefile.in (DLL_OFILES): Add lsearch.o. * cygthread.h (cygthread::notify_detached): New element. (cygthread::cygthread): Take optional fourth argument signifying event to signal on thread completion. * cygthread.cc (cygthread::stub): Signal notify_detached event, if it exists. (cygthread::cygthread): Initialize notify_detached from fourth argument. (cygthread::detach): Wait for notify_detached field is present. * lsearch.cc: New file. * search.h: Ditto. * include/cygwin/version.h: Bump API minor number to 126. * cygwin.din: Export lsearch, lfind.
		
			
				
	
	
		
			146 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/* fhandler_windows.cc: code to access windows message queues.
 | 
						|
 | 
						|
   Copyright 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 Red Hat, Inc.
 | 
						|
 | 
						|
   Written by Sergey S. Okhapkin (sos@prospect.com.ru).
 | 
						|
   Feedback and testing by Andy Piper (andyp@parallax.co.uk).
 | 
						|
 | 
						|
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. */
 | 
						|
 | 
						|
#include "winsup.h"
 | 
						|
#include <wingdi.h>
 | 
						|
#include <winuser.h>
 | 
						|
#include "cygerrno.h"
 | 
						|
#include "security.h"
 | 
						|
#include "path.h"
 | 
						|
#include "fhandler.h"
 | 
						|
 | 
						|
/*
 | 
						|
The following unix-style calls are supported:
 | 
						|
 | 
						|
	open ("/dev/windows", flags, mode=0)
 | 
						|
		- create a unix fd for message queue.
 | 
						|
		  O_NONBLOCK flag controls the read() call behavior.
 | 
						|
 | 
						|
	read (fd, buf, len)
 | 
						|
		- return next message from queue. buf must point to MSG
 | 
						|
		  structure, len must be >= sizeof (MSG). If read is set to
 | 
						|
		  non-blocking and the queue is empty, read call returns -1
 | 
						|
		  immediately with errno set to EAGAIN, otherwise it blocks
 | 
						|
		  untill the message will be received.
 | 
						|
 | 
						|
	write (fd, buf, len)
 | 
						|
		- send a message pointed by buf. len argument ignored.
 | 
						|
 | 
						|
	ioctl (fd, command, *param)
 | 
						|
		- control read()/write() behavior.
 | 
						|
		ioctl (fd, WINDOWS_POST, NULL): write() will PostMessage();
 | 
						|
		ioctl (fd, WINDOWS_SEND, NULL): write() will SendMessage();
 | 
						|
		ioctl (fd, WINDOWS_HWND, &hWnd): read() messages for
 | 
						|
			hWnd window.
 | 
						|
 | 
						|
	select () call marks read fd when any message posted to queue.
 | 
						|
*/
 | 
						|
 | 
						|
fhandler_windows::fhandler_windows ()
 | 
						|
  : fhandler_base (), hWnd_ (NULL), method_ (WINDOWS_POST)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
int
 | 
						|
fhandler_windows::open (int flags, mode_t)
 | 
						|
{
 | 
						|
  set_flags ((flags & ~O_TEXT) | O_BINARY);
 | 
						|
  close_on_exec (true);
 | 
						|
  set_open_status ();
 | 
						|
  return 1;
 | 
						|
}
 | 
						|
 | 
						|
int
 | 
						|
fhandler_windows::write (const void *buf, size_t)
 | 
						|
{
 | 
						|
  MSG *ptr = (MSG *) buf;
 | 
						|
 | 
						|
  if (method_ == WINDOWS_POST)
 | 
						|
    {
 | 
						|
      if (!PostMessage (ptr->hwnd, ptr->message, ptr->wParam, ptr->lParam))
 | 
						|
	{
 | 
						|
	  __seterrno ();
 | 
						|
	  return -1;
 | 
						|
	}
 | 
						|
      else
 | 
						|
	return sizeof (MSG);
 | 
						|
    }
 | 
						|
  else
 | 
						|
    return SendMessage (ptr->hwnd, ptr->message, ptr->wParam, ptr->lParam);
 | 
						|
}
 | 
						|
 | 
						|
void __stdcall
 | 
						|
fhandler_windows::read (void *buf, size_t& len)
 | 
						|
{
 | 
						|
  MSG *ptr = (MSG *) buf;
 | 
						|
 | 
						|
  if (len < sizeof (MSG))
 | 
						|
    {
 | 
						|
      set_errno (EINVAL);
 | 
						|
      len = (size_t) -1;
 | 
						|
      return;
 | 
						|
    }
 | 
						|
 | 
						|
  len = (size_t) GetMessage (ptr, hWnd_, 0, 0);
 | 
						|
 | 
						|
  if ((ssize_t) len == -1)
 | 
						|
    __seterrno ();
 | 
						|
  return;
 | 
						|
}
 | 
						|
 | 
						|
int
 | 
						|
fhandler_windows::ioctl (unsigned int cmd, void *val)
 | 
						|
{
 | 
						|
  switch (cmd)
 | 
						|
    {
 | 
						|
    case WINDOWS_POST:
 | 
						|
    case WINDOWS_SEND:
 | 
						|
      method_ = cmd;
 | 
						|
      break;
 | 
						|
    case WINDOWS_HWND:
 | 
						|
      if (val == NULL)
 | 
						|
	{
 | 
						|
	  set_errno (EINVAL);
 | 
						|
	  return -1;
 | 
						|
	}
 | 
						|
      hWnd_ = * ((HWND *) val);
 | 
						|
      break;
 | 
						|
    default:
 | 
						|
      set_errno (EINVAL);
 | 
						|
      return -1;
 | 
						|
    }
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fhandler_windows::set_close_on_exec (bool val)
 | 
						|
{
 | 
						|
  if (get_handle ())
 | 
						|
    fhandler_base::set_close_on_exec (val);
 | 
						|
  else
 | 
						|
    fhandler_base::close_on_exec (val);
 | 
						|
  void *h = hWnd_;
 | 
						|
  if (h)
 | 
						|
    set_no_inheritance (h, val);
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fhandler_windows::fixup_after_fork (HANDLE parent)
 | 
						|
{
 | 
						|
  if (get_handle ())
 | 
						|
    fhandler_base::fixup_after_fork (parent);
 | 
						|
  void *h = hWnd_;
 | 
						|
  if (h)
 | 
						|
    fork_fixup (parent, h, "hWnd_");
 | 
						|
}
 |