delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2006/02/13/13:12:13

X-Spam-Check-By: sourceware.org
From: "Dave Korn" <dave DOT korn AT artimi DOT com>
To: <cygwin AT cygwin DOT com>
Subject: RE: _kbhit
Date: Mon, 13 Feb 2006 18:11:58 -0000
Message-ID: <010301c630c8$fb06ff10$a501a8c0@CAM.ARTIMI.COM>
MIME-Version: 1.0
In-Reply-To: <6CA15ADD82E5724F88CB53D50E61C9AE9ECE5F@cgcmail.cgc.cpmc.columbia.edu>
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com>
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com

On 13 February 2006 17:10, Michiel De Hoon wrote:

> Gary R. Van Sickle wrote:
>>> First, some Cygwin programs will need _kbhit to be
>>> able to interact with the Windows OS.
>> 
>> That's simply not true.  They may *want* it so that they can interact with
>> cmd.exe, in which case they're not a "Cygwin program".
> 
> If:
> 1) A program needs to run a Windows message loop;

-  Then it's not a POSIX program.

> 2) This message loop should be exited when user input is available on stdin;

-  Then if it's running a windows message loop, it should be looking for
WM_KEYDOWN.  (_kbhit is a remnant from the late '80s DOS 3.x int 21h call
interface; I don't know if it's even guaranteeed to play nicely with windows
message queues in any case, is it?  It certainly requires a console to be
available at the very least...)

-  And if it's trying to be a POSIX program, it should use the POSIX way of
doing that (cf. select/ncurses/footnote[*] qv).

> 3) The program needs to link to cygwin1.dll;
> then it is a Cygwin program that needs _kbhit (either present in the DLL or
> implemented by myself using select()), isn't it?

  No.

  It's a MinGW program that has been compiled for the wrong environment.





  The key is in the word "needs" to link to cygwin1.dll.

  Why would any app (in general, and yours in particular) /need/ to link to
cygwin1.dll?  The only reason is for the POSIX/Unix/Linux compatibility it
provides, because that is _all_ that cygwin1.dll does.

  You will never want to write a fullly POSIX/Unix/Linux-compatible
application that contains a Windows message loop, because then it's not a
POSIX/Unix/Linux-compatible application, by definition.

  If you're writing what is fundamentally a Windows program, and just want a
few library functions to provide you with posix-alike functionality, that is
/exactly/ the definition of MinGW.  Use it instead.

  If you want a full POSIX/Unix/Linux-compatible environment that runs on
windows, you want Cygwin, but then you don't want to write windows message
loops, or your code won't be POSIX/Unix/Linux-compatible.

 
    cheers,
      DaveK

[*] - Ok.  Here ya go: "_kbhit() for Linux".
http://www.flipcode.org/cgi-bin/fcarticles.cgi?show=64166
Considering that this is hit #1 on google when you enter the term "_kbhit", it
seems blatantly clear that you haven't made even a token effort to STFW.
-- 
Can't think of a witty .sigline today....


--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Problem reports:       http://cygwin.com/problems.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019