!pgmp extension installation

Prerequisites

!pgmp is currently compatible with:

  • PostgreSQL from version 8.4
  • GMP from version 4.1 (tested with versions 4.1.4, 4.2.4, 4.3.2, 5.0.1, 6.1.2, 6.2.0).

Note

GMP 4.1 doesn't implement a few functions (rootrem(), combit(), randinit_mt()) and the maximum base accepted by the I/O functions is 36, not 62.

In order to build the library your system must have the server development files (on Debian systems usually packaged as postgresql-server-dev) and regular UNIX development tools, such as make. The pg_config program should be available in the PATH. If more than one PostgreSQL version is available on the system, the library will be built against the version of the first pg_config found in the path. You may also override the selection specifying the PG_CONFIG variable.

Using the PGXN client

If the prerequsites are met you can use the PGXN Client to download, build, and install !pgmp, e.g.:

$ pgxn install pgmp
$ pgxn load -d somedb pgmp

The further instructions are to build, test, and install the library without using the PGXN Client.

Building the library

The library must be built and installed to be used with a database cluster: once it is built, SQL installation scripts can be used to install the data types and functions in one or more databases.

To build and install the library:

$ make
$ sudo make install

You can test the installation with:

$ make installcheck

(adjust the REGRESS_OPTS variable to select a test database).

Note

Because of the missing functions in GMP 4.1 (see Prerequisites), a few tests are expected to fail with this library version. After running the test suite you may check the regression.diff file to verify that the only tests failed are the ones related to the missing functionalities and the different default random numbers gerenator algorithm.

Installing the extension

With PostgreSQL versions before 9.1, an install script called pgmp.sql is installed in the directory {$sharedir}/pgmp: just run the script into a database to install the provided types and functions. An uninstall script is also provided in the same directory to remove the installed objects.

With PostgreSQL 9.1 the library is packaged as an extension: once built and installed in the cluster, use the command:

=# CREATE EXTENSION pgmp;

to install it in a database. If your database was migrated from a previous PostgreSQL version, you can convert the !pgmp objects into a packaged extension using the command:

=# CREATE EXTENSION pgmp FROM unpackaged;

In order to uninstall the extension you can use the DROP EXTENSION command. Please refer to the documentation for further informations about PostgreSQL extensions management.