Это старая версия документа!
#summary|Psi+ on MS Windows: Build Instructions (win32-msvc2008) #labels Windows,Phase-Implementation
= Устаревшая статья =
= Microsoft Visual Studio 2008 (НЕ РЕКОМЕНДУЕТСЯ) =
Необходимый инструментарий
Скачиваем исходный код Psi из git-репозитория:
git clone git://git.psi-im.org/psi.git cd psi git submodule init git submodule update
Скачиваем:
- Win32 OpenSSL (full version)
Настройка переменных окружения и необходимых библиотек
В свойствах компьютера (Advanced → Environment Variables) прописываем следующие пути (переменная Path):
- *C:\Qt\4.4.3-msvc\bin*
- *C:\Program Files\Microsoft Visual Studio 9.0\VC\bin*
Добавляем следующие системные переменные:
- *QMAKESPEC=win32-msvc2008*
- *QTDIR=C:\Qt\4.4.3-msvc*
Копируем содержимое директории *C:\OpenSSL\lib\VC* в директорию *C:\Program Files\Microsoft Visual Studio 9.0\VC\lib* и переименовываем следующие файлы:
- *libeay32MD.lib* → *libeay32.lib*
- *libeay32MDd.lib* → *libeay32d.lib*
- *ssleay32MD.lib* → *ssleay32.lib*
- *ssleay32MDd.lib* → *ssleay32d.lib*
Выбираем директорию *C:\OpenSSL\include\openssl* и копируем всю директорию *openssl* в *C:\Program Files\Microsoft Visual Studio 9.0\VC\include*
В результате должно получиться так *C:\Program Files\Microsoft Visual Studio 9.0\VC\include\openssl*
Установка Qt
Скачанный архив *qt-win-opensource-src-4.4.3.zip* распаковываем в директорию *C:\Qt\4.4.3-msvc*
Запуск командой строки Visual Studio 2008 Command Prompt
Открываем командную строку Visual Studio 2008 Command Prompt:
*Start* → *Programs* → *Microsoft Visual Studio 2008* → *Visual Studio Tools* → *Visual Studio 2008 Command Prompt*
Для проверки правильности прописанного пути к *nmake.exe* пишем в cmd:
C:\Program Files\Microsoft Visual Studio 9.0\VC>nmake /? Microsoft (R) Program Maintenance Utility Version 9.00.21022.08 Copyright (C) Microsoft Corporation. All rights reserved. Usage: NMAKE @commandfile NMAKE [[options]] [[/f|makefile]] [[/x|stderrfile]] [[macrodefs]] [[targets]] Options: /A|Build all evaluated targets /B Build if time stamps are equal /C Suppress output messages /D Display build information /E Override env-var macros /ERRORREPORT:{NONE|PROMPT|QUEUE|SEND} Report errors to Microsoft /G Display !include filenames /HELP Display brief usage message ........
Конфигурирование Qt перед сборкой
Для вывода справки по команде *configure.exe* пишем в cmd:
C:\Qt\4.4.3-msvc>configure.exe -help
Для начала процесса конфигурирования Qt пишем:
C:\Qt\4.4.3-msvc>configure -debug-and-release This is the Qt for Windows Open Source Edition. You are licensed to use this software under the terms of the GNU General Public License (GPL) version 2 or 3. Type '2' to view the GNU General Public License version 2 (GPLv2). Type '3' to view the GNU General Public License version 3 (GPLv3). Type 'y' to accept this license offer. Type 'n' to decline this license offer. Do you accept the terms of the license? y
В результате видим следующее:
........ Reading C:/Qt/4.4.3-msvc/demos/spreadsheet/spreadsheet.pro Reading C:/Qt/4.4.3-msvc/demos/textedit/textedit.pro Reading C:/Qt/4.4.3-msvc/demos/chip/chip.pro Reading C:/Qt/4.4.3-msvc/demos/embeddeddialogs/embeddeddialogs.pro Reading C:/Qt/4.4.3-msvc/demos/undo/undo.pro Reading C:/Qt/4.4.3-msvc/demos/arthurplugin/arthurplugin.pro Reading C:/Qt/4.4.3-msvc/demos/sqlbrowser/sqlbrowser.pro Reading C:/Qt/4.4.3-msvc/demos/qtdemo/qtdemo.pro Reading C:/Qt/4.4.3-msvc/demos/mediaplayer/mediaplayer.pro Reading C:/Qt/4.4.3-msvc/demos/browser/browser.pro Reading C:/Qt/4.4.3-msvc/tools/qdoc3/qdoc3.pro Qt is now configured for building. Just run nmake. To reconfigure, run nmake confclean and configure.
Сборка Qt
Приступаем к сборке Qt. Для этого выполняем команду *nmake*:
C:\Qt\4.4.3-msvc>nmake
Процесс сборки Qt может занять некоторое время (20-60 минут).
Применение патчей к исходному коду Psi
- Скачиваем патчи для Psi+ и кладём в директорию *psi-git*.
- Скачиваем [[http://gnuwin32.sourceforge.net/packages/patch.htm|GNU/Patch for Windows]*.
*_Примечание:_* On MS-Windows, the patchfile must be a text file, i.e. CR-LF must be used as line endings. A file with LF may give the error: “Assertion failed, hunk, file patch.c, line 343,” unless the option ‘–binary’ is given.
- Запускаем *cmd* в директории *psi-git* и последовательно выполняем следующие команды:
patch -p1 < 000-about-psi-plus.diff patch -p1 < 005-psi-win32-pre-patching.diff patch -p1 < 020-psi-muc-kickban-reasons.diff patch -p1 < 030-psi-vcard-save.diff patch -p1 < 040-psi-muc-topic.diff patch -p1 < 050-psi-quick-disco.diff patch -p1 < 060-psi-receipts.diff patch -p1 < 070-psi-muc-user-count.diff patch -p1 < 080-psi-popup-avatar.diff patch -p1 < 090-psi-entity-time.diff patch -p1 < 100-psi-mood-icons.diff patch -p1 < 110-psi-muc-change-affiliation.diff patch -p1 < 120-psi-muc-nickclick-chat.diff patch -p1 < 130-psi-send-button-arrow.diff patch -p1 < 140-psi-bookmark-skip.diff patch -p1 < 150-psi-muc-notify-highlight.diff ..............
*_Примечание:_* Перед скачиванием и установкой патчей, желательно проверить правильность имён файлов с их текущим списком по [[http://psi-dev.googlecode.com/svn/trunk/patches/series.txt|адресу]*.
Компиляция Psi в командной строке Visual Studio 2008 Command Prompt
Переходим в директорию *psi-git* с файлами исходного кода Psi и проверяем правильность установки путей и переменных:
D:\psi-git>qmake -v QMake version 2.01a Using Qt version 4.4.3 in C:\Qt\4.4.3-msvc\lib
D:\psi-git>echo %QMAKESPEC% win32-msvc2008
После этого выполняем последовательно следующие команды:
D:\psi-git>qmake psi.pro
Затем:
D:\psi-git>nmake
После окончание процесса компиляции видим собранное приложение в *D:\psi-git\src\release\psi.exe*.
Создание проекта psi.vcproj для Microsoft Visual Studio 2008
Переходим в директорию *psi-git/src* и запускаем команду на создание проекта *psi* для Microsoft Visual Studio 2008:
D:\psi-git\src>qmake -t vcapp src.pro
После выполнения данной команды в этой же директории видим файл *psi.vcproj*.
Открываем файл *psi.vcproj* в Microsoft Visual Studio 2008.
Переключаемся на конфигурацию *Release*, сохраняем *psi.sln* и выполняем команду *Build*.
*_Примечание_*: при возникновении проблем с компиляцией qca-файлов необходимо в директории *psi-git/third-party/qca* сделать *qmake* и затем *nmake*.