2021-08-21 18:57:11 +08:00
|
|
|
#!/usr/bin/env perl
|
2020-08-26 14:30:38 +08:00
|
|
|
|
|
|
|
print <<HEAD
|
|
|
|
/***************************************************************************
|
|
|
|
* _ _ ____ _
|
2023-01-11 18:35:08 +08:00
|
|
|
* Project ___| | | | _ \\| |
|
2020-08-26 14:30:38 +08:00
|
|
|
* / __| | | | |_) | |
|
|
|
|
* | (__| |_| | _ <| |___
|
2023-01-11 18:35:08 +08:00
|
|
|
* \\___|\\___/|_| \\_\\_____|
|
2020-08-26 14:30:38 +08:00
|
|
|
*
|
2024-02-28 18:28:10 +08:00
|
|
|
* Copyright (C) Daniel Stenberg, <daniel\@haxx.se>, et al.
|
2020-08-26 14:30:38 +08:00
|
|
|
*
|
|
|
|
* This software is licensed as described in the file COPYING, which
|
|
|
|
* you should have received as part of this distribution. The terms
|
2020-11-04 21:02:01 +08:00
|
|
|
* are also available at https://curl.se/docs/copyright.html.
|
2020-08-26 14:30:38 +08:00
|
|
|
*
|
|
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
|
|
* copies of the Software, and permit persons to whom the Software is
|
|
|
|
* furnished to do so, under the terms of the COPYING file.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: curl
|
2022-05-17 17:16:50 +08:00
|
|
|
*
|
2020-08-26 14:30:38 +08:00
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
/* This source code is generated by optiontable.pl - DO NOT EDIT BY HAND */
|
|
|
|
|
|
|
|
#include "curl_setup.h"
|
|
|
|
#include "easyoptions.h"
|
|
|
|
|
|
|
|
/* all easy setopt options listed in alphabetical order */
|
|
|
|
struct curl_easyoption Curl_easyopts[] = {
|
|
|
|
HEAD
|
|
|
|
;
|
|
|
|
|
|
|
|
my $lastnum=0;
|
|
|
|
|
2022-11-28 23:32:43 +08:00
|
|
|
sub add {
|
|
|
|
my($opt, $type, $num)=@_;
|
|
|
|
my $name;
|
|
|
|
# remove all spaces from the type
|
|
|
|
$type =~ s/ //g;
|
|
|
|
my $ext = $type;
|
2020-08-26 14:30:38 +08:00
|
|
|
|
2022-11-28 23:32:43 +08:00
|
|
|
if($opt =~ /OBSOLETE/) {
|
|
|
|
# skip obsolete options
|
|
|
|
next;
|
|
|
|
}
|
2020-08-26 14:30:38 +08:00
|
|
|
|
2022-11-28 23:32:43 +08:00
|
|
|
if($opt =~ /^CURLOPT_(.*)/) {
|
|
|
|
$name=$1;
|
|
|
|
}
|
|
|
|
$ext =~ s/CURLOPTTYPE_//;
|
|
|
|
$ext =~ s/CBPOINT/CBPTR/;
|
|
|
|
$ext =~ s/POINT\z//;
|
|
|
|
$type = "CURLOT_$ext";
|
|
|
|
|
|
|
|
$opt{$name} = $opt;
|
|
|
|
$type{$name} = $type;
|
|
|
|
push @names, $name;
|
|
|
|
if($num < $lastnum) {
|
|
|
|
print STDERR "ERROR: $opt has bad number: $num < $lastnum\n";
|
|
|
|
exit 2;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$lastnum = $num;
|
|
|
|
}
|
|
|
|
}
|
2020-08-26 14:30:38 +08:00
|
|
|
|
2022-11-28 23:32:43 +08:00
|
|
|
|
|
|
|
my $fl;
|
|
|
|
while(<STDIN>) {
|
|
|
|
my $l = $_;
|
|
|
|
if($fl) {
|
|
|
|
# continued deprecation
|
|
|
|
if($l =~ /(.*)\),/) {
|
|
|
|
$fl .= $1;
|
|
|
|
|
|
|
|
# the end
|
|
|
|
my @p=split(/, */, $fl);
|
|
|
|
add($p[0], $p[1], $p[2]);
|
|
|
|
undef $fl;
|
2020-08-26 14:30:38 +08:00
|
|
|
}
|
|
|
|
else {
|
2022-11-28 23:32:43 +08:00
|
|
|
# another line to append
|
|
|
|
chomp $l;
|
|
|
|
$fl .= $l;
|
2020-08-26 14:30:38 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-28 23:32:43 +08:00
|
|
|
if(/^ *CURLOPTDEPRECATED\((.*)/) {
|
|
|
|
$fl = $1;
|
|
|
|
chomp $fl;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(/^ *CURLOPT\(([^,]*), ([^,]*), (\d+)\)/) {
|
|
|
|
my($opt, $type, $num)=($1,$2,$3);
|
|
|
|
add($opt, $type, $num);
|
|
|
|
}
|
|
|
|
|
2020-08-26 14:30:38 +08:00
|
|
|
# alias for an older option
|
|
|
|
# old = new
|
|
|
|
if(/^#define (CURLOPT_[^ ]*) *(CURLOPT_\S*)/) {
|
|
|
|
my ($o, $n)=($1, $2);
|
|
|
|
# skip obsolete ones
|
|
|
|
if($n !~ /OBSOLETE/) {
|
|
|
|
$o =~ s/^CURLOPT_//;
|
|
|
|
$n =~ s/^CURLOPT_//;
|
|
|
|
$alias{$o} = $n;
|
|
|
|
push @names, $o,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for my $name (sort @names) {
|
|
|
|
my $oname = $name;
|
|
|
|
my $a = $alias{$name};
|
|
|
|
my $flag = "0";
|
|
|
|
if($a) {
|
|
|
|
$name = $alias{$name};
|
|
|
|
$flag = "CURLOT_FLAG_ALIAS";
|
|
|
|
}
|
|
|
|
$o = sprintf(" {\"%s\", %s, %s, %s},\n",
|
|
|
|
$oname, $opt{$name}, $type{$name}, $flag);
|
|
|
|
if(length($o) < 80) {
|
|
|
|
print $o;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf(" {\"%s\", %s,\n %s, %s},\n",
|
|
|
|
$oname, $opt{$name}, $type{$name}, $flag);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
print <<FOOT
|
2022-07-19 05:38:36 +08:00
|
|
|
{NULL, CURLOPT_LASTENTRY, CURLOT_LONG, 0} /* end of table */
|
2020-08-26 14:30:38 +08:00
|
|
|
};
|
|
|
|
|
2020-09-01 22:01:00 +08:00
|
|
|
#ifdef DEBUGBUILD
|
2020-08-26 14:30:38 +08:00
|
|
|
/*
|
|
|
|
* Curl_easyopts_check() is a debug-only function that returns non-zero
|
|
|
|
* if this source file is not in sync with the options listed in curl/curl.h
|
|
|
|
*/
|
|
|
|
int Curl_easyopts_check(void)
|
|
|
|
{
|
2021-09-29 16:06:42 +08:00
|
|
|
return ((CURLOPT_LASTENTRY%10000) != ($lastnum + 1));
|
2020-08-26 14:30:38 +08:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
FOOT
|
|
|
|
;
|