summaryrefslogtreecommitdiffstats
path: root/doc/win32.compiling.1.2.txt
diff options
context:
space:
mode:
Diffstat (limited to 'doc/win32.compiling.1.2.txt')
-rw-r--r--doc/win32.compiling.1.2.txt269
1 files changed, 269 insertions, 0 deletions
diff --git a/doc/win32.compiling.1.2.txt b/doc/win32.compiling.1.2.txt
new file mode 100644
index 00000000..bb396a33
--- /dev/null
+++ b/doc/win32.compiling.1.2.txt
@@ -0,0 +1,269 @@
+Win32 KVIrc compiling 1.2
+a tutorial by <Grifisx>
+updated by <LoSko> on 2007/01/18
+
+english translation by <etherea`>
+
+Index
+
+@ Prologue
+@ Ingredients
+@ Providing ingredients
+@ Setting up the ambiency
+@ Setting ambiency variables
+@ Compiling
+@ Creating ambiency for setup
+@ Creating setup
+
+@ Prologue
+
+This is meant to be a simple guide to KVIrc compiling under Windows ambiency, so
+that everyone who's willing to try to compile the latest version of this cross platform
+client can easily do without the need for the latest snapshot/development to be
+released.
+
+@ Ingredients
+
+1) CVS version of KVIrc
+2) Visual C++ 2005 Express
+3) SDK package from Microsoft
+4) Perl.
+5) gettext for Windows
+6) Innosetup or NSIS
+7) Non Commercial QT 3.2.1
+8) OpenSSL
+9) zlib for Win32
+
+@ Providing ingredients
+
+So, let's see where to find the necessary ingredients to bake up our freshy KVIrc.
+
+-1) CVS version of KVIrc
+
+To get this out you will need a CVS client for Windows, then type the following
+command:
+
+cvs -z3 -d:pserver:anonymous@cvs.kvirc.net:/cvs co kvirccvs
+
+
+And just in case you can find instructions here:
+Link: http://www.kvirc.net/?id=cvs
+A suggestion for a tiny and free CVS is Tortoise CVS.
+Link: http://www.tortoisecvs.org/
+
+-2) Visual C++ 2005 Express
+
+This compiler is free (at least for the moment), you will only need to register in order to
+get it and use it for free, use it!
+Link: http://msdn.microsoft.com/vstudio/express/visualc/
+
+-3) SDK package from Microsoft
+
+This one too is for free, then download and install it!
+Link: http://www.microsoft.com/downloads/details.aspx?FamilyId=A55B6B43-E24F-4EA3A93E-40C0EC4F68E5&displaylang=en
+
+-4) Perl
+Perl is needed to create documentation and make perl module works, you can
+download it from here:
+Link: http://www.activestate.com/Products/ActivePerl/?
+
+-5) gettext for Windows
+Download and install it, it's needed to create languages localization files:
+Link: http://sourceforge.net/projects/gettext
+Note: be sure to install gettext in this directory C:\Program Files\GnuWin32 so that all the
+executables are located in C:\Program Files\GnuWin32\bin otherwise you'll be forced to
+change something in the file needed to create the setup ambiency.
+
+-6) Innosetup
+
+Another free program, required to create the final setup.
+Link: http://www.jrsoftware.org/isinfo.php
+If you are using NSIS you can have your copy here:
+Link: http://nsis.sourceforge.net/Download
+
+-7) Non Commercial QT 3.2.1
+
+That's probably the most difficult thing to acquire; you can try find a book on QT that
+has it enclosed (the non commercial one) or you'll have to figure out how to find it out.
+You can buy a commercial version too, 3.x.x higher than 3.2.1.
+
+Book: C++ GUI Programming with QT 3
+Link: http://www.amazon.com/gp/product/0131240722/102-11831924381702?v=glance&n=283155
+If you are pretty acknowledged with compiling you can try these instructions:
+Link: http://qtwin.sourceforge.net/qt3-win32/compile-msvc-2005.php
+Even if this last choice's a bit nasty to make out working =)
+You still can find some precompiled version of this free stand (found on the same site of
+qtwin even if a bit older) but beware: choosing this last chance will make KVIrc XP
+themes not supported.
+By using a different version of QT you'll need to modify every KVIrc project adapting
+the qt.xxxx.dll and headers and libraries paths.
+For example, assuming you have installed commercial QT 3.3.4 you'll have to modify
+the projects this way:
+a) selecting Properties of each project then ->Linker and ->Input
+b) store the right library in the qt-mtnc321.lib matching the installed version
+requirements, ie qt-3.3.4.lib. To know the exact name of your .lib file to be linked just go
+to the directory where you did installed QT, in the subfolder /lib (like C:\Qt\3.3.4\lib)
+
+-8) OpenSSL
+That is needed in order to compile SSL support for KVIrc, you can have libraries and
+everything else from here:
+Link: http://www.slproweb.com/products/Win32OpenSSL.html
+
+-9) zlib for win32
+
+To give KVIrc the ability to save log files in compressed format that's what you need.
+Link: http://gnuwin32.sourceforge.net/packages/zlib.htm
+
+That's the main page, but you will need the developers files:
+Link: http://gnuwin32.sourceforge.net/downloadlinks/zlib-lib-zip.php
+Extract them in any folder you may like, my own suggestion is folder C:\lib for your
+convenience; directory tree will be as follows:
+
+C:(dir)
+|__zlib(dir)
+|__include(dir)
+| |__zconf.h
+| |__zlib.h
+|__lib(dir)
+|__zlib.lib
+|__zlib.exp
+
+Remember where did you have this folder extract because you will have to setup paths
+of the include files (the .h files) and of the libraries (the .lib files) in ambiency variables
+of your operating system.
+
+@ Setting up the ambiency
+
+Install in the following order (theoretically it is not necessary a given order but this
+“recipe” is fully oriented to non expert users):
+1-Visual C++ 2005 Express
+2-SDK ; once you have installed it take the folders Lib, Include and Bin (you will find
+them all in the SDK given path – generally in folder C:\Program Files\Microsoft Platform
+SDK) and copy them in the folder \SDK\v2.0 that is under the installation path of Visual
+C++ (generally in C:\Program Files\Microsoft Visual Studio 8\SDK\v2.0).
+Attention: when copying these files you'll be prompted to overwrite one or more files;
+just answer NO.
+3-QT 3.x.x ; during the installation you'll be prompted to record ambiency variables:
+answer YES.
+4-OpenSSL ; during the installation you'll be prompted to record ambiency variables:
+answer YES.
+5-Perl ; during the installation you'll be prompted to record ambiency variables:
+answer YES.
+6-gettext
+7-Innosetup or NSIS or both =) (Freedom is the power to choose ;))
+8-zlib ; if you did download the install&compile package; otherwise just unpack
+and/or extract the ready-to-use pakage wherever you may like (generally in folder C:\).
+
+@ Setting ambiency variables
+
+Now we need to set up every variable of this ambiency, needed in order the compiler
+will be able to find every library from which KVIrc depends.
+Right-button on Resources then Properties -> Advanced -> Ambient Variables and this will
+engage all QT system variables (QTDIR) set; if that doesn't match you will need to
+reinstall QT and remember to answer YES once you're prompted for setting all ambiency
+variables, otherwise you will need to set them manually – that parts from this tutorial.
+
+In the section dedicated to variables of the actual user add (if you don't have it yet) the
+following and then give the right paths that are on your own machine (hereby are my
+own paths):
+
+Variable:
+
+PERLDIR
+Value:
+C:\perl
+Meaning:
+Directory that stores Perl
+
+Variable:
+ZLIBLIBDIR
+Value:
+C:\zlib\lib
+Meaning:
+Directory that stores file .lib of zlib installed library, the file name must be zlib.lib
+
+Variable:
+OPENSSL
+Value:
+C:\OpenSLL
+Meaning:
+Installation folder of OpenSSL
+
+Variable:
+SSLINCDIR
+Value:
+C:\OpenSSL\include
+Meaning:
+Directory that stores OpenSSL .h files
+
+Variable:
+SSLLIBDIR
+Value:
+C:\OpenSSL\lib\VC
+Meaning:
+OpenSSL .lib files storage
+
+Variable:
+MSGFMT
+Value:
+C:\Program Files\GnuWin32\bin\msgfmt.exe
+Meaning:
+msgfmt executable path
+
+After you've added all the variables with their own values you need to reboot.
+
+@ Compiling
+
+Go to folder kvirccvs\kvirc and open the file kvirc_vc05.sln then -for the less
+experienced-select Build -> Configure Manager -> Release and run the compiling with
+Build ->Build Solution.
+You'll need to wait a little before the building ends, mostly that's up to your processor
+(on a P3 800MHz it takes about 40/45 minutes, on a P4 3000 just 10/15 minutes).
+Now.. pray everything is going to get the right place and no unexpected to happen; but
+in case you do have troubles here are 3 different solutions:
+
+a) read this tutorial once more, hoping you missed some points;
+b) try to find out where the problem is;
+c) step to Azzurranet on channel #kvirc.net and ask for Grifisx or Noldor or Pragma.
+
+@ Creating ambiency for setup
+
+If you're reading this, thank God, your patience and your mother (yes, yet she didn't
+managed to kill you death nevertheless you spent 28 hours a day reading lines on a
+monitor) you're almost done!
+The latest 2 steps are quite easy.
+Go to folder kvirccvs\kvirc\win32build and run makedist.vbs file.
+Then run the process, on which end you'll get a folder named pakage; be sure inside
+there are kvirc.exe, kvilib.dll, the folder with every KVIrc module and the following dlls:
+
+ssleay32.dll
+libeay32.dll
+qt-mtnc3321.dll
+perl58.dll
+zlib1.dll
+idleui.dll
+msvcr80.dll
+
+
+If you see something missing just run up a search onto your system and copy them into
+the pakage directory.
+Check even the file Microsoft.VC80.CRT.manifest is placed both in root folder and sub folder
+modules, otherwise copy it into them (files are stored into kvirccvs\kvirc\data\manifests ;
+in this last case you will only need to rename the given file
+Microsoft.VC80.CRT.modules.manifest into Microsoft.VC80.CRT.manifest before you put it in
+the modules folder).
+
+@ Creating setup
+
+Easypeasy!
+After installation of Innosetup launch file KVIrc.iss that houses in folder
+kvirccvs\kvirc\win32build and run the script so that at the end of the process you'll find
+a freshy hot setup.exe in folder kvirccvs\kvirc\win32build\package\setup.
+If you did chose NSIS: right click on the KVIrc.nsi installation script that is found in
+folder kvirccvs\kvirc\win32build and run Compile NSIS Script.
+This way you'll have a KVIrc.VERSION-dev-DATE.exe in your actual directory!
+Run.
+If everything went ok then.. EnjoY! =D
+
+Tonino Imbesi
+<Grifisx>