xref: /aosp_15_r20/external/grpc-grpc/tools/distrib/c-ish/check_documentation.py (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker#!/usr/bin/env python3
2*cc02d7e2SAndroid Build Coastguard Worker
3*cc02d7e2SAndroid Build Coastguard Worker# Copyright 2015 gRPC authors.
4*cc02d7e2SAndroid Build Coastguard Worker#
5*cc02d7e2SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
6*cc02d7e2SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
7*cc02d7e2SAndroid Build Coastguard Worker# You may obtain a copy of the License at
8*cc02d7e2SAndroid Build Coastguard Worker#
9*cc02d7e2SAndroid Build Coastguard Worker#     http://www.apache.org/licenses/LICENSE-2.0
10*cc02d7e2SAndroid Build Coastguard Worker#
11*cc02d7e2SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
12*cc02d7e2SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
13*cc02d7e2SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*cc02d7e2SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
15*cc02d7e2SAndroid Build Coastguard Worker# limitations under the License.
16*cc02d7e2SAndroid Build Coastguard Worker
17*cc02d7e2SAndroid Build Coastguard Worker# check for directory level 'README.md' files
18*cc02d7e2SAndroid Build Coastguard Worker# check that all implementation and interface files have a \file doxygen comment
19*cc02d7e2SAndroid Build Coastguard Worker
20*cc02d7e2SAndroid Build Coastguard Workerimport os
21*cc02d7e2SAndroid Build Coastguard Workerimport sys
22*cc02d7e2SAndroid Build Coastguard Worker
23*cc02d7e2SAndroid Build Coastguard Worker# where do we run
24*cc02d7e2SAndroid Build Coastguard Worker_TARGET_DIRS = [
25*cc02d7e2SAndroid Build Coastguard Worker    "include/grpc",
26*cc02d7e2SAndroid Build Coastguard Worker    "include/grpc++",
27*cc02d7e2SAndroid Build Coastguard Worker    "src/core",
28*cc02d7e2SAndroid Build Coastguard Worker    "src/cpp",
29*cc02d7e2SAndroid Build Coastguard Worker    "test/core",
30*cc02d7e2SAndroid Build Coastguard Worker    "test/cpp",
31*cc02d7e2SAndroid Build Coastguard Worker]
32*cc02d7e2SAndroid Build Coastguard Worker
33*cc02d7e2SAndroid Build Coastguard Worker# which file extensions do we care about
34*cc02d7e2SAndroid Build Coastguard Worker_INTERESTING_EXTENSIONS = [".c", ".h", ".cc"]
35*cc02d7e2SAndroid Build Coastguard Worker
36*cc02d7e2SAndroid Build Coastguard Worker# find our home
37*cc02d7e2SAndroid Build Coastguard Worker_ROOT = os.path.abspath(os.path.join(os.path.dirname(sys.argv[0]), "../../.."))
38*cc02d7e2SAndroid Build Coastguard Workeros.chdir(_ROOT)
39*cc02d7e2SAndroid Build Coastguard Worker
40*cc02d7e2SAndroid Build Coastguard Workererrors = 0
41*cc02d7e2SAndroid Build Coastguard Worker
42*cc02d7e2SAndroid Build Coastguard Worker# walk directories, find things
43*cc02d7e2SAndroid Build Coastguard Workerprinted_banner = False
44*cc02d7e2SAndroid Build Coastguard Workerfor target_dir in _TARGET_DIRS:
45*cc02d7e2SAndroid Build Coastguard Worker    for root, dirs, filenames in os.walk(target_dir):
46*cc02d7e2SAndroid Build Coastguard Worker        if "README.md" not in filenames:
47*cc02d7e2SAndroid Build Coastguard Worker            if not printed_banner:
48*cc02d7e2SAndroid Build Coastguard Worker                print("Missing README.md")
49*cc02d7e2SAndroid Build Coastguard Worker                print("=================")
50*cc02d7e2SAndroid Build Coastguard Worker                printed_banner = True
51*cc02d7e2SAndroid Build Coastguard Worker            print(root)
52*cc02d7e2SAndroid Build Coastguard Worker            errors += 1
53*cc02d7e2SAndroid Build Coastguard Workerif printed_banner:
54*cc02d7e2SAndroid Build Coastguard Worker    print()
55*cc02d7e2SAndroid Build Coastguard Workerprinted_banner = False
56*cc02d7e2SAndroid Build Coastguard Workerfor target_dir in _TARGET_DIRS:
57*cc02d7e2SAndroid Build Coastguard Worker    for root, dirs, filenames in os.walk(target_dir):
58*cc02d7e2SAndroid Build Coastguard Worker        for filename in filenames:
59*cc02d7e2SAndroid Build Coastguard Worker            if os.path.splitext(filename)[1] not in _INTERESTING_EXTENSIONS:
60*cc02d7e2SAndroid Build Coastguard Worker                continue
61*cc02d7e2SAndroid Build Coastguard Worker            path = os.path.join(root, filename)
62*cc02d7e2SAndroid Build Coastguard Worker            with open(path) as f:
63*cc02d7e2SAndroid Build Coastguard Worker                contents = f.read()
64*cc02d7e2SAndroid Build Coastguard Worker            if "\\file" not in contents:
65*cc02d7e2SAndroid Build Coastguard Worker                if not printed_banner:
66*cc02d7e2SAndroid Build Coastguard Worker                    print("Missing \\file comment")
67*cc02d7e2SAndroid Build Coastguard Worker                    print("======================")
68*cc02d7e2SAndroid Build Coastguard Worker                    printed_banner = True
69*cc02d7e2SAndroid Build Coastguard Worker                print(path)
70*cc02d7e2SAndroid Build Coastguard Worker                errors += 1
71*cc02d7e2SAndroid Build Coastguard Worker
72*cc02d7e2SAndroid Build Coastguard Workerassert errors == 0, "error count = %d" % errors
73