38 KiB
% LameXP Audio-Encoder Front-End – Manual
Introduction
LameXP is a graphical user-interface (front-end) for various of audio encoders: It allows you to convert your audio files from one audio format to another one in the most simple way. Despite its name, LameXP is not only a front-end for the LAME MP3 encoder, but supports a wide range of output formats, including MP3, Ogg Vorbis, Opus, AAC/MP4, FLAC, AC-3 and Wave Audio. The number of supported input formats is even bigger! Furthermore LameXP not only runs on Windows XP, but also on Windows 7, 8 and 10 as well as many other operating systems.
Since all the encoders and decoders that are used by the LameXP software are already built-in (with one exception), you do not need to install any additional software, such as "Codecs", "Filters" or "Plug-ins", on your computer. Everything works "out of the box". You can even use LameXP as a "portable" application, i.e. you can run LameXP directly off your USB stick. Moreover, LameXP was designed for batch processing. This means that you can convert a huge number of audio files, e.g. a complete album or even your entire music collection, in just a single step. At the same time, LameXP is able to process several audio files concurrently, so it can take full advantage of modern multi-core processors! However, LameXP is not only optimized for speed, it also provides excellent sound quality by using the most sophisticated audio encoders currently available.
In addition to that, LameXP provides full support for meta information, including cover artwork. So when converting your audio files with LameXP, any existing meta information will be retained – to the highest possible extent. Of course, there also is an easy-to-use meta-tag editor for adding new meta information or managing the existing meta information. On top of it all, LameXP provides full Unicode support, for meta information as well as file names, thus problems with "intentional" character sets are avoided. Likewise, thanks to our translators, the user-interface of the LameXP software is available in many different languages, including English, German, Spanish and Chinese. Last but not least, LameXP supports a number of post-processing filters, including sample rate conversion, normalization (gain adjustment), tone adjustment as well as down-mixing.
Platform Support##
Tier #1: LameXP is currently being developed on the following platforms:
- Microsoft Windows 8.1, 32-Bit and 64-Bit editions
- Microsoft Windows 7 with Service Pack 1, 32-Bit and 64-Bit editions
- Microsoft Windows XP with Service Pack 3 (see remarks)
Tier #2: The following platforms should work too, but aren't tested extensively:
- Microsoft Windows 10, 32-Bit and 64-Bit editions
- Microsoft Windows 8.0, 32-Bit and 64-Bit editions
- Microsoft Windows Vista with Service Pack 2, 32-Bit and 64-Bit editions
- Microsoft Windows XP x64 Edition with Service Pack 2
- Microsoft Windows Server 2008 with Service Pack 2
- Microsoft Windows Server 2008 R2 with Service Pack 1
- GNU/Linux (e.g. Ubuntu 12.04), using Wine v1.4+
The following legacy platforms are not actively supported any longer:
- Microsoft Windows 2000
- Microsoft Windows NT 4.0
- Microsoft Windows Millennium Edition
- Microsoft Windows 98
- Microsoft Windows 95
Remarks: Windows XP has reached "end of life" on April 8th, 2014. This means that Microsoft has stopped all support for Windows XP. Thus no updates or bugfixes are made available to regular Windows XP users since that date, not even security fixes! Thus, all the security vulnerabilities that have been discovered after the deadline – and all the security vulnerabilities that are going to be discovered in the future – will persists forever! Consequently, using Windows XP has become a severe security risk, and the situation is only going to get worse. While LameXP will continue to support Windows XP (note that Service Pack 3 is required!) for the foreseeable future, we highly recommend everybody to update to a less antiquated system now. Windows XP support will be discontinued in a future version, when most users have migrated to a contemporary system.
Output Formats (Encoders)
Currently the following output formats (audio encoders) are supported by LameXP:
- Ogg Vorbis by Xiph.org, using the OggEnc2/libvorbis encoder with aoTuV [built-in]
- Opus Interactive Audio Codec by Xiph.org and Mozilla, using the Opus-Tools [built-in]
- MPEG Audio-Layer III (MP3), using the LAME encoder [built-in]
- Advanced Audio Coding (AAC), using Nero AAC or QAAC encoder [separate download]
- Free Lossless Audio Codec (FLAC) [built-in]
- ATSC A/52 (aka "AC-3"), using the Aften encoder [built-in]
- Monkey's Audio (APE), lossless audio compression [built-in]
- DCA, using the DCA Enc encoder software (still experimental) [built-in]
- Uncompressed PCM / Waveform Audio File (WAV/RIFF)
Input Formats (Decoders)
Currently the following input formats (audio decoders) are supported by LameXP:
- AC-3 (ATSC A/52), using Valib decoder [built-in]
- Advanced Audio Coding (AAC), using FAAD decoder [built-in]
- Apple Lossless (ALAC) [built-in]
- Apple/SGI AIFF [built-in]
- Avisynth, audio only [requires Avisynth 2.5.x to be installed]
- Digital Theater System, using Valib decoder [built-in]
- Free Lossless Audio Codec (FLAC) [built-in]
- Microsoft ADPCM [built-in]
- Monkey's Audio (APE) [built-in]
- MPEG Audio-Layer I (MP1), using mpg123 decoder [built-in]
- MPEG Audio-Layer II (MP2), using mpg123 decoder [built-in]
- MPEG Audio-Layer III (MP3), using mpg123 decoder [built-in]
- Musepack [built-in]
- Opus Audio Codec [built-in]
- Shorten [built-in]
- Speex [built-in]
- Sun/NeXT Au [built-in]
- The True Audio (TTA) [built-in]
- Uncompressed PCM / Waveform Audio File (WAV/RIFF) [built-in]
- WavPack Hybrid Lossless Audio [built-in]
- Windows Media Audio (WMA), using wma2wav [built-in]
Leagl Information
The LameXP software was developed, from the scratch, by LoRd_MuldeR <MuldeR2@GMX.de>. Consequently, all copyrights on the LameXP software exclusively belong to LoRd_MuldeR. The right to use, modify and redistribute the LameXP software according to the license terms is granted to everybody. Please see below for license details! If you want to use the LameXP software in a way that is not covered by the license terms, e.g. if you want to include the LameXP software (or parts of it) in a proprietary software, written permission by LoRd_MuldeR is required.
More OpenSource projects by LoRd_MuldeR can be found at http://muldersoft.com/ and https://github.com/lordmulder. Please do not send e-mail to LoRd_MuldeR directly, if the problem or suggestion can be discussed on the support forums or on the issue tracker!
Third-party Software
It has to be noticed that LameXP uses a number of third-party applications and libraries. The copyright on these third-party tools belongs to the individual authors. All third-party tools that are included in the official distribution packages of LameXP are distributed in accordance with the respective software license. For legal reasons, some of the third-party tools can not be redistributed along with LameXP and therefore need to be obtained separately. For more details on the third-party tools that are used by the LameXP software, please refer to the "Third-party software" tab in the "About" dialogue. Moreover, various people have contributed translations to the LameXP project. These translation are redistributed with permission of the respective contributor. For more information about our contributors, please refer to the "Contributors" tab in the "About" dialogue.
License Terms
LameXP is free software, released under the terms of the GNU General Public License (GPL), version 2. The licenses for most software and other practical works are designed to take away your freedom to share and change the works. In contrast, the GPL is designed to guarantee your freedom to share and change all versions of the software. In other words, the GPL ensures that free software will remain free for all of its users. LameXP adds some additional terms in order to keep your computer safe from unwanted software. See the GNU General Public License for more details!
LameXP - Audio Encoder Front-End
Copyright (C) 2004-2014 LoRd_MuldeR <MuldeR2@GMX.de>
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Addendum: When distributing binaries of the LameXP software, it is strictly forbidden to bundle the LameXP program files and/or the LameXP installation program with any kind of Adware, Spyware or PUP (potentially unwanted program), including, but not limited to, any downloaders, dialers, browser toolbars/extensions or restricted shareware/demo programs. It is, however, perfectly legitimate to bundle LameXP with other OpenSource programs, according to the OSI (Open Source Initiative). Finally, it is also legitimate to bundle LameXP with commercial software, as long as that software does not meet the criteria of Adware, Spyware or PUP. If you bundle the LameXP software with another software, you are required to make sure that the user is provided with an easy way to install and start the LameXP software separately from that other software.
Install Instructions
This chapter explains how to install the LameXP software on your computer. If LameXP has already been installed on your computer, you may skip this chapter.
Install the LameXP Software
Distribution packages of the LameXP software is provided in two different flavours: a self-running setup program and a ZIP package. For regular users, using the setup program is highly recommended!
Setup Program
In order to start the installation process, simply double-click on the downloaded LameXP setup program, e.g. LameXP.yyyy-mm-dd.Release-Static.Build-xxxx.exe
.
Note: Shortly after launching the setup program, an UAC (User Access Control) dialogue may appear. This is a standard Windows security feature, so don't worry! You have to choose "Yes", if you wish to continue the installation process.
Now simply follow the instructions of the setup wizard, which will guide you through the installation process…
Note: Please do not change the "Destionation Folder", unless you know exactly what you are doing. The "Destionation Folder" cannot be changed, when upgrading an existing LameXP installation.
Congratulation, LameXP has been installed successfully on your computer!
Note: If you keep the "Run LameXP …" option enabled and click on the "Finish" button, the LameXP software will be launched immediately.
ZIP Package
If you decided for the ZIP package, you need to open the downloaded ZIP file, e.g. LameXP.yyyy-mm-dd.Release-Static.Build-xxxx.zip
, in your favourite file archive software (we recommend using 7-Zip or WinRAR).
This step may be slightly different, depending on what file archive software (e.g. 7-Zip or WinRAR) you are using. Select all files in the LameXP ZIP archive and extract them to a new/empty directory of your choice.
Note: It is very important that you have write-access to the chosen destination directory. So make sure that you choose a directory where the required access rights are granted!
Congratulation, LameXP has been installed successfully on your computer! Now double-click on the LameXP.exe
program file in order to launch the application!
Portable Mode
First of all, it is important to note that there is no such thing as a separate "portable version" or "portable edition" of the LameXP software. Instead, all versions of the LameXP software always are "portable" – in the sense that the LameXP software is fully self-contained and thus no additional dependencies (libraries, frameworks, codecs or whatsoever) need to be installed on the computer separately. Or, in other words, the LameXP software is designed to work "out of the box". And this applies regardless of whether you choose the setup program or the ZIP package!
Nonetheless, the LameXP software supports a so-called "portable mode", which can be enabled or disabled at any time. By default, i.e. when the "portable mode" is not enabled, LameXP will store all of its configuration files in the current user's %APPDATA%
directory. This is the correct way of storing user-specific configuration files on a modern multi-user operating system. Some users, however, may wish to use LameXP as a portable application. For example, they may wish to run the LameXP software directly off an USB flash drive – and do that on many different machines. In this particular situation, storing the configuration files in the same location where the LameXP program file resides (e.g. on the USB flash drive), instead of the local %APPDATA%
directory, may come in handy! And that is exactly what LameXP does when the "portable mode" is enabled.
Enable the Portable Mode
If you fully understand what the consequences of the "portable mode" are and still want to enable this mode, then simply rename the LameXP program file form LameXP.exe
to LameXP-Portable.exe
. You must exit LameXP, before you can rename the program file!
Note: By default, the LameXP installation directory is either C:\Program Files (x86)\MuldeR\LameXP
or C:\Program Files\MuldeR\LameXP
. However, this can be changed by the user during the setup process.
Warning
While the "portable mode" is in effect, it is the user's responsibility to ensure that LameXP will be provided with the proper access rights to save/load its configuration files to/from the LameXP program directory!
Note that the directories C:\Program Files (x86)
and C:\Program Files
usually are "protected" by the operating system, so LameXP may not be able to write into these directories.
Disable the Portable Mode
If you wish to disable the "portable mode" again, then all you need to do is renaming the LameXP program file form LameXP-Portable.exe
back to LameXP.exe
. You must exit LameXP, before you can rename the program file!
Note: After the "portable mode" has been disabled, any configurations files that may have been created in the LameXP installation directory will no longer be recognized. Therefore, you can delete these files safely…
Install the AAC Encoder
For legal reasons, the AAC (Advanced Audio Coding) encoder can not be included in the official LameXP distribution packages. Therefore, you need to download and install the AAC encoder manually. Don't worry, it's easy!
LameXP can use the Nero Digital AAC encoder as well as the QAAC (Apple iTunes/QuickTime) encoder. This chapter describes how to set up one of these AAC encoders for use with the LameXP software.
Note: If you are uncertain which AAC encoder to choose, please be aware that the QAAC encoder may produce slightly better sound quality, according to listening tests, while the Nero Digital encoder is less hassle to install.
Nero Digital AAC Encoder
First of all, you need to download the Nero AAC encoder from the official Nero Digital web-site. The download is free of charge:
- http://www.nero.com/eng/company/about-nero/nero-aac-codec.php
- http://www.free-codecs.com/download/Nero_AAC_Codec.htm
Simply scroll down, click the "I agree" button, and enter user@example.com
when asked for an e-mail address. Finally, click the "Download" button, which initates the download of the required NeroAACCodec-1.5.1.zip
file.
Note: Although the ZIP file is called NeroAACCodec-1.5.1.zip
, it actually contains version 1.5.4.0 of the Nero AAC encoder software. Please check the included changelog.txt
to verify this!
Now open the downloaded ZIP file with your favourite file archive software (we recommend using 7-Zip or WinRAR) and navigate to the "win32" sub-directory.
Finally, extract all the three files neroAacDec.exe
, neroAacEnc.exe
and neroAacTag.exe
into the LameXP installation directory. That is the directory where your LameXP executable file, i.e. the LameXP.exe
, is located.
Note: By default, the LameXP installation directory is either C:\Program Files (x86)\MuldeR\LameXP
or C:\Program Files\MuldeR\LameXP
. However, this can be changed by the user during the setup process.
Once the required Nero AAC files have been put into the proper place, simply restart LameXP in order to enable the AAC encoding support!
QAAC (Apple AAC) Encoder
Getting the Apple/QuickTime AAC encoder ready involves two separate steps: In the first place we will install the QAAC encoder, and in the second place we will install the Apple AAC encoder libraries.
Install QAAC Encoder
First of all, you need to download the QAAC application, which provides a CLI font-end to the Apple/QuickTime AAC encoder. QAAC is provided as an Add-in for LameXP and is available from the following locations:
- http://sourceforge.net/projects/lamexp/files/Miscellaneous/Add-ins/qaac/
- http://muldersoft.com/misc/lamexp/add-ins/qaac/
Now open the downloaded ZIP file, e.g. LameXP.qaac-addin.yyyy-mm-dd.zip
, with your favourite file archive software (we recommend using 7-Zip or WinRAR) to find the required QAAC program files.
Note: The LameXP software generally expects the latest version of the QAAC add-in; and the QAAC add-in is designed to work with the latest version of the LameXP software. Make sure your files are up-to-date!
Please extract all the three files, the program qaac.exe
plus its DLLs libsoxr.dll
and libsoxconvolver.dll
, into the LameXP installation directory. That is the directory where your LameXP executable file, i.e. the LameXP.exe
, is located.
Note: By default, the LameXP installation directory is either C:\Program Files (x86)\MuldeR\LameXP
or C:\Program Files\MuldeR\LameXP
. However, this can be changed by the user during the setup process.
Install Apple AAC Encoder Libraries
Next, the actual Apple/QuickTime AAC encoder libraries, which are part of the so-called "Apple Application Support" package, need to be installed on your computer. QAAC can not work without these libraries!
The required "Apple Application Support" package is included, for example, in the official setup packages of QuickTime or iTunes for Windows, which can be obtained from the Apple web-site free of charge:
Since you usually do not want to install the complete QuickTime (or iTunes) software on your computer, please only download the QuickTime (or iTunes) setup package, but do not actually run the installer!
Instead, open the QuickTimer setup program, i.e. QuickTimeInstaller.exe
, with your favourite file archive software (we recommend using 7-Zip or WinRAR) and extract the required AppleApplicationSupport.msi
package.
After the "Apple Application Support" setup package has been extracted, you can launch it by double-clicking on the AppleApplicationSupport.msi
file. Then simply follow the installer's instructions.
Once the QAAC encoder as well as the Apple AAC encoder libraries ("Apple Application Support") have been installed properly, simply restart LameXP in order to enable the AAC encoding support!
Note: You may run qaac.exe --check
from the command prompt to ensure that QAAC has been set up correctly. Expected output is qaac 2.xx, CoreAudioToolbox x.x.x.x
.
Tutorial (Step-by-Step Guide)
This tutorial will teach you, step by step, how to convert your audio files using the LameXP software. The tutorial assumes that LameXP is already installed on your computer.
Source Files
First of all, you need to add all source files that you want to convert. So switch to the "Source Files" tab, just in case that tab is not active already, and then click the "Add File(s)" button.
This will bring up a standard file selection dialogue. Now simply select the files that you want to add and click the "Open" button. You can repeat this step multiple times, e.g. to add files from different directories.
All files you have added, so far, will show up in the list. You can click the "Remove" button to remove a single file from the list or "Clear" to remove them all. Click the "Show details" button to show details about a file.
Did you know? Files can also be added via Drag & Drop. Just grab the files that you want to add in your Explorer window and drop them onto the LameXP main window (or onto the LameXP "dropbox" widget).
Output Directory
Next, you need to choose the output directory, i.e. the directory where the converted files will be saved. Switch to the "Output Directory" tab and choose the desired output directory from the directory tree view.
Note: There are several quick navigation buttons below, which will allow you to jump quickly to your personal "Home" folder, "Desktop" folder and "Music" folder, respectively.
Sometimes you may wish to store the converted files in a new (sub-)folder. In this case, simply click the "Make New Folder" button, enter the desired folder name and hit the "OK" button.
The new folder is going to be created inside the current directory and will be selected automatically. You can repeat this step multiple times in order to created nested sub-folders.
Did you know? If you enable the "Save output files in the same directory where the input file is located" option, each output file will be saved to the same location where the corresponding source file resides.
Compression Settings
Finally, you need to choose your compression settings. First, and most important, you must decide for an output audio format (encoder). Depending on your needs and preferences, you can choose between MP3, Ogg/Vorbis, Opus, AAC/MP4, FLAC and others.
Note: If you are uncertain which audio format to choose, then this article by Lifehacker is a good starting point. Also see the comparison of audio coding formats on Wikipedia. If still uncertain, just go with good old MP3 😉
Once you have decided for an audio format, you need to choose a rate-control mode next. The available rate-control modes include VBR (quality-base variable bitrate), ABR (average bitrate) and CBR (constant bitrate). Not all modes are available for all audio formats.
Note: If you are uncertain which rate-control mode to chose, the guideline is that VBR mode should be preferred over ABR mode whenever possible. And CBR mode generally should be avoided. See also Wikipedia's article on variable bitrate encoding.
Last but not least, you need to choose the desired target bitrate or quality-level. Put simply, this controls the "quality vs. file size" trade-off. You choose a target quality-level in case of VBR mode, and you choose a target (average) bitrate in case of ABR or CBR mode.
Note: If you are uncertain which bitrate or quality-level to choose, bare in mind that a higher bitrate (or a better quality level) results in better audio quality, but also produces larger files – and vice versa. "Level 2" or "192 kbps" is a typical choice for MP3.
Did you know? You can click on the "Reset" link at any time in order to reset all available settings for all available encoders to their factory defaults.
Processing
When everything has been set up properly, the time has come to actually start the encoding process. So simply click the "Encode Now" button in order to get going!
This will bring up the "Processing" dialogue. LameXP will now convert all your audio files on the list. Depending on the number of audio files and depending on the performance of your system, this may take several minutes, so please be patient 😉
Note: In order to leverage the power "multi-core" processors and thus massively speed-up the encoding process, LameXP will run multiple encoding jobs in parallel – provided that your system has multiple processor cores and that there are enough encoding jobs left in the queue.
The "Processing" dialogue is going to turn green, as soon as all encoding jobs have finished successfully. If anything went wrong, e.g. if one of the encoding jobs failed for some reason, it will turn red instead.
Did you know? You can double-click on a completed (or failed) job in the list, in order to bring up a dialogue with all details about the specific job. This is especially useful, if something went wrong.
Help & Support
Before you report any problems that you may have encountered with the LameXP software, please make sure that the problem can be reproduced with the latest release version of LameXP!
Download Mirrors
The latest official release of the LameXP software can be obtained from one of the following official download mirrors:
- https://github.com/lordmulder/LameXP/releases/latest
- http://sourceforge.net/projects/lamexp/files/
- https://lamexp.codeplex.com/releases/
- https://bitbucket.org/lord_mulder/lamexp/downloads
- https://www.assembla.com/spaces/lamexp/documents
- http://www.free-codecs.com/lamexp_download.htm
- http://www.videohelp.com/tools/LameXP
It is highly recommended to download LameXP only from one of the official mirrors listed above. We are not responsible for the integrity and trustworthiness of LameXP downloads you may have received from other locations!
Diagnostic Output
If you want to report any problems that you have encountered with the LameXP software, please provide as much details as possible. Diagnostic output can be especially helpful here!
-
If a certain encoding job has failed, you can double-click the failed job in the LameXP "Processing" dialogue, which will bring up a detailed log for that job. Use the "Copy to Clipboard" button to save that information.
-
You can launch the LameXP application with the additional command-line parameter
--console
in order to enable the LameXP debug console, which provides many information on what is going on "behind the scenes". -
The environment variable
MUTILS_LOGFILE
may be used to specify a log file that will be created by LameXP. The information that are saved to the log file are the same as those available from the debug console.
Note: We highly recommend using a web-service like Gist, Pastie or Pastebin in order to share your diagnostic information. Please avoid posting long log files directly on the forums!
Bugtracker
The recommended way to submit bug reports or feature requests to the LameXP developers is using the issue tracking system at our GitHub project site:
Note: In order to use the issue tracking system, you need to log in with your GitHub account. Creating a GitHub account is easy and completely free of charge, simply click here!
Support Forum
If you want to discuss the development of the LameXP software, help other users or receive help from other users, please use the LameXP thread at Doom9's Forum:
- http://forum.doom9.org/showthread.php?t=157726 – English
- http://forum.gleitz.info/showthread.php?t=37956 – German
Note: Due to the massive amount of spam attacks, Doom9 has established strict anti-spam measures. Therefore, it takes a few days until your account will be approved.
Developer Center
While LameXP originally was written in Delphi/Pascal, the current version 4 series of the software has been re-written in the C++ programming language. LameXP v4 uses the Qt cross-platform application framework and provides full Unicode support. Furthermore, LameXP is tightly coupled with the MUtilities library, a vast collection of "utility" routines and classes to extend the Qt framework. Build files are currently provided for Microsoft Visual Studio only. Linux support is currently provided via Wine; a native Linux port of LameXP is planned for a future version.
Source Code Access
The source code of the LameXP software is managed using the Git version control system. The Git repository can be cloned from one of the official Git mirrors:
-
git clone git://git.code.sf.net/p/lamexp/code LameXP
(Browse) -
git clone https://github.com/lordmulder/LameXP.git LameXP
(Browse) -
git clone https://git01.codeplex.com/lamexp LameXP
(Browse) -
git clone https://bitbucket.org/lord_mulder/lamexp.git LameXP
(Browse) -
git clone git://git.assembla.com/lamexp.git LameXP
(Browse) -
git clone git://gitorious.org/lamexp/lamexp.git LameXP
(Browse) -
git clone git://repo.or.cz/LameXP.git LameXP
(Browse)
The source code of the MUtilities library is managed using the Git version control system. The Git repository can be cloned from one of the official Git mirrors:
-
git clone git://git.code.sf.net/p/mutilities/code MUtilities
(Browse) -
git clone https://github.com/lordmulder/MUtilities.git MUtilities
(Browse) -
git clone https://git01.codeplex.com/mutilities MUtilities
(Browse) -
git clone https://bitbucket.org/lord_mulder/mutilities.git MUtilities
(Browse) -
git clone git://git.assembla.com/mutilities.git MUtilities
(Browse) -
git clone git://gitorious.org/mutilities/mutilities.git MUtilities
(Browse) -
git clone git://repo.or.cz/MUtilities.git MUtilities
(Browse)
Remarks: In case you are new to Git or want to extend your knowledge, have a look at the Pro Git book by Scott Chacon! For Windows users, we highly recommend using MSYS Git in conjunction with the superb Tortoise Git front-end.
Build Prerequisites
LameXP is currently being developed and built using the following development tools and libraries:
-
Visual Studio 2013 Update-4, running on Windows 7 with Service Pack 1
-
Qt libraries 4.8.6 for Windows (pre-compiled Qt libraries for Visual Studio 2013 can be found here)
-
Windows Platform SDK v7.1A, included with Visual Studio 2013 or Visual Studio 2012
-
The minimum supported build platform is Windows 7 (x86 and x64)
In order to create LameXP release packages, using the included deployment scripts, you need the following additional tools:
-
7-Zip – file archiver with a high compression ratio
-
NSIS – Nullsoft Scriptable Install System (Unicode version recommended!)
- StdUtils plug-in
- LockedList plug-in
- Inetc plug-in
- Aero plug-in
-
UPX – the Ultimate Packer for eXecutables
-
Pandoc – the Universal Document Converter
-
GnuPG – the GNU Privacy Guard v1.4.x
Qt as Static Libraries
In order to create a "fully static" build of LameXP, i.e. a build that does not depend on any "external" DLL files (except for the obligatory operating system DLL's that you cannot get around), you'll need to compile Qt as "static" libraries. The official Qt web-site does provide pre-compiled Qt libraries. However, they only provide DLL versions, they do not provide "static" libraries. Consequently, you need to build the required "static" Qt libraries yourself. The following simple instructions should make it easy to build Qt from the sources and as "static" libraries:
-
Make sure Visual Studio 2013 with Update-4 (or later) is installed
-
Make sure *Strawberry Perl *for Windows and Python 2.7 are installed
-
Download and extract the Qt 4.8.x source code package (e.g. to
C:\QtSources\4.8.x
) -
Edit the file
mkspecs\win32-msvc2010\qmake.conf
from your Qt Sources directory as follows:Old: QMAKE_CFLAGS_RELEASE = -O2 -MD
New: QMAKE_CFLAGS_RELEASE = -O2 -MT <more optimization flags here>
Old: QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -MD -Zi
New: QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -MT -Zi <more optimization flags here>
-
Open a new command window (
cmd.exe
) – use this very same console for all upcoming steps! -
Add Strawberry Perl to your PATH (e.g.
set PATH=C:\strawberry\perl\bin;%PATH%
) -
Add Python 2.7 to your PATH (e.g.
set PATH=C:\python27;%PATH%
) -
Run
vcvarsall.bat x86
form your Visual C++ install directory - within the same console! -
Change the current directory to the Qt Sources path (e.g.
C:\QtSources\4.8.x
) -
Run
configure.exe -release -static -ltcg -qt-zlib -qt-libpng -qt-libjpeg -qt-libtiff -qt-libmng
- Hint: For Visual Studio 2013 you currently need to add
-platform win32-msvc2012
too
- Hint: For Visual Studio 2013 you currently need to add
-
Now the makefiles should have been generated, so simply enter
nmake /B
and be patient - voilà! -
The build process is going to take good amount of time. Once it is done, make sure you got all needed libs:
lib\qtmain.lib
lib\QtCore.lib
lib\QtGui.lib
lib\QtSvg.lib
lib\QtXml.lib
plugins\imageformats\qico.lib
plugins\imageformats\qsvg.lib
plugins\imageformats\qtga.lib
-
Put all the static *.lib files into the
Prerequisites\qt4_static\lib
directory -
ImageFormat plugins go to
Prerequisites\qt4_static\plugins\imageformats
-
Congratulations, you should now be prepared to build the
Release_Static
configuration of LameXP 😊
Note: Static libraries only work with the exactly same compiler (version) they were built with!
F.A.Q. (Frequently Asked Questions)
TODO
EOF