postgresql/src/tools/msvc
Thomas Munro 8d9a9f034e All supported systems have locale_t.
locale_t is defined by POSIX.1-2008 and SUSv4, and available on all
targeted systems.  For Windows, win32_port.h redirects to a partial
implementation called _locale_t.  We can now remove a lot of
compile-time tests for HAVE_LOCALE_T, and associated comments and dead
code branches that were needed for older computers.

Since configure + MinGW builds didn't detect locale_t but now we assume
that all systems have it, further inconsistencies among the 3 Windows build
systems were revealed.  With this commit, we no longer define
HAVE_WCSTOMBS_L and HAVE_MBSTOWCS_L on any Windows build system, but
we have logic to deal with that so that replacements are available where
appropriate.

Reviewed-by: Noah Misch <noah@leadboat.com>
Reviewed-by: Tristan Partin <tristan@neon.tech>
Reviewed-by: Peter Eisentraut <peter@eisentraut.org>
Discussion: https://postgr.es/m/CA%2BhUKGLg7_T2GKwZFAkEf0V7vbnur-NfCjZPKZb%3DZfAXSV1ORw%40mail.gmail.com
2023-07-09 11:55:18 +12:00
..
dummylib Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
.gitignore Ignore config.pl and buildenv.pl in src/tools/msvc. 2014-05-12 14:24:18 -04:00
Install.pm Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
MSBuildProject.pm src/tools/msvc: Move all.sym temporary file back to Debug/postgres. 2023-06-12 07:40:39 -07:00
Mkvcbuild.pm Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
Project.pm Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
README Remove support for Visual Studio 2013 2022-07-14 11:22:49 +09:00
Solution.pm All supported systems have locale_t. 2023-07-09 11:55:18 +12:00
VSObjectFactory.pm Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
build.bat Allow MSVC .bat wrappers to be called from anywhere 2022-01-07 16:07:45 -05:00
build.pl Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
clean.bat Generate automatically code and documentation related to wait events 2023-07-05 10:53:11 +09:00
config_default.pl Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
ecpg_regression.proj Fix inconsistencies and typos in the tree, take 11 2019-08-19 16:21:39 +09:00
gendef.pl Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
install.bat Allow MSVC .bat wrappers to be called from anywhere 2022-01-07 16:07:45 -05:00
install.pl Update copyright for 2023 2023-01-02 15:00:37 -05:00
mkvcbuild.pl Update copyright for 2023 2023-01-02 15:00:37 -05:00
pgbison.bat Allow MSVC .bat wrappers to be called from anywhere 2022-01-07 16:07:45 -05:00
pgbison.pl Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00
pgflex.bat Allow MSVC .bat wrappers to be called from anywhere 2022-01-07 16:07:45 -05:00
pgflex.pl Update copyright for 2023 2023-01-02 15:00:37 -05:00
vcregress.bat Allow MSVC .bat wrappers to be called from anywhere 2022-01-07 16:07:45 -05:00
vcregress.pl Pre-beta mechanical code beautification. 2023-05-19 17:24:48 -04:00

README

src/tools/msvc/README

MSVC build
==========

This directory contains the tools required to build PostgreSQL using
Microsoft Visual Studio 2015 - 2022. This builds the whole backend, not just
the libpq frontend library. For more information, see the documentation
chapter "Installation on Windows" and the description below.


Notes about Visual Studio Express
---------------------------------
To build PostgreSQL using Visual Studio Express, the Microsoft Windows SDK
has to be installed. Since this is not included in the product
originally, extra steps are needed to make it work.

First, download and install a supported version of the Microsoft Windows SDK
from www.microsoft.com (v8.1a or greater).

Locate the files vcprojectengine.dll.express.config and
vcprojectengine.dll.config in the vc\vcpackages directory of
the Visual C++ Express installation. In these files, add the paths
to the Platform SDK to the Include, Library and Path tags. Be sure
to add them to the beginning of the list.

This should work for both GUI and commandline builds, but a restart
may be necessary.

If you are using a recent version of the Microsoft Windows SDK that includes
the compilers and build tools you probably don't even need Visual Studio
Express to build PostgreSQL.


Structure of the build tools
----------------------------
The tools for building PostgreSQL using Microsoft Visual Studio currently
consist of the following files:

- Configuration files -
config_default.pl      default configuration arguments

A typical build environment has two more files, buildenv.pl and config.pl
that contain the user's build environment settings and configuration
arguments.


- User tools -
build.pl               tool to build the binaries
clean.bat              batch file for cleaning up generated files
install.pl             tool to install the generated files
mkvcbuild.pl           tool to generate the Visual Studio build files
vcregress.pl           tool to run the regression tests


- Internal tools -
gendef.pl              internal tool to generate .DEF files
pgbison.pl             internal tool to process .y files using bison
pgflex.pl              internal tool to process .l files using flex

Many of those .pl files also have a corresponding .bat-wrapper that doesn't
contain any additional logic.


- Internal modules -
Install.pm             module containing the install logic
Mkvcbuild.pm           module containing the code to generate the Visual
                       Studio build (project/solution) files
MSBuildProject.pm      module containing the code to generate MSBuild based
                       project files (Visual Studio 2015 or greater)
Project.pm             module containing the common code to generate the
                       Visual Studio project files. Also provides the
                       common interface of all project file generators
Solution.pm            module containing the code to generate the Visual
                       Studio solution files.
VSObjectFactory.pm     factory module providing the code to create the
                       appropriate project/solution files for the current
                       environment


Description of the internals of the Visual Studio build process
---------------------------------------------------------------
By typing 'build' the user starts the build.bat wrapper which simply passes
its arguments to build.pl.
In build.pl the user's buildenv.pl is used to set up the build environment
(i. e. path to bison and flex). In addition his config.pl file is merged into
config_default.pl to create the configuration arguments.
These configuration arguments are passed over to Mkvcbuild::mkvcbuild
(Mkvcbuild.pm) which creates the Visual Studio project and solution files.
It does this by using VSObjectFactory::CreateSolution to create an object
implementing the Solution interface (this could be either
VS2015Solution, VS2017Solution, VS2019Solution or VS2022Solution, all in
Solution.pm, depending on the user's build environment) and adding objects
implementing the corresponding Project interface (
VC2015Project, VC2017Project, VC2019Project or VC2022Project from
MSBuildProject.pm) to it. When Solution::Save is called, the implementations
of Solution and Project save their content in the appropriate format.
The final step of starting the appropriate build program (msbuild) is
performed in build.pl again.