Обсуждение: [PATCH] Add hints for invalid binary encoding names in encode/decode functions

Поиск
Список
Период
Сортировка

[PATCH] Add hints for invalid binary encoding names in encode/decode functions

От
Sugamoto Shinya
Дата:
Hi,

When users pass an invalid encoding name to the built-in functions
`encode()` or `decode()`, PostgreSQL currently reports only:

    ERROR:  unrecognized encoding: "xxx"

This patch adds an error hint listing the valid encoding names,
so users can immediately see the supported options.

Example:

    SELECT encode('\x01'::bytea, 'invalid');
    ERROR:  unrecognized encoding: "invalid"
    HINT:  Valid binary encodings are: "hex", "base64", "base64url", "escape".

This change applies to both `binary_encode()` and `binary_decode()` in `encode.c`,
and adds regression tests under `src/test/regress/sql/strings.sql`.

Although this is a small change, let me share a few considerations behind it:

- I extracted the valid encodings from the hint messages and used a format specifier like  
  `Valid binary encodings are: %s`, so that we avoid scattering those fixed strings
  across translation files.
- I briefly considered adding a small helper function to build the hint string,
  but decided against it since keeping the codebase simple felt preferable, and
  new binary encodings are not added very often.

I’d be happy to hear any opinions or suggestions.

Patch attached.

Best regards,  
Shinya Sugamoto
Вложения