xref: /aosp_15_r20/external/curl/docs/libcurl/symbols.pl (revision 6236dae45794135f37c4eb022389c904c8b0090d)
1*6236dae4SAndroid Build Coastguard Worker#!/usr/bin/env perl
2*6236dae4SAndroid Build Coastguard Worker#***************************************************************************
3*6236dae4SAndroid Build Coastguard Worker#                                  _   _ ____  _
4*6236dae4SAndroid Build Coastguard Worker#  Project                     ___| | | |  _ \| |
5*6236dae4SAndroid Build Coastguard Worker#                             / __| | | | |_) | |
6*6236dae4SAndroid Build Coastguard Worker#                            | (__| |_| |  _ <| |___
7*6236dae4SAndroid Build Coastguard Worker#                             \___|\___/|_| \_\_____|
8*6236dae4SAndroid Build Coastguard Worker#
9*6236dae4SAndroid Build Coastguard Worker# Copyright (C) Daniel Stenberg, <[email protected]>, et al.
10*6236dae4SAndroid Build Coastguard Worker#
11*6236dae4SAndroid Build Coastguard Worker# This software is licensed as described in the file COPYING, which
12*6236dae4SAndroid Build Coastguard Worker# you should have received as part of this distribution. The terms
13*6236dae4SAndroid Build Coastguard Worker# are also available at https://curl.se/docs/copyright.html.
14*6236dae4SAndroid Build Coastguard Worker#
15*6236dae4SAndroid Build Coastguard Worker# You may opt to use, copy, modify, merge, publish, distribute and/or sell
16*6236dae4SAndroid Build Coastguard Worker# copies of the Software, and permit persons to whom the Software is
17*6236dae4SAndroid Build Coastguard Worker# furnished to do so, under the terms of the COPYING file.
18*6236dae4SAndroid Build Coastguard Worker#
19*6236dae4SAndroid Build Coastguard Worker# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
20*6236dae4SAndroid Build Coastguard Worker# KIND, either express or implied.
21*6236dae4SAndroid Build Coastguard Worker#
22*6236dae4SAndroid Build Coastguard Worker# SPDX-License-Identifier: curl
23*6236dae4SAndroid Build Coastguard Worker#
24*6236dae4SAndroid Build Coastguard Worker###########################################################################
25*6236dae4SAndroid Build Coastguard Worker#
26*6236dae4SAndroid Build Coastguard Worker# Experience has shown that the symbols-in-versions file is useful to
27*6236dae4SAndroid Build Coastguard Worker# applications that want to build with a wide range of libcurl versions.  It
28*6236dae4SAndroid Build Coastguard Worker# is however easy to get it wrong and the source gets a bit messy with all the
29*6236dae4SAndroid Build Coastguard Worker# fixed numerical comparisons.
30*6236dae4SAndroid Build Coastguard Worker#
31*6236dae4SAndroid Build Coastguard Worker# The point of this script is to provide an easy-to-use macro for libcurl-
32*6236dae4SAndroid Build Coastguard Worker# using applications to do preprocessor checks for specific libcurl defines,
33*6236dae4SAndroid Build Coastguard Worker# and yet make the code clearly show what the macro is used for.
34*6236dae4SAndroid Build Coastguard Worker#
35*6236dae4SAndroid Build Coastguard Worker# Run this script and generate libcurl-symbols.h and then use that header in
36*6236dae4SAndroid Build Coastguard Worker# a fashion similar to:
37*6236dae4SAndroid Build Coastguard Worker#
38*6236dae4SAndroid Build Coastguard Worker# #include "libcurl-symbols.h"
39*6236dae4SAndroid Build Coastguard Worker#
40*6236dae4SAndroid Build Coastguard Worker# #if LIBCURL_HAS(CURLOPT_MUTE)
41*6236dae4SAndroid Build Coastguard Worker#   has mute
42*6236dae4SAndroid Build Coastguard Worker# #else
43*6236dae4SAndroid Build Coastguard Worker#   no mute
44*6236dae4SAndroid Build Coastguard Worker# #endif
45*6236dae4SAndroid Build Coastguard Worker#
46*6236dae4SAndroid Build Coastguard Worker#
47*6236dae4SAndroid Build Coastguard Workeropen F, "<symbols-in-versions";
48*6236dae4SAndroid Build Coastguard Worker
49*6236dae4SAndroid Build Coastguard Workersub str2num {
50*6236dae4SAndroid Build Coastguard Worker    my ($str)=@_;
51*6236dae4SAndroid Build Coastguard Worker    if($str =~ /([0-9]*)\.([0-9]*)\.*([0-9]*)/) {
52*6236dae4SAndroid Build Coastguard Worker        return sprintf("0x%06x", $1<<16 | $2 << 8 | $3);
53*6236dae4SAndroid Build Coastguard Worker    }
54*6236dae4SAndroid Build Coastguard Worker}
55*6236dae4SAndroid Build Coastguard Worker
56*6236dae4SAndroid Build Coastguard Workerprint <<EOS
57*6236dae4SAndroid Build Coastguard Worker
58*6236dae4SAndroid Build Coastguard Worker#include <curl/curl.h>
59*6236dae4SAndroid Build Coastguard Worker
60*6236dae4SAndroid Build Coastguard Worker#define LIBCURL_HAS(x) \\
61*6236dae4SAndroid Build Coastguard Worker  (defined(x ## _FIRST) && (x ## _FIRST <= LIBCURL_VERSION_NUM) && \\
62*6236dae4SAndroid Build Coastguard Worker   (!defined(x ## _LAST) || ( x ## _LAST >= LIBCURL_VERSION_NUM)))
63*6236dae4SAndroid Build Coastguard Worker
64*6236dae4SAndroid Build Coastguard WorkerEOS
65*6236dae4SAndroid Build Coastguard Worker    ;
66*6236dae4SAndroid Build Coastguard Worker
67*6236dae4SAndroid Build Coastguard Workerwhile(<F>) {
68*6236dae4SAndroid Build Coastguard Worker    if(/^(CURL[^ ]*)[ \t]*(.*)/) {
69*6236dae4SAndroid Build Coastguard Worker        my ($sym, $vers)=($1, $2);
70*6236dae4SAndroid Build Coastguard Worker
71*6236dae4SAndroid Build Coastguard Worker        my $intr;
72*6236dae4SAndroid Build Coastguard Worker        my $rm;
73*6236dae4SAndroid Build Coastguard Worker        my $dep;
74*6236dae4SAndroid Build Coastguard Worker
75*6236dae4SAndroid Build Coastguard Worker        # is there removed info?
76*6236dae4SAndroid Build Coastguard Worker        if($vers =~ /([\d.]+)[ \t-]+([\d.-]+)[ \t]+([\d.]+)/) {
77*6236dae4SAndroid Build Coastguard Worker            ($intr, $dep, $rm)=($1, $2, $3);
78*6236dae4SAndroid Build Coastguard Worker        }
79*6236dae4SAndroid Build Coastguard Worker        # is it a dep-only line?
80*6236dae4SAndroid Build Coastguard Worker        elsif($vers =~ /([\d.]+)[ \t-]+([\d.]+)/) {
81*6236dae4SAndroid Build Coastguard Worker            ($intr, $dep)=($1, $2);
82*6236dae4SAndroid Build Coastguard Worker        }
83*6236dae4SAndroid Build Coastguard Worker        else {
84*6236dae4SAndroid Build Coastguard Worker            $intr = $vers;
85*6236dae4SAndroid Build Coastguard Worker        }
86*6236dae4SAndroid Build Coastguard Worker
87*6236dae4SAndroid Build Coastguard Worker        my $inum = str2num($intr);
88*6236dae4SAndroid Build Coastguard Worker
89*6236dae4SAndroid Build Coastguard Worker        print <<EOS
90*6236dae4SAndroid Build Coastguard Worker#define ${sym}_FIRST $inum /* Added in $intr */
91*6236dae4SAndroid Build Coastguard WorkerEOS
92*6236dae4SAndroid Build Coastguard Worker;
93*6236dae4SAndroid Build Coastguard Worker        my $irm = str2num($rm);
94*6236dae4SAndroid Build Coastguard Worker        if($rm) {
95*6236dae4SAndroid Build Coastguard Worker        print <<EOS
96*6236dae4SAndroid Build Coastguard Worker#define ${sym}_LAST $irm /* Last featured in $rm */
97*6236dae4SAndroid Build Coastguard WorkerEOS
98*6236dae4SAndroid Build Coastguard Worker;
99*6236dae4SAndroid Build Coastguard Worker        }
100*6236dae4SAndroid Build Coastguard Worker
101*6236dae4SAndroid Build Coastguard Worker    }
102*6236dae4SAndroid Build Coastguard Worker}
103