pq-sys 0.7.0

Auto-generated rust bindings for libpq
Documentation
# Change Log
All user visible changes to this project will be documented in this file.
This project adheres to [Semantic Versioning](http://semver.org/), as described
for Rust libraries in [RFC #1105](https://github.com/rust-lang/rfcs/blob/master/text/1105-api-evolution.md)

## Unreleased

### pq-sys [0.7.0] 2025-01-10

* Bump bindgen to 0.71
* Regenerate bindings and make sure that they compile on common platforms
* Remove non-libpq items from the generated bindings
* Bump crate to 2021 edition
* Increase minimal supported rust version to 1.82

### pq-src [0.3.2] 2024-09-27

### Changed

* Update the bundled libpq version to the postgres 17.0 release

### pq-sys [0.6.3] 2024-09-18

### Fixed

* Linking of bundled libpq with the `bundled_without_openssl` feature

### pq-sys [0.6.2] 2024-09-09

### Changed

* `openssl` usage can now be disabled with the `bundled_without_openssl` feature of `pq-sys`.
  To deactivate `openssl`, enable it:
  ```toml
  [dependencies]
  pq-sys = { version = "0.3.0", features = ["bundled_without_openssl"]}
  ```
  This disables the TLS support in `libpq`, so that you cannot connect to a database requiring TLS anymore.

## pq-sys [0.6.1] 2024-06-11

### Changed

* `pq-src` starting with version 0.3 now depends on openssl on windows as well add support for the scram-sha-256 authentication method
* `pq-sys` adds support for pq-src 0.3.0

## pq-sys [0.6.0] 2024-05-17

### Changed

* The `bundled` feature of `pq-sys` no longer build a bundled version of `openssl`.
  To bundle `openssl` when compiling `libpq` from source, add `openssl-sys` with the `vendored` feature to your crate dependencies:
  ```toml
  [dependencies]
  openssl-sys = { version = "0.9.93", features = ["vendored"] }
  ```

## pq-src [0.1.6] 2024-04-12

### Changed

* Fixed a potential compilation error on MacOS

## pq-src [0.1.5] 2024-04-10

### Changed

* Include a vendored copy of `explicit_bzero` to the linux build as well as that function only exists on newer glibc versions

## pq-src [0.1.4] 2024-04-05

### Changed

* Readded `strlcat` on linux as well

## pq-src [0.1.3] 2024-04-04

### Changed

* Include more required headers in the generated include directory
* Fix including `strlcat` on windows only

## pq-src [0.1.2] 2024-03-08

### Changed

* Change `#[cfg(target_*)]` attributes in the build script to use cargo set environment variables
  instead. This enables cross compiling `pq-src` to a different target system.

## pq-src [0.1.1] 2024-02-09

### Changed

- We updated the bundled libpq version to 16.2 to fix compatibility with openssl 3.2
- We changed the build script to expose the bundled libpq headers by setting `DEP_PQ_SYS_SRC_INCLUDE` so that other *-sys crates can consume that information and reuse the bundled build provided by this crate


## [0.5.0] 2024-01-19

### Added

- We added a `pq-src` crate and a `bundled` feature for `pq-sys`. This allows to build and link a static version of libpq during the rust build process. This feature currently supports builds targeting Windows, Linux and macOS. It requires a c-compiler toolchain for the target to build libpq from source.
- We added a `buildtime_bindgen` feature flag that allows to generate bindings for your locally installed libpq version. This is helpful for cases where the target architecture is significantly different to what the built-in bindings assume.

### Changed

- We regenerated the bundled bindings to match the libpq version build by the `bundled` feature flag

## [0.4.8] 2023-04-18

## Fixed

- Added `wldap` as dependency for the vcpk installation on windows as that's now required there

## [0.4.5] 2018-05-09

### Added

- Linking can now be dynamically handled per-target by specifying the `TARGET`
  environment variable and `PQ_LIB_STATIC_$TARGET` environment variable.

- The path to `pg_config` can now be dynamically handled per-target by
  specifying the `TARGET` environment variable and `PG_CONFIG_$TARGET`
  environment variable.

## [0.4.3] 2017-03-10

### Fixed

- Linking on the msvc toolchain will no longer attempt to statically link

## [0.4.2] 2017-02-19

### Fixed

- Improved linking on Windows, particularly with the msvc toolchain.

## [0.4.1] 2017-02-19

### Fixed

- Properly specified the build script

## [0.4.0] 2017-02-19 [YANKED]

### Changed

- Bindings are no longer generated at compile time. Requiring clang 3.9 caused
  too many issues for too many users, and requiring `syntex_syntax` increased
  compile time too much.

## [0.3.2] 2017-02-16

### Fixed

- Fixed an issue when building on mac against postgres from homebrew

## [0.3.1] 2017-02-16

### Fixed

- Fixed an issue when building on mac against postgres from homebrew

- Fixed an issue with locating header files on linux

## [0.3.0] 2017-02-16

### Changed

- Bindings are now generated when the library is built, rather than being
  vendored ahead of time.

- `libc` is no longer used. Anywhere that `libc::some_type` was expected,
  `std::os::raw::some_type` is now used instead.

- The build script will no longer attempt to canonicalize symlinks on MacOS.

## [0.2.7] 2016-12-10

### Changed

- `pkg-config` is disabled by default. It can be enabled by adding `features =
  ["pkg-config"]` to your `Cargo.toml`.

## [0.2.6] 2016-12-10

### Added

- We will attempt to use `pkg-config` to locate libpq before falling back to
  `pg_config`.

## [0.2.5] 2016-12-10

- No changes. Accidental release on the wrong commit.

## [0.2.4] 2016-11-22

### Added

- `pq` will be statically linked if the environment variable `PQ_LIB_STATIC` is
  set.

## [0.2.3] 2016-08-12

### Changed

- On Mac if `pg_config` points to a directory where `libpq.dylib` is a symlink,
  we will now attempt to find the canonical directory to link against. This
  means that for installations using homebrew,
  `/usr/local/Cellar/postgresql/version/lib` will be added to `DYLD_LIBRARY_PATH`
  instead of `/usr/local/lib`

## [0.2.2] 2016-07-30

### Added

- The directory containing libpq for linking can now be specified via the
  `PQ_LIB_DIR` environment variable.