Blame view

scripts/find-unused-docs.sh 1.27 KB
45653c845   sayli karnik   scripts: Add a sc...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
  #!/bin/bash
  # (c) 2017, Jonathan Corbet <corbet@lwn.net>
  #           sayli karnik <karniksayli1995@gmail.com>
  #
  # This script detects files with kernel-doc comments for exported functions
  # that are not included in documentation.
  #
  # usage: Run 'scripts/find-unused-docs.sh directory' from top level of kernel
  # 	 tree.
  #
  # example: $scripts/find-unused-docs.sh drivers/scsi
  #
  # Licensed under the terms of the GNU GPL License
  
  if ! [ -d "Documentation" ]; then
  	echo "Run from top level of kernel tree"
  	exit 1
  fi
  
  if [ "$#" -ne 1 ]; then
  	echo "Usage: scripts/find-unused-docs.sh directory"
  	exit 1
  fi
  
  if ! [ -d "$1" ]; then
  	echo "Directory $1 doesn't exist"
  	exit 1
  fi
  
  cd "$( dirname "${BASH_SOURCE[0]}" )"
  cd ..
  
  cd Documentation/
  
  echo "The following files contain kerneldoc comments for exported functions \
  that are not used in the formatted documentation"
  
  # FILES INCLUDED
  
  files_included=($(grep -rHR ".. kernel-doc" --include \*.rst | cut -d " " -f 3))
  
  declare -A FILES_INCLUDED
  
  for each in "${files_included[@]}"; do
  	FILES_INCLUDED[$each]="$each"
  	done
  
  cd ..
  
  # FILES NOT INCLUDED
  
  for file in `find $1 -name '*.c'`; do
  
  	if [[ ${FILES_INCLUDED[$file]+_} ]]; then
  	continue;
  	fi
1630146db   Geert Uytterhoeven   scripts/find-unus...
57
  	str=$(scripts/kernel-doc -export "$file" 2>/dev/null)
45653c845   sayli karnik   scripts: Add a sc...
58
59
60
61
  	if [[ -n "$str" ]]; then
  	echo "$file"
  	fi
  	done