2000-08-03 13:55:54 +04:00
|
|
|
=begin
|
|
|
|
|
|
|
|
= How to build ruby using Visual C++
|
|
|
|
|
|
|
|
== Requirement
|
|
|
|
|
2009-03-04 18:26:17 +03:00
|
|
|
(1) Visual C++ 6.0 or later.
|
2000-08-03 13:55:54 +04:00
|
|
|
|
2007-10-31 18:53:19 +03:00
|
|
|
Note: if you want to build x64 or ia64 version, use native compiler for
|
|
|
|
x64/ia64.
|
|
|
|
|
2003-12-28 20:25:31 +03:00
|
|
|
(2) Please set environment variable (({INCLUDE})), (({LIB})), (({PATH}))
|
2000-08-03 13:55:54 +04:00
|
|
|
to run required commands properly from the command line.
|
|
|
|
|
|
|
|
Note: building ruby requires following commands.
|
|
|
|
* nmake
|
|
|
|
* cl
|
|
|
|
* lib
|
|
|
|
* dumpbin
|
|
|
|
|
2007-09-27 12:38:46 +04:00
|
|
|
(3) If you want to build from SVN source, following commands are required.
|
2004-11-12 11:33:17 +03:00
|
|
|
* bison
|
2003-12-28 20:25:31 +03:00
|
|
|
* sed
|
2007-09-27 12:38:46 +04:00
|
|
|
* ruby 1.8
|
2003-12-28 20:25:31 +03:00
|
|
|
|
2009-03-04 18:06:39 +03:00
|
|
|
(4) If you want built binaries to run on Windows 95 series (including
|
|
|
|
98 and Me), you need unicows.lib at compile time, and unicows.dll
|
|
|
|
at run time.
|
|
|
|
|
2000-08-03 13:55:54 +04:00
|
|
|
== How to compile and install
|
|
|
|
|
|
|
|
(1) Execute win32\configure.bat on your build directory.
|
2002-09-10 12:24:11 +04:00
|
|
|
You can specify the target platform as an argument.
|
2007-10-31 18:53:19 +03:00
|
|
|
For example, run `((%configure --target=i686-mswin32%))'
|
2003-12-28 20:25:31 +03:00
|
|
|
You can also specify the install directory.
|
|
|
|
For example, run `((%configure --prefix=<install_directory>%))'
|
|
|
|
Default of the install directory is /usr .
|
2000-08-03 13:55:54 +04:00
|
|
|
|
|
|
|
(2) Change ((|RUBY_INSTALL_NAME|)) and ((|RUBY_SO_NAME|)) in (({Makefile}))
|
|
|
|
if you want to change the name of the executable files.
|
|
|
|
And add ((|RUBYW_INSTALL_NAME|)) to change the name of the
|
|
|
|
executable without console window if also you want.
|
|
|
|
|
|
|
|
(3) Run `((%nmake%))'
|
|
|
|
|
2007-09-27 12:38:46 +04:00
|
|
|
(4) Run `((%nmake test%))'
|
2000-08-03 13:55:54 +04:00
|
|
|
|
2007-09-27 12:38:46 +04:00
|
|
|
(5) Run `((%nmake install%))'
|
2000-08-03 13:55:54 +04:00
|
|
|
|
|
|
|
This command will create following directories and install files onto them.
|
|
|
|
* <install_directory>\bin
|
|
|
|
* <install_directory>\lib
|
|
|
|
* <install_directory>\lib\ruby
|
|
|
|
* <install_directory>\lib\ruby\<MAJOR>.<MINOR>
|
|
|
|
* <install_directory>\lib\ruby\<MAJOR>.<MINOR>\<PLATFORM>
|
|
|
|
* <install_directory>\lib\ruby\site_ruby
|
|
|
|
* <install_directory>\lib\ruby\site_ruby\<MAJOR>.<MINOR>
|
|
|
|
* <install_directory>\lib\ruby\site_ruby\<MAJOR>.<MINOR>\<PLATFORM>
|
|
|
|
* <install_directory>\man\man1
|
|
|
|
If Ruby's version is `x.y.z', the ((|<MAJOR>|)) is `x' and the ((|<MINOR>|)) is `y'.
|
2002-09-10 12:24:11 +04:00
|
|
|
The default ((|<PLATFORM>|)) is `(({i386-mswin32}))'.
|
2000-08-03 13:55:54 +04:00
|
|
|
|
|
|
|
== Icons
|
|
|
|
|
|
|
|
Any icon files(*.ico) in the build directory, directories specified with
|
|
|
|
((|icondirs|)) make variable and (({win32})) directory under the ruby
|
|
|
|
source directory will be included in DLL or executable files, according
|
|
|
|
to their base names.
|
|
|
|
$(RUBY_INSTALL_NAME).ico or ruby.ico --> $(RUBY_INSTALL_NAME).exe
|
|
|
|
$(RUBYW_INSTALL_NAME).ico or rubyw.ico --> $(RUBYW_INSTALL_NAME).exe
|
|
|
|
the others --> $(RUBY_SO_NAME).dll
|
|
|
|
|
|
|
|
Although no icons are distributed with the ruby source or in the official
|
|
|
|
site, you can use anything you like. For example, followings are written
|
|
|
|
in Japanese, but you can download at least.
|
|
|
|
|
|
|
|
* ((<URL:http://homepage1.nifty.com/a_nakata/ruby/>)) or
|
|
|
|
((<icon itself|URL:http://homepage1.nifty.com/a_nakata/ruby/RubyIcon.ico>))
|
|
|
|
|
|
|
|
== Build examples
|
|
|
|
|
|
|
|
* Build on the ruby source directory.
|
|
|
|
|
|
|
|
ex.)
|
|
|
|
ruby source directory: C:\ruby
|
|
|
|
build directory: C:\ruby
|
|
|
|
install directory: C:\usr\local
|
|
|
|
|
|
|
|
C:
|
|
|
|
cd \ruby
|
2003-12-28 20:25:31 +03:00
|
|
|
win32\configure --prefix=/usr/local
|
2000-08-03 13:55:54 +04:00
|
|
|
nmake
|
|
|
|
nmake test
|
2003-12-28 20:25:31 +03:00
|
|
|
nmake install
|
2000-08-03 13:55:54 +04:00
|
|
|
|
|
|
|
* Build on the relative directory from the ruby source directory.
|
|
|
|
|
|
|
|
ex.)
|
|
|
|
ruby source directory: C:\ruby
|
|
|
|
build directory: C:\ruby\mswin32
|
|
|
|
install directory: C:\usr\local
|
|
|
|
|
|
|
|
C:
|
|
|
|
cd \ruby
|
|
|
|
mkdir mswin32
|
|
|
|
cd mswin32
|
2003-12-28 20:25:31 +03:00
|
|
|
..\win32\configure --prefix=/usr/local
|
2000-08-03 13:55:54 +04:00
|
|
|
nmake
|
|
|
|
nmake test
|
2003-12-28 20:25:31 +03:00
|
|
|
nmake install
|
2000-08-03 13:55:54 +04:00
|
|
|
|
|
|
|
* Build on the different drive.
|
|
|
|
|
|
|
|
ex.)
|
|
|
|
ruby source directory: C:\src\ruby
|
|
|
|
build directory: D:\build\ruby
|
|
|
|
install directory: C:\usr\local
|
|
|
|
|
|
|
|
D:
|
|
|
|
cd D:\build\ruby
|
2009-03-04 18:06:39 +03:00
|
|
|
C:\src\ruby\win32\configure --prefix=/usr/local
|
2000-08-03 13:55:54 +04:00
|
|
|
nmake
|
|
|
|
nmake test
|
2009-03-04 18:06:39 +03:00
|
|
|
nmake install DESTDIR=C:
|
2000-08-03 13:55:54 +04:00
|
|
|
|
2007-09-27 12:38:46 +04:00
|
|
|
* Build x64 version (requires native x64 VC++ compiler)
|
|
|
|
|
|
|
|
ex.)
|
|
|
|
ruby source directory: C:\ruby
|
|
|
|
build directory: C:\ruby
|
|
|
|
install directory: C:\usr\local
|
|
|
|
|
|
|
|
C:
|
|
|
|
cd \ruby
|
|
|
|
win32\configure --prefix=/usr/local --target=x64-mswin64
|
|
|
|
nmake
|
|
|
|
nmake test
|
|
|
|
nmake install
|
|
|
|
|
2000-08-03 13:55:54 +04:00
|
|
|
== Bugs
|
|
|
|
|
|
|
|
You can ((*NOT*)) use a path name contains any white space characters as
|
|
|
|
the ruby source directory, this restriction comes from the behavior of
|
|
|
|
(({!INCLUDE})) directives of (({NMAKE})).
|
|
|
|
((- you may call it a bug. -))
|
|
|
|
|
|
|
|
=end
|