public inbox for cygwin@cygwin.com
 help / color / mirror / Atom feed
* distinguishing cygwin from mingw binaries
@ 2017-07-10 17:40 Nellis, Kenneth
  2017-07-10 19:01 ` Hans-Bernhard Bröker
  2017-07-11 14:37 ` cyg Simple
  0 siblings, 2 replies; 6+ messages in thread
From: Nellis, Kenneth @ 2017-07-10 17:40 UTC (permalink / raw)
  To: cygwin

For my personal use, I use gcc to generate binaries, but occasionally I need 
to make a binary available to someone who doesn't use Cygwin. For that I use 
Cygwin's x86_64-w64-mingw32-gcc.

After the fact, I would like to know whether the binary requires Cygwin support 
or not. One way is: strings foo.exe | grep cygwin1.dll

Curious what techniques others might use.

One of my wishes for Cygwin is for the "file" command to make the distinction.

--Ken Nellis

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

^ permalink raw reply	[flat|nested] 6+ messages in thread
* Re: distinguishing cygwin from mingw binaries
@ 2017-07-10 18:01 Kaz Kylheku
  2017-07-11 14:43 ` cyg Simple
  0 siblings, 1 reply; 6+ messages in thread
From: Kaz Kylheku @ 2017-07-10 18:01 UTC (permalink / raw)
  To: cygwin

On 10.07.2017 10:40, Nellis, Kenneth wrote:
> For my personal use, I use gcc to generate binaries, but occasionally I 
> need
> to make a binary available to someone who doesn't use Cygwin. For that 
> I use
> Cygwin's x86_64-w64-mingw32-gcc.
> 
> After the fact, I would like to know whether the binary requires Cygwin 
> support
> or not. One way is: strings foo.exe | grep cygwin1.dll
> 
> Curious what techniques others might use.

There is always the technique of actually packaging the program 
deliverables
and then testing them, beginning with installation, if you were the 
end-user.

If the program doesn't run when installed by itself in C:\Program Files
somewhere, then it might be missing DLLs.

I use a special fork of Cygwin called Cygnal for delivering programs to
users who don't use Cygwin and don't understand POSIX conventions for 
paths
and other things.

http://www.kylheku.com/cygnal/

With this, you make your executable with the regular Cygwin host 
compiler.
Yes, you know your executable needs a CYGWIN1.DLL (and possibly others);
no guesswork. You package the needed DLL's with the program.

Except, you use the CYGWIN1.DLL from the Cygnal project rather than the
stock Cygwin one.

Example software shipping with Cygnal is the port of the TXR language to
Win32 and Win64. Installers available here:
https://bintray.com/kazinator/Binaries/TXR/


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

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2017-07-11 14:43 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-07-10 17:40 distinguishing cygwin from mingw binaries Nellis, Kenneth
2017-07-10 19:01 ` Hans-Bernhard Bröker
2017-07-11 14:20   ` Nellis, Kenneth
2017-07-11 14:37 ` cyg Simple
2017-07-10 18:01 Kaz Kylheku
2017-07-11 14:43 ` cyg Simple

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).