Функция curl_easy_escape
curl принимает CURL*
в качестве своего первого параметра, как указывает документация по curl:
char *curl_easy_escape(CURL *curl, const char *string, int length);
↑
Я не понимаю, для чего используется этот параметр, так как для экранирования URL не нужен дескриптор curl. На самом деле исходный код curl игнорирует этот параметр.
Безопасно ли просто использовать NULL
для этого параметра, если мне нужно избежать URL-адреса без предварительного дескриптора curl, как это делает реализация curl_escape
?
В документации параметр curl
явно не упоминается, но если есть сомнения, укажите действительный CURL*
. У вас все равно есть один, так что просто передайте его.
Это для обратной совместимости с ABI. CURL *curl
использовался 6 лет назад: curl_easy_escape, Curl_convert_to_network.
Всегда было и сейчас безопасно проходить NULL
: curl_escape, curl_easy_escape.
История интересная. char *curl_unescape(const char *string, int length)
была первой функцией. Позже был введен char *curl_easy_escape(CURL *handle, const char *string, int inlength)
для поддержки всех расширенных кодировок ASCII с помощью iconv
. И, наконец, код curl_easy_escape
был практически откатан до curl_unescape
и перестал использовать CURL *handle
.
Трудно угадать намерение разработчиков, но они могут планировать использовать
curl
в будущей версии. Поэтому, чтобы быть в безопасности, я бы не передал NULL, даже если он явно работает в данный момент.