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

Поиск
Список
Период
Сортировка
От Sugamoto Shinya
Тема [PATCH] Add hints for invalid binary encoding names in encode/decode functions
Дата
Msg-id CAAe3y+99sfPv8UDF1VM-rC1i5HBdqxUh=2HrbJJFm2+i=1OwOw@mail.gmail.com
обсуждение исходный текст
Список pgsql-hackers
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
Вложения

В списке pgsql-hackers по дате отправления: