Fixes for Cygwin and MinGW.

Carl


git-svn-id: file:///fltk/svn/fltk/branches/branch-1.0@1230 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
Carl E. Thompson 2000-06-20 18:47:33 +00:00
parent 52496ba472
commit 463681c1ca
7 changed files with 138 additions and 379 deletions

View File

@ -1,182 +1,111 @@
README.win32 - 06/15/2000 - Building FLTK under Windows README.win32 - 06/15/2000 - Building FLTK under Windows
------------------------------------------------------- -------------------------------------------------------
This document is split into two main sections. This document is split into two main sections. The first describes several
The first describes several possible build environments, possible build environments, while the second describes some of the issues
whilst the second describes some of the issues associated with associated with using the GNU-like build configurations in the "makefiles"
using the GNU-like build configurations in the makefiles/
subdirectory. subdirectory.
------------------------------------------------------- -------------------------------------------------------
INTRODUCTION INTRODUCTION
FLTK currently supports the following development environments on FLTK currently supports the following development environments on the
the Windows platform: Windows platform:
- Microsoft Visual C++ 5.0 and 6.0 using the supplied workspace - Microsoft Visual C++ 5.0 and 6.0 using the supplied workspace
and project files. Be sure to get your service packs! and project files. Be sure to get your service packs!
- Borland C++ Builder 5 using the supplied IDE file. - Borland C++ Builder 5 using the supplied IDE file.
- Various GNU-like toolsets (Cygwin, Mingw) hosted on - GNU toolsets (Cygwin or MinGW) hosted on Windows 9x/2000/NT
Windows 9x/2000/NT
This document gives a brief overview of using FLTK with the Cygwin and This document gives a brief overview of compiling and using FLTK with the
Mingw compiler toolkits. Both toolkits provide a build environment Cygwin and MinGW compiler toolkits. Both toolkits provide a build
based around the GNU C/C++ compiler. environment based around the GNU C/C++ compiler.
The Cygwin build environment is primarily intended to provide a number of The Cygwin build environment supplies a library (the Cygwin DLL) that is
Un*x-like facilities for programs being ported to the Windows environment. primarily intended to provide a number of Unix-like POSIX facilities for
(Win32 or WinNT) programs being ported to the Windows environment (Win32 or WinNT). Cygwin
also supplies a very Unix-like build environment for Windows, including
the "BASH" Bourne-compatible shell and all of the standard Unix file
utilities (ls, cat, grep, etc.).
It was developed by Cygnus (now part of RedHat) and although provided Cygwin is developed by Cygnus (now part of RedHat, Inc). Although provided
for free download, does require a license if programs are to be for free download under the GPL, distributing programs that require the
distributed that require the main CYGWIN1.DLL library. Cygwin DLL under a license other than the GPL requires a commercial
license for the Cygwin DLL. Native Windows programs that do not require
the Cygwin DLL (compiled and linked with the "-mno-cygwin" option) may be
released under any license freely.
The Mingw distribution (Minimalist GNU for Windows) provides a similar The MinGW distribution (Minimalist GNU for Windows) provides a similar
toolset but geared solely towards windows development. Because of this toolset but geared solely towards native Windows development without the
it uses only those DLLs provided by Microsoft as part of the operating Unix-like POSIX library. The lack of any libraries under the GPL or any
system. The lack of any proprietary DLLs means that licensing of the other restrictive license means that programs built with the MinGW
Mingw toolset is considerably more relaxed. environment may always be released under any license freely.
Perhaps confusingly, the Cygwin environment supports some basic If you are not familiar with these GNU-like toolkits please refer to the
Mingw-like compilation (via the -mno-cygwin flag), but requires links section later in this section. In particular, check out their
supplementary files to mimic the full standalone Mingw capabilities. license conditions carefully before use.
These supplementary files (headers and replacement libraries) can be
found at the Mingw home page along with its native toolkit.
If you are not familiar with these GNU-like toolkits please refer to
the links section later in this section. In particular, check out
their license conditions carefully before use.
THE TOOLS THE TOOLS
There are currently two main configurations supported by FLTK There are currently three main configurations supported by FLTK
cygnus: Built natively under the Cygwin toolset and using the Un*x 1. Cygwin: Built using the Cygwin toolset and using the Unix-like POSIX
compatibility layer provided by CYGWIN1.DLL compatibility layer provided by the Cygwin DLL.
2. Cygwin using the "-mno-cygwin" option: Built using the Cygwin toolset
but not using the Cygwin DLL.
mingw: Mainly based upon the Mingw utilities, compiler and tools but 3. MinGW: Mainly based upon the MinGW utilities, compiler and tools but
currently needs supplementing by additional tools such as currently needs additional tools from the Cygwin distribution (make.exe
make.exe. Consequently the Makefiles provided do require the and sh.exe).
Cygwin toolset as a convenient way of obtaining some of the
build utilities but generates code not using CYGWIN1.DLL.
It is also possible to build an executable using the Mingw toolset and
other windows-native tools (rather than using Cygwin for supplementary
tools like make). At present although such tools do exist, they are
spread widely over the net and of differing versions.
The advantage of this approach though would be no necessity to download
and configure the Cygwin tools.
At this time it is felt that the maintenance costs of this approach
outweigh any benefits however.
By design, the Cygwin tools themselves are supposed to provide a basic
Mingw alternate compilation mode through the compile/link
flag -mno-cygwin.
At the time of writing v1.1.2 of Cygwin has just been released and
still has some serious configuration issues for Mingw compilation and
so cannot be recommended.
This Cygwin-only method also has a number of deficiencies that prevent
many modern programs from compiling unless further headers and
replacement libraries are added (even if basic mingw compilation did
work OK).
These additions are also available at the Mingw site mentioned in the
links section. I refer to these as the mingw supplementary files as
opposed to the full toolset.
As you can see there are many ways to configure the various bits of
Cygwin and Mingw. In order to set up development, refer to the links
section below for more guidance.
PROBLEMS WITH THE `MIX AND MATCH' APPROACH
One main confusion is the use of Un*x and Windows conventions based
upon the tool being used.
Cygwin tools tend to follow the Un*x rules for things like path names
(forward slashes) whereas the Mingw tools follow the windows
conventions.
A hybrid toolset can be a source of confusion for this reason.
Other issues from this combination are caused by the use of say the DOS
copy command in a DOS shell (with '\') and say the cp command with '/'
in a bash or sh shell.
RECOMMENDED BUILD ENVIRONMENTS RECOMMENDED BUILD ENVIRONMENTS
Our recommendation is to: Our recommendation is to:
1) Get a pre-built combined toolset that has been tested with FLTK 1) Get the current Cygwin toolset (June 20, 2000 or later).
This will provide several Cygwin utilities and the Mingw compiler. Can produce executables that do or do not rely on the Cygwin DLL (check
Compilation will produce executables not reliant on the CYGWIN1.DLL licensing)-- your choice. No supplementary MinGW files are required.
and so are freely-redistributable.
Carl Thompson has provided a set based upon the B20.1 Cygwin release 2) Get the latest full MinGW toolset and add Cygwin "make.exe" and "sh.exe"
and ~Feb 2000 version of Mingw which has been successfully used for to it.
FLTK.
Will only normal Windows native executables without any Unix or POSIX
compatibility.
3) Get a pre-built combined toolset that has been tested with FLTK.
Carl Thompson has provided a set based upon the B20.1 Cygwin release and
~Feb 2000 version of Mingw which has been successfully used for FLTK.
This will provide several Cygwin utilities and the MinGW compiler.
Compilation will produce executables not reliant on the Cygwin DLL and
so are freely redistributable under any license you choose.
See the links section below for more information. See the links section below for more information.
2) Get the latest Cygwin toolset. All three options can provide windows-native executables and 1) can provide
Get the latest full Mingw toolset. a Unix-like POSIX portability layer that is reliant on a GPLed library.
Configure your PATH to find the Mingw tools first but also have the
Cygwin supplementary tools on your PATH for commands like make.
3) Get the latest Cygwin toolset
Produce executables dependent on CYGWIN1.DLL (Check licensing).
i.e. No supplementary Mingw files required.
1) and 2) provide windows-native executables whilst 3) has a un*x
portability layer but is reliant on a proprietary DLL.
See the later sections for detailed information about using one of See the later sections for detailed information about using one of
these configurations. these configurations.
Other options:
4) When the Cygwin tools are fixed...
Get the latest Cygwin toolset.
Get the latest Mingw supplementary files for Cygwin.
This would be a good long-term solution since this would allow
Cygwin native or Cygwin-hosted Mingw compilation without the
confusion of two versions of some of the tools.
This is in fact how things are intended when the two toolsets are in
step.
5) Get the latest full Mingw toolset.
Get the necessary supplementary tools for native versions of make etc
Again a good long-term solution but currently difficult to maintain
due to the diversity of tools and versions.
LINKS LINKS
1) Main Cygwin homepage: http://sourceware.cygnus.com/cygwin/ 1) Main Cygwin homepage: http://sourceware.cygnus.com/cygwin/
2) Main Mingw homepage: http://www.mingw.org/ 2) Main Mingw homepage: http://www.mingw.org/
In particular look for the Mingw FAQ at this link for a lot of useful In particular look for the MinGW FAQ at this link for a lot of useful
Mingw-native development documentation. Mingw-native development documentation.
3) Mumit Khan's homepage (chief maintainer and driving force behing Mingw): 3) Mumit Khan's homepage (chief maintainer and driving force behing MinGW):
http://www.xraylith.wisc.edu/~khan/software/gnu-win32/index.html http://www.xraylith.wisc.edu/~khan/software/gnu-win32/index.html
@ -184,18 +113,20 @@ LINKS
similar packages. This information can sometimes lag the current similar packages. This information can sometimes lag the current
release however. release however.
In particular the insights and recommendations for using Cygwin for Mingw In particular the insights and recommendations for using Cygwin for MinGW
compilation are very useful: compilation are very useful:
http://www.xraylith.wisc.edu/~khan/software/gnu-win32/mno-cygwin-howto.txt http://www.xraylith.wisc.edu/~khan/software/gnu-win32/mno-cygwin-howto.txt
(Some of this information may be outdated and inaccurate!)
4) Check out the FLTK mailing list at the FLTK homepage: 4) Check out the FLTK mailing list at the FLTK homepage:
http://www.fltk.org/ http://www.fltk.org/
Its archival search facilities are EXTREMELY useful to check back Its archival search facilities are EXTREMELY useful to check back
through previous problems with this sort of configuration before through previous problems with this sort of configuration before posting
posting new questions. new questions.
5) Carl Thompson (One of the core team responsible for FLTK): 5) Carl Thompson (One of the core team responsible for FLTK):
@ -218,226 +149,64 @@ LINKS
BUILDING FLTK WITH CYGWIN OR MINGW BUILDING FLTK WITH CYGWIN OR MINGW
1. Starting my first build 1. Starting your first build
-------------------------- ----------------------------
1.1 How do I build FLTK 1.1 How to build FLTK
a) Cygwin 'native' system (intend building an executable using CYGWIN1.DLL) a) Cygwin (to build an executable that does not use the Cygwin DLL)
Having read the Cygwin documentation and happily compiled and linked your (You should have read the Cygwin documentation and compiled and linked
own small test programs (see below)... your own small test programs)
i) Copy makefiles/Makefile.cygnus to top level FLTK directory. i) Copy makefiles/Makefile.no-cygwin to top level FLTK directory.
ii) Backup existing Makefile and rename top level copy of Makefile.cygnus to ii) Backup existing Makefile and rename top level copy of Makefile.no-cygwin
Makefile to Makefile
iii) Type make iii) Type make
The first time it is run it will copy other configuration files from the The first time it is run it will copy other configuration files from
makefiles directory and then begin building FLTK, Fluid and the test examples the makefiles directory and then begin building FLTK, Fluid and the
test examples.
iv) The build process will produce libraries in the lib directory and various iv) The build process will produce libraries in the lib directory and
executables. various executables.
v) Read the rest of this document to learn how to troubleshoot your setup or v) Read the rest of this document to learn how to troubleshoot your setup
change various configuration settings. or change various configuration settings.
b) For a combination Cygwin + full Mingw solution b) Cygwin (to build an executable that uses the Cygwin DLL)
Download the Cygwin tools and Mingw tools. (Steps are the same as above, but use "Makefile.cygwin" instead of
Set the PATH to find the Mingw tools first and then the Cygwin ones. "Makefile.no-cygwin" .)
Follow steps i) to v) above but copying Makefile.Mingw to the top level. c) MinGW
(Steps are the same as above, but use "Makefile.mingw" instead of
"Makefile.no-cygwin" . Make sure you have "make.exe" and "sh.exe" from the
Cygwin distribution in your path as well as the MinGW tools.)
c) For a Cygwin solution with only supplementary libraries/headers from Mingw
(rather than full native Mingw toolset).
At the time of writing, Cygwin 1.1.2 does not work with early June 2000 gcc 1.2 How do I set up Cygwin and/or MinGW
tools to produce Mingw executables.
[For the truly adventurous it can be made to work by following the
instructions from Dale Goudney on the cygwin mailing list dated June 13 or
subsequent updated gcc distribution for cygwin.]
As such this is not currently supported via a supported set of configuration See the links section provided in the first part of this document. This
files, but a preliminary (largely untested) set are provided as *.no-cygwin. isn't really an FLTK issue and is adequately described at the linked sites.
The files are a hybrid of the cygnus and mingw-native files.
Here's a 'recipe' to derive *.no-cygwin from *.cygnus and *.mingw. 2. Other stuff
The compiler and linker option -mno-cygwin should be added to --------------
makeinclude.cygnus as the toolset should then pull in the correct alternate
files. (creating makeinclude.no-cygwin)
Because we are using a basic mingw arrangement, config.mingw is copied to 2.1 Getting rid of that peskey console window in the background!
config.no-cygwin. Take a look at the "makeinclude" file. You'll want the add the option
"-mwindows" to your LDFLAGS setting.
Makefile.no-cygwin is created from a copy of Makefile.cygnus with a minor 2.2 OpenGL - How do I get it to work
change towards the bottom of the Makefile where config.cygnus and
makeinclude.cygnus should be replaced by equivalent *.no-cygwin.
The configuration file config.h has a number of settings which control
I would strongly recommend you read the insights into this process described compile-time compilation. One such setting is "HAVE_GL" . By default this
by Mumit Khan (see links section of the first part of this document above.) is set to 0 to disable Open GL operation. Changing the line in config.h to
1.2 How do I set up Cygwin and/or Mingw
See the links section provided in the first part of this document.
This isn't really an FLTK issue and is adequately described at the linked
sites.
2. Common build problems
------------------------
2.1 Compilation tests
There are many reasons for a failed compilation, including an incorrect
development toolset.
If you haven't regularly used the environment before, try compiling a few
basic programs directly.
e.g. 1
---------------------
/* Filename hello.c */
#include <stdio.h>
int main()
{
printf("Hello World\n");
return 0;
}
---------------------
gcc hello.c
should produce an executable called 'a.exe'
Try adding the -v option to display a lot of diagnostic search information
about where gcc is looking.
Often problems can be traced to incorrect include or library paths.
Once successfully compiled, try
objdump -p a.exe
on the executable to display info on the executable (including DLLs it uses)
If you want a summary of what libraries an executable uses, try
objdump -p a.exe | grep 'DLL Name'
Case is important in the grep command.
e.g.2
-------------------------
/* Filename hello.cxx */
#include <iostream>
int main()
{
std::cout <<"Hello World\n";
return 0;
}
-------------------------
gcc hello.cxx
Default compilation with gcc will probably no longer work complaining it
can't find 'cout' etc.
Hopefully g++ will though!
g++ hello.cxx
Although gcc and g++ end up calling the same common code, they often differ
by what default libraries they include, hence the failure for gcc and success
for g++. (g++ additionally adds the standard C++ libs)
Once again you can try adding the -v option or looking at the file with
objdump.
Also try to look at the compile and link options provided by gcc and g++
gcc --help
ld --help
Hopefully if all goes well, you should be set to try compilation for real.
If these don't compile then it would be prudent to check the latest info
for the compiler you're using (maybe a newer version is available?) or
look for additional information at the compiler home page.
e.g. http://gcc.gnu.org/ for gcc details and documentation
2.2 Make errors
There are various compiled forms of make.exe, some native Windows, others
emulating Un*x.
Together with this, the build environment may not be set correctly.
For example the type of 'end of line' characters can cause problems.
a) Basic advice:
Check that the environment is set correctly. You may need to set MAKE_MODE
to unix for instance. ( SET MAKE_MODE=unix in DOS window )
Try and get a newer version of make ( make v3.79 at time of writing). Prior
versions particularly some patch levels for v3.77 didn't cope as well with
mixed EOL characters (unix vs Windows)
Check for incorrect end of line characters.
Check that your build environment is correctly mapping text files correctly.
[Cygwin has a text mode and binary mode for mount points.
Typically files should be mounted on a drive in text mode.
Type mount and see if your drive is mounted correctly.]
Check your PATH is set to find the right version of executables particularly
in a mixed Cygwin/Mingw environment.
b) Check the correct Makefile is in the top level directory
3. Compile/link options
-----------------------
3.1 Getting rid of that peskey console window in the background!
3.2 Slimming down an executable
By default the configuration leaves an executable suitable for debugging.
That means it is not stripped of debugging symbols, but also that it needs
to put those error messages somewhere.
Take a look at the 'makeinclude.<env>' file for your environment and there
are a few notes on how to avoid the console window and how to slim down the
executable.
3.3 OpenGL - How do I get it to work
The configuration file makefiles/config.<env> has a number of settings which
control compile-time compilation.
One such setting is HAVE_GL
By default this is set to 0 to disable Open GL operation.
#define HAVE_GL 1 #define HAVE_GL 1
@ -445,24 +214,28 @@ will change this to compile and link in OpenGL.
In order for it to work you will need a few OpenGL headers for both Cygwin In order for it to work you will need a few OpenGL headers for both Cygwin
and Mingw. These are not part of the official distributions of Cygwin or and MinGW. These are not part of the official distributions of Cygwin or
Mingw, so need to be added. MinGW, so they need to be added.
http://www.carlthompson.net/fltk/ http://www.carlthompson.net/fltk/
has a small zip file called MingwGL.zip which contains the necessary headers. has a small zip file called MingwGL.zip which contains the necessary
headers.
Normally these are put in FLTK's Gl directory. These should be put in a "GL" subdirectory somewhere in your compiler's
search path.
You will also need an opengl library and an additional set of GLUT libraries. You will also need an OpenGL library and an additional set of GLUT
libraries.
The opengl files are most likely already part of your operating system, and The opengl files are most likely already part of your operating system, and
the GLUT libraries may be found by searching at the GLUT libraries are in current versions of MinGW and Cygwin or may be
found at:
http://www.opengl.org/ http://www.opengl.org/
Do a search for 'GLUT windows' and the first couple of results will take you Do a search for 'GLUT windows' and the first couple of results will take you
to the latest GLUT and OpenGL libs for windows. to the latest GLUT and OpenGL libs for Windows.
The binaries (DLLs normally) need to be put somewhere on the system PATH. The binaries (DLLs normally) need to be put somewhere on the system PATH.
Consult the install documentation on the site for info. Consult the install documentation on the site for info.

View File

@ -1,5 +1,5 @@
# #
# "$Id: Makefile.cygnus,v 1.1.2.2 2000/06/13 20:33:33 mike Exp $" # "$Id: Makefile.cygwin,v 1.1.2.1 2000/06/20 18:47:31 carl Exp $"
# #
# Top-level makefile for the Fast Light Tool Kit (FLTK). # Top-level makefile for the Fast Light Tool Kit (FLTK).
# #
@ -85,12 +85,12 @@ clean:
touch test/makedepend touch test/makedepend
cd test ; $(MAKE) clean cd test ; $(MAKE) clean
config.h: makefiles/config.cygnus config.h: makefiles/config.cygwin
cp $< $@ cp $< $@
makeinclude: makefiles/makeinclude.cygnus makeinclude: makefiles/makeinclude.cygwin
cp $< $@ cp $< $@
# #
# End of "$Id: Makefile.cygnus,v 1.1.2.2 2000/06/13 20:33:33 mike Exp $". # End of "$Id: Makefile.cygwin,v 1.1.2.1 2000/06/20 18:47:31 carl Exp $".
# #

View File

@ -1,5 +1,5 @@
# #
# "$Id: Makefile.os2x,v 1.6.2.2 2000/06/13 20:33:34 mike Exp $" # "$Id: Makefile.os2x,v 1.6.2.3 2000/06/20 18:47:31 carl Exp $"
# #
# Top-level makefile for the Fast Light Tool Kit (FLTK). # Top-level makefile for the Fast Light Tool Kit (FLTK).
# #
@ -67,12 +67,12 @@ clean:
touch test/makedepend touch test/makedepend
cd test & $(MAKE) clean cd test & $(MAKE) clean
config.h: makefiles\config.os2x config.h: makefiles/config.os2x
copy $< $@ cp $< $@
makeinclude: makefiles\makeinclude.os2x makeinclude: makefiles/makeinclude.os2x
copy $< $@ cp $< $@
# #
# End of "$Id: Makefile.os2x,v 1.6.2.2 2000/06/13 20:33:34 mike Exp $". # End of "$Id: Makefile.os2x,v 1.6.2.3 2000/06/20 18:47:31 carl Exp $".
# #

View File

@ -1,5 +1,5 @@
/* /*
* "$Id: config.cygnus,v 1.4.2.3 2000/06/13 20:33:35 mike Exp $" * "$Id: config.cygwin,v 1.1.2.1 2000/06/20 18:47:32 carl Exp $"
* *
* Configuration file for the Fast Light Tool Kit (FLTK). * Configuration file for the Fast Light Tool Kit (FLTK).
* *
@ -153,5 +153,5 @@
#define HAVE_POLL 0 #define HAVE_POLL 0
/* /*
* End of "$Id: config.cygnus,v 1.4.2.3 2000/06/13 20:33:35 mike Exp $". * End of "$Id: config.cygwin,v 1.1.2.1 2000/06/20 18:47:32 carl Exp $".
*/ */

View File

@ -1,5 +1,5 @@
# #
# "$Id: makeinclude.cygnus,v 1.9.2.6 2000/06/20 17:54:41 mike Exp $" # "$Id: makeinclude.cygwin,v 1.1.2.1 2000/06/20 18:47:33 carl Exp $"
# #
# Make include file for the Fast Light Tool Kit (FLTK). # Make include file for the Fast Light Tool Kit (FLTK).
# #
@ -31,11 +31,7 @@
# but will cause an 'unnecessary' console to appear when run directly from # but will cause an 'unnecessary' console to appear when run directly from
# windows (say explorer). It provides i/o for stdin/stdout for debugging # windows (say explorer). It provides i/o for stdin/stdout for debugging
# #
# To avoid this use an additional compile/link switch to move the program # To avoid this add "-mwindows" to LDLIBS and GLDLIBS below
# entry point to WinMain(). If not defined a link warning may appear
# but the program will run correctly from main() and not produce a console.
# Adding -mwindows to CFLAGS,CXXFLAGS,LDLIBS,GLDLIBS below
# will cause this revised behaviour
# #
# 2) Stripping the executable to reduce size # 2) Stripping the executable to reduce size
# #
@ -73,7 +69,6 @@ DSONAME =
DSOCOMMAND = echo DSOCOMMAND = echo
# libraries to link with (in addition to default libs): # libraries to link with (in addition to default libs):
# (Note: -lm may be required with older versions of the Cygwin environment)
LDLIBS = -lgdi32 -lwsock32 LDLIBS = -lgdi32 -lwsock32
GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32 GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32
@ -96,5 +91,5 @@ GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32
$(CXX) -I.. $(CXXFLAGS) $< -c $(CXX) -I.. $(CXXFLAGS) $< -c
# #
# End of "$Id: makeinclude.cygnus,v 1.9.2.6 2000/06/20 17:54:41 mike Exp $". # End of "$Id: makeinclude.cygwin,v 1.1.2.1 2000/06/20 18:47:33 carl Exp $".
# #

View File

@ -1,5 +1,5 @@
# #
# "$Id: makeinclude.mingw,v 1.1.2.1 2000/06/13 20:33:35 mike Exp $" # "$Id: makeinclude.mingw,v 1.1.2.2 2000/06/20 18:47:33 carl Exp $"
# #
# Make include file for the Fast Light Tool Kit (FLTK). # Make include file for the Fast Light Tool Kit (FLTK).
# #
@ -31,11 +31,7 @@
# but will cause an 'unnecessary' console to appear when run directly from # but will cause an 'unnecessary' console to appear when run directly from
# windows (say explorer). It provides i/o for stdin/stdout for debugging # windows (say explorer). It provides i/o for stdin/stdout for debugging
# #
# To avoid this use an additional compile/link switch to move the program # To avoid this add "-mwindows" to LDLIBS and GLDLIBS below
# entry point to WinMain(). If not defined a link warning may appear
# but the program will run correctly from main() and not produce a console.
# Adding -mwindows to CFLAGS,CXXFLAGS,LDLIBS,GLDLIBS below
# will cause this revised behaviour
# #
# 2) Stripping the executable to reduce size # 2) Stripping the executable to reduce size
# #
@ -95,5 +91,5 @@ GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32
$(CXX) -I.. $(CXXFLAGS) $< -c $(CXX) -I.. $(CXXFLAGS) $< -c
# #
# End of "$Id: makeinclude.mingw,v 1.1.2.1 2000/06/13 20:33:35 mike Exp $". # End of "$Id: makeinclude.mingw,v 1.1.2.2 2000/06/20 18:47:33 carl Exp $".
# #

View File

@ -1,5 +1,5 @@
# #
# "$Id: makeinclude.no-cygwin,v 1.1.2.2 2000/06/20 17:54:41 mike Exp $" # "$Id: makeinclude.no-cygwin,v 1.1.2.3 2000/06/20 18:47:33 carl Exp $"
# #
# Make include file for the Fast Light Tool Kit (FLTK). # Make include file for the Fast Light Tool Kit (FLTK).
# #
@ -31,11 +31,7 @@
# but will cause an 'unnecessary' console to appear when run directly from # but will cause an 'unnecessary' console to appear when run directly from
# windows (say explorer). It provides i/o for stdin/stdout for debugging # windows (say explorer). It provides i/o for stdin/stdout for debugging
# #
# To avoid this use an additional compile/link switch to move the program # To avoid this add "-mwindows" to LDLIBS and GLDLIBS below
# entry point to WinMain(). If not defined a link warning may appear
# but the program will run correctly from main() and not produce a console.
# Adding -mwindows to CFLAGS,CXXFLAGS,LDLIBS,GLDLIBS below
# will cause this revised behaviour
# #
# 2) Stripping the executable to reduce size # 2) Stripping the executable to reduce size
# #
@ -58,12 +54,12 @@ libdir = ${exec_prefix}/lib
srcdir = . srcdir = .
# compiler names: # compiler names:
CXX = g++ CXX = g++ -mno-cygwin
CC = gcc CC = gcc -mno-cygwin
# flags for C++ compiler: # flags for C++ compiler:
CFLAGS = -Wall -O2 -DWIN32 -mno-cygwin CFLAGS = -Wall -O2 -DWIN32
CXXFLAGS = -Wall -O2 -DWIN32 -mno-cygwin CXXFLAGS = -Wall -O2 -DWIN32
# program to make the archive: # program to make the archive:
LIBNAME = libfltk.a LIBNAME = libfltk.a
@ -73,9 +69,8 @@ DSONAME =
DSOCOMMAND = echo DSOCOMMAND = echo
# libraries to link with (in addition to default libs): # libraries to link with (in addition to default libs):
# (Note: -lm may be required with older versions of the Cygwin environment) LDLIBS = -lgdi32 -lwsock32
LDLIBS = -lgdi32 -lwsock32 -mno-cygwin GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32
GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32 -mno-cygwin
# Be quiet when building... # Be quiet when building...
.SILENT: .SILENT:
@ -96,5 +91,5 @@ GLDLIBS = -lglu32 -lopengl32 -lgdi32 -lwsock32 -mno-cygwin
$(CXX) -I.. $(CXXFLAGS) $< -c $(CXX) -I.. $(CXXFLAGS) $< -c
# #
# End of "$Id: makeinclude.no-cygwin,v 1.1.2.2 2000/06/20 17:54:41 mike Exp $". # End of "$Id: makeinclude.no-cygwin,v 1.1.2.3 2000/06/20 18:47:33 carl Exp $".
# #