xref: /aosp_15_r20/external/libtraceevent/check-manpages.sh (revision 436bf2bcd5202612ffffe471bbcc1f277cc8d28e)
1*436bf2bcSAndroid Build Coastguard Worker#!/bin/bash
2*436bf2bcSAndroid Build Coastguard Worker# SPDX-License-Identifier: LGPL-2.1
3*436bf2bcSAndroid Build Coastguard Worker# Copyright (C) 2022, Google Inc, Steven Rostedt <[email protected]>
4*436bf2bcSAndroid Build Coastguard Worker#
5*436bf2bcSAndroid Build Coastguard Worker# This checks if any function is listed in a man page that is not listed
6*436bf2bcSAndroid Build Coastguard Worker# in the main man page.
7*436bf2bcSAndroid Build Coastguard Worker
8*436bf2bcSAndroid Build Coastguard Workerif [ $# -lt 1 ]; then
9*436bf2bcSAndroid Build Coastguard Worker	echo "usage: check-manpages man-page-path"
10*436bf2bcSAndroid Build Coastguard Worker	exit 1
11*436bf2bcSAndroid Build Coastguard Workerfi
12*436bf2bcSAndroid Build Coastguard Worker
13*436bf2bcSAndroid Build Coastguard Workercd $1
14*436bf2bcSAndroid Build Coastguard Worker
15*436bf2bcSAndroid Build Coastguard WorkerMAIN=libtraceevent
16*436bf2bcSAndroid Build Coastguard WorkerMAIN_FILE=${MAIN}.txt
17*436bf2bcSAndroid Build Coastguard Worker
18*436bf2bcSAndroid Build Coastguard WorkerPROCESSED=""
19*436bf2bcSAndroid Build Coastguard Worker
20*436bf2bcSAndroid Build Coastguard Worker# Ignore man pages that do not contain functions
21*436bf2bcSAndroid Build Coastguard WorkerIGNORE=""
22*436bf2bcSAndroid Build Coastguard Worker
23*436bf2bcSAndroid Build Coastguard Workerfor man in ${MAIN}-*.txt; do
24*436bf2bcSAndroid Build Coastguard Worker
25*436bf2bcSAndroid Build Coastguard Worker	for a in `sed -ne '/^NAME/,/^SYNOP/{/^[a-z]/{s/, *$//;s/,/\n/g;s/ //g;s/-.*$/-/;/-/{s/-//p;q};p}}' $man`; do
26*436bf2bcSAndroid Build Coastguard Worker		if [ "${PROCESSED/:${a} /}" != "${PROCESSED}" ]; then
27*436bf2bcSAndroid Build Coastguard Worker			P="${PROCESSED/:${a} */}"
28*436bf2bcSAndroid Build Coastguard Worker			echo "Found ${a} in ${man} and in ${P/* /}"
29*436bf2bcSAndroid Build Coastguard Worker		fi
30*436bf2bcSAndroid Build Coastguard Worker		PROCESSED="${man}:${a} ${PROCESSED}"
31*436bf2bcSAndroid Build Coastguard Worker		if [ "${IGNORE/$man/}" != "${IGNORE}" ]; then
32*436bf2bcSAndroid Build Coastguard Worker			continue
33*436bf2bcSAndroid Build Coastguard Worker		fi
34*436bf2bcSAndroid Build Coastguard Worker		if ! grep -q '\*'${a}'\*' $MAIN_FILE; then
35*436bf2bcSAndroid Build Coastguard Worker			if [ "$last" == "" ]; then
36*436bf2bcSAndroid Build Coastguard Worker				echo
37*436bf2bcSAndroid Build Coastguard Worker			fi
38*436bf2bcSAndroid Build Coastguard Worker			if [ "$last" != "$man" ]; then
39*436bf2bcSAndroid Build Coastguard Worker				echo "Missing functions from $MAIN_FILE that are in $man"
40*436bf2bcSAndroid Build Coastguard Worker				last=$man
41*436bf2bcSAndroid Build Coastguard Worker			fi
42*436bf2bcSAndroid Build Coastguard Worker			echo "   ${a}"
43*436bf2bcSAndroid Build Coastguard Worker		fi
44*436bf2bcSAndroid Build Coastguard Worker	done
45*436bf2bcSAndroid Build Coastguard Workerdone
46*436bf2bcSAndroid Build Coastguard Worker
47*436bf2bcSAndroid Build Coastguard WorkerDEPRECATED="*tep_print_field*"
48*436bf2bcSAndroid Build Coastguard Worker
49*436bf2bcSAndroid Build Coastguard Worker# Should not be used by applications, only internal use by trace-cmd
50*436bf2bcSAndroid Build Coastguard WorkerIGNORE="*kbuffer_set_old_format* *kbuffer_raw_get* *kbuffer_ptr_delta* *kbuffer_translate_data*"
51*436bf2bcSAndroid Build Coastguard Worker
52*436bf2bcSAndroid Build Coastguard WorkerHEADER=event-parse.h
53*436bf2bcSAndroid Build Coastguard Worker
54*436bf2bcSAndroid Build Coastguard Workersed -ne 's/^[a-z].*[ \*]\([a-z_][a-z_]*\)(.*/\1/p' -e 's/^\([a-z_][a-z_]*\)(.*/\1/p' ../include/traceevent/{event-parse,trace-seq,kbuffer}.h | while read f; do
55*436bf2bcSAndroid Build Coastguard Worker	if ! grep -q '\*'${f}'\*' $MAIN_FILE; then
56*436bf2bcSAndroid Build Coastguard Worker		if [ "${DEPRECATED/\*$f\*/}" != "${DEPRECATED}" ]; then
57*436bf2bcSAndroid Build Coastguard Worker			continue;
58*436bf2bcSAndroid Build Coastguard Worker		fi
59*436bf2bcSAndroid Build Coastguard Worker		if [ "${IGNORE/\*$f\*/}" != "${IGNORE}" ]; then
60*436bf2bcSAndroid Build Coastguard Worker			continue;
61*436bf2bcSAndroid Build Coastguard Worker		fi
62*436bf2bcSAndroid Build Coastguard Worker		for head in event-parse.h trace-seq.h kbuffer.h; do
63*436bf2bcSAndroid Build Coastguard Worker			if grep -q $f ../include/traceevent/$head; then
64*436bf2bcSAndroid Build Coastguard Worker				if [ "$HEADER" != "$head" ]; then
65*436bf2bcSAndroid Build Coastguard Worker					last=""
66*436bf2bcSAndroid Build Coastguard Worker					HEADER=$head
67*436bf2bcSAndroid Build Coastguard Worker					break
68*436bf2bcSAndroid Build Coastguard Worker				fi
69*436bf2bcSAndroid Build Coastguard Worker			fi
70*436bf2bcSAndroid Build Coastguard Worker		done
71*436bf2bcSAndroid Build Coastguard Worker		if [ "$last" == "" ]; then
72*436bf2bcSAndroid Build Coastguard Worker			echo
73*436bf2bcSAndroid Build Coastguard Worker			echo "Missing functions from $MAIN_FILE that are in $HEADER"
74*436bf2bcSAndroid Build Coastguard Worker			last=$f
75*436bf2bcSAndroid Build Coastguard Worker		fi
76*436bf2bcSAndroid Build Coastguard Worker		echo "   ${f}"
77*436bf2bcSAndroid Build Coastguard Worker	fi
78*436bf2bcSAndroid Build Coastguard Workerdone
79