summaryrefslogtreecommitdiffstats
path: root/README
diff options
context:
space:
mode:
authorWill Schroeder <will.schroeder@kitware.com>2001-01-12 12:43:28 (GMT)
committerWill Schroeder <will.schroeder@kitware.com>2001-01-12 12:43:28 (GMT)
commitca9099b551ad615a7368c0f71a7aa8fc3bc0c307 (patch)
tree7a719f53868934385563d3c8094f365f43bb4ceb /README
parent1690312e3ebc4d8127ccffd827f76c0f5efd04b4 (diff)
downloadCMake-ca9099b551ad615a7368c0f71a7aa8fc3bc0c307.zip
CMake-ca9099b551ad615a7368c0f71a7aa8fc3bc0c307.tar.gz
CMake-ca9099b551ad615a7368c0f71a7aa8fc3bc0c307.tar.bz2
README
Diffstat (limited to 'README')
-rw-r--r--README79
1 files changed, 48 insertions, 31 deletions
diff --git a/README b/README
index 0a6d1fb..f50e6a6 100644
--- a/README
+++ b/README
@@ -1,35 +1,62 @@
+WELCOME TO CROSS-PLATFORM MAKE
+
+CMake is a cross-platform, extensible build environment. It currently generates
+Unix makefiles and Microsoft Visual C++ projects/workspaces.
+
+To use CMake, create CMakeLists.txt in each directory that makes up your
+source repository. The CMakeLists.txt contains rules. Each rule does something
+different, like defines a list of source code, include directories, etc. Once
+CMake has processed all the rules in all the CMakeLists.txt files, it generates
+the appropriate "makefile(s)" for the system/compiler that you are on.
+
+THE BOOK OF RULES
+The key to using CMake is to learn the rules. Each rule has the same format:
+
+ NAME_OF_RULE(args....)
+
+where args is a white-space separated listed of arguments. (Arguments
+containing spaces should be quoted. For example:
+
+ INCLUDE_DIRECTORIES(./ d:/include "c:/Program Files/include")
+
+note that Unix-style slashes are used.
+
+Here are the important rules.
-CMakeLists.txt -> File in each directory that contains classes, exe, etc
-CMakeLists.txt contains the following:
# build targets
-WIN32_SOURCE_FILES =
-UNIX_SOURCE_FILES =
-ABSTRACT_CLASSES =
-SUBDIRS =
-EXECUTABLES =
+WIN32_SOURCE_FILES(file1 file2 ...)
+
+UNIX_SOURCE_FILES()
+
+ABSTRACT_CLASSES(class1 class2 ...)
+
+SUBDIRS()
+
+EXECUTABLES()
+
+# name of the library to build
+LIBRARY(library_name)
+
# make flags
-# make flags can use these varibles:
+# make flags can use these variables:
# ${CMAKE_BINARY_DIR} The root of the build tree where the binaries are
# ${CMAKE_SOURCE_DIR} The root of the source tree where configure is
-INCLUDE_DIRECTORIES =
-LINK_DIRECTORIES =
-LINK_LIBRARIES = # use the same name as ME =
-WIN32_LIBRARIES =
-UNIX_LIBRARIES =
-# name of the library to build
-ME =
+INCLUDE_DIRECTORIES()
-# add make commands
-BEGIN MAKE VERBATIM
-... # copy stuff into CMakeTargets.make directly
-LOCAL_BUILD_TARGETS = // These are done first before anything else
-END MAKE VERBATIM
-AUX_SOURCE_DIR =
+LINK_DIRECTORIES()
+
+LINK_LIBRARIES() = # use the same name as the LIBRARY() rule specified
+WIN32_LIBRARIES()
+UNIX_LIBRARIES()
+
+# define other targtes/source directories
+AUX_SOURCE_DIR(dir1 dir2 ...)
Windows / Visual Studio 6.0 programs
CMakeSetup.exe -> window MFC based GUI for configure on windows
CMakeSetupCMD.exe -> windows command line version of CMakeConfigure
+
To Build on Windows:
load CMake/Source/CMakeSetup.dsw
Build it
@@ -55,16 +82,6 @@ CMakeTargets.make -> generated rules for make style build in each directory
MakefileTemplate.make -> master makefile template used by configure to generate Makefiles
-Note on adding targets inside "BEGIN/END MAKE VERBATIM" lines:
-
- By default, after "includ"ing a makefile, make will attempt to bring
-that included file up to date. So, when you first run configure, your
-makefiles will _not_ contain the target you have asked for inside the
-VERBATIM tags. However, it will be added by CMake when make attempts
-to bring the included make files up to date. NOTE: this will make
-your head hurt if you think about it too long. Just accept that it
-works to ask for a build target that does not yet exist.
-
Unix install:
In place:
./configure