xref: /aosp_15_r20/external/curl/docs/examples/adddocsref.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# pass files as argument(s)
27*6236dae4SAndroid Build Coastguard Worker
28*6236dae4SAndroid Build Coastguard Workermy $docroot="https://curl.se/libcurl/c";
29*6236dae4SAndroid Build Coastguard Worker
30*6236dae4SAndroid Build Coastguard Workerfor $f (@ARGV) {
31*6236dae4SAndroid Build Coastguard Worker    open(NEW, ">$f.new");
32*6236dae4SAndroid Build Coastguard Worker    open(F, "<$f");
33*6236dae4SAndroid Build Coastguard Worker    while(<F>) {
34*6236dae4SAndroid Build Coastguard Worker        my $l = $_;
35*6236dae4SAndroid Build Coastguard Worker        if($l =~ /\/* $docroot/) {
36*6236dae4SAndroid Build Coastguard Worker            # just ignore preciously added refs
37*6236dae4SAndroid Build Coastguard Worker        }
38*6236dae4SAndroid Build Coastguard Worker        elsif($l =~ /^( *).*curl_easy_setopt\([^,]*, *([^ ,]*) *,/) {
39*6236dae4SAndroid Build Coastguard Worker            my ($prefix, $anc) = ($1, $2);
40*6236dae4SAndroid Build Coastguard Worker            $anc =~ s/_//g;
41*6236dae4SAndroid Build Coastguard Worker            print NEW "$prefix/* $docroot/curl_easy_setopt.html#$anc */\n";
42*6236dae4SAndroid Build Coastguard Worker            print NEW $l;
43*6236dae4SAndroid Build Coastguard Worker        }
44*6236dae4SAndroid Build Coastguard Worker        elsif($l =~ /^( *).*(curl_([^\(]*))\(/) {
45*6236dae4SAndroid Build Coastguard Worker            my ($prefix, $func) = ($1, $2);
46*6236dae4SAndroid Build Coastguard Worker            print NEW "$prefix/* $docroot/$func.html */\n";
47*6236dae4SAndroid Build Coastguard Worker            print NEW $l;
48*6236dae4SAndroid Build Coastguard Worker        }
49*6236dae4SAndroid Build Coastguard Worker        else {
50*6236dae4SAndroid Build Coastguard Worker            print NEW $l;
51*6236dae4SAndroid Build Coastguard Worker        }
52*6236dae4SAndroid Build Coastguard Worker    }
53*6236dae4SAndroid Build Coastguard Worker    close(F);
54*6236dae4SAndroid Build Coastguard Worker    close(NEW);
55*6236dae4SAndroid Build Coastguard Worker
56*6236dae4SAndroid Build Coastguard Worker    system("mv $f $f.org");
57*6236dae4SAndroid Build Coastguard Worker    system("mv $f.new $f");
58*6236dae4SAndroid Build Coastguard Worker}
59