Files
ortools-clone/tools/doc/gen_ref_doc.py
2025-03-13 16:54:58 +01:00

267 lines
9.0 KiB
Python
Executable File

#!/usr/bin/env python3
# Copyright 2010-2025 Google LLC
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Generate OR-Tools ref doc using Doxygen."""
import os
import re
def main(version):
"""For each doc section, edit the doxy and header files, and generate the doc."""
sections = create_section_data()
doxy_tmp = 'tools/doc/tmp.doxy'
header_tmp = 'tools/doc/header.tmp.html'
footer_tmp = 'tools/doc/footer.tmp.html'
style_sheet_tmp = 'tools/doc/styleSheet.tmp.css'
for section in sections:
output_dir = section['output_dir']
project_name = section['project name']
title = section['title']
doxyfile = 'tools/doc/' + section['doxyfile']
headerfile = 'tools/doc/' + section['headerfile']
footerfile = 'tools/doc/' + section['footerfile']
stylesheetfile = 'tools/doc/' + section['styleSheetfile']
input_files = section['input_files']
# Edit doxyfile.
project_name_string = 'PROJECT_NAME = ' + project_name
project_number_string = 'PROJECT_NUMBER = ' + version
html_output_string = 'HTML_OUTPUT = ' + output_dir
input_string = 'INPUT = ' + input_files
f = open(doxyfile, 'r')
g = open(doxy_tmp, 'w')
filedata = f.read()
filedata = re.sub('PROJECT_NAME', project_name_string, filedata)
filedata = re.sub('PROJECT_NUMBER', project_number_string, filedata)
filedata = re.sub('HTML_OUTPUT', html_output_string, filedata)
if input_files:
filedata = re.sub(r'INPUT.*=.*', input_string, filedata)
# Write filedata.
g.write(filedata)
f.close()
g.close()
# Edit header file.
f = open(headerfile, 'r')
g = open(header_tmp, 'w')
filedata = f.read()
filedata = re.sub('Banner Text', 'Google OR-Tools ' + version,
filedata)
filedata = re.sub('Page Title', title, filedata)
# Write filedata.
g.write(filedata)
f.close()
g.close()
# Edit footer file.
f = open(footerfile, 'r')
g = open(footer_tmp, 'w')
filedata = f.read()
# Write filedata.
g.write(filedata)
f.close()
g.close()
# Edit style sheet file.
f = open(stylesheetfile, 'r')
g = open(style_sheet_tmp, 'w')
filedata = f.read()
# Write filedata.
g.write(filedata)
f.close()
g.close()
# Clean previous doc.
os.system('rm -rf docs/' + output_dir)
# Generate the doc.
os.system(f'doxygen {doxy_tmp}')
# Remove temp files.
os.system(f'rm {doxy_tmp}')
os.system(f'rm {header_tmp}')
os.system(f'rm {footer_tmp}')
os.system(f'rm {style_sheet_tmp}')
def create_section_data():
"""Generate each section configuration."""
sections = [{
'output_dir':
'cpp_algorithms',
'project name':
'Algorithms',
'title':
'C++ Reference: Algorithms',
'doxyfile':
'cpp.doxy.in',
'headerfile':
'cpp.header.html.in',
'footerfile':
'all.footer.html.in',
'styleSheetfile':
'all.styleSheet.css.in',
'input_files':
'ortools/algorithms/dense_doubly_linked_list.h ' +
'ortools/algorithms/dynamic_partition.h ' +
'ortools/algorithms/dynamic_permutation.h ' +
'ortools/algorithms/find_graph_symmetries.h ' +
'ortools/algorithms/hungarian.h ' +
'ortools/algorithms/knapsack_solver.h ' +
'ortools/algorithms/sparse_permutation.h'
}, {
'output_dir':
'cpp_sat',
'project name':
'CP-SAT',
'title':
'C++ Reference: CP-SAT',
'doxyfile':
'cpp.doxy.in',
'headerfile':
'cpp.header.html.in',
'footerfile':
'all.footer.html.in',
'styleSheetfile':
'all.styleSheet.css.in',
'input_files':
'ortools/sat/cp_model.h ' + 'ortools/sat/cp_model_solver.h ' +
'ortools/sat/model.h ' + 'ortools/util/sorted_interval_list.h ' +
'ortools/util/time_limit.h ' +
'ortools/gen/ortools/sat/boolean_problem.pb.h ' +
'ortools/gen/ortools/sat/cp_model.pb.h ' +
'ortools/gen/ortools/sat/sat_parameters.pb.h'
}, {
'output_dir':
'cpp_graph',
'project name':
'Graph',
'title':
'C++ Reference: Graph',
'doxyfile':
'cpp.doxy.in',
'headerfile':
'cpp.header.html.in',
'footerfile':
'all.footer.html.in',
'styleSheetfile':
'all.styleSheet.css.in',
'input_files':
'ortools/graph/christofides.h ' + 'ortools/graph/cliques.h ' +
'ortools/graph/connected_components.h ' +
'ortools/graph/connectivity.h ' +
'ortools/graph/eulerian_path.h ' + 'ortools/graph/graph.h ' +
'ortools/graph/graphs.h ' + 'ortools/graph/hamiltonian_path.h ' +
'ortools/graph/graph_io.h ' + 'ortools/graph/iterators.h ' +
'ortools/graph/linear_assignment.h ' + 'ortools/graph/max_flow.h ' +
'ortools/graph/min_cost_flow.h ' +
'ortools/graph/minimum_spanning_tree.h ' +
'ortools/graph/one_tree_lower_bound.h ' +
'ortools/graph/shortestpaths.h ' +
'ortools/graph/strongly_connected_components.h ' +
'ortools/graph/util.h ' +
'ortools/gen/ortools/graph/flow_problem.pb.h '
}, {
'output_dir':
'cpp_linear',
'project name':
'Linear solver',
'title':
'C++ Reference: Linear solver',
'doxyfile':
'cpp.doxy.in',
'headerfile':
'cpp.header.html.in',
'footerfile':
'all.footer.html.in',
'styleSheetfile':
'all.styleSheet.css.in',
'input_files':
'ortools/linear_solver/linear_expr.h ' +
'ortools/linear_solver/linear_solver.h ' +
'ortools/linear_solver/model_exporter.h ' +
'ortools/linear_solver/model_exporter_swig_helper.h ' +
'ortools/linear_solver/model_validator.h ' +
'ortools/gen/ortools/linear_solver/linear_solver.pb.h '
}, {
'output_dir':
'cpp_routing',
'project name':
'Routing',
'title':
'C++ Reference: Routing',
'doxyfile':
'cpp.doxy.in',
'headerfile':
'cpp.header.html.in',
'footerfile':
'all.footer.html.in',
'styleSheetfile':
'all.styleSheet.css.in',
'input_files':
'ortools/constraint_solver/constraint_solver.h ' +
'ortools/constraint_solver/constraint_solveri.h ' +
'ortools/constraint_solver/routing.h ' +
'ortools/constraint_solver/routing_index_manager.h ' +
'ortools/constraint_solver/routing_lp_scheduling.h ' +
'ortools/constraint_solver/routing_neighborhoods.h ' +
'ortools/constraint_solver/routing_parameters.h ' +
'ortools/constraint_solver/routing_types.h ' +
'ortools/gen/ortools/constraint_solver/assignment.pb.h ' +
'ortools/gen/ortools/constraint_solver/demon_profiler.pb.h ' +
'ortools/gen/ortools/constraint_solver/routing_enums.pb.h ' +
'ortools/gen/ortools/constraint_solver/routing_parameters.pb.h ' +
'ortools/gen/ortools/constraint_solver/search_limit.pb.h ' +
'ortools/gen/ortools/constraint_solver/solver_parameters.pb.h '
}, {
'output_dir': 'cpp',
'project name': 'OR-Tools',
'title': 'C++ Reference',
'doxyfile': 'cpp.doxy.in',
'headerfile': 'default.header.html.in',
'footerfile': 'default.footer.html.in',
'styleSheetfile': 'default.styleSheet.css.in',
'input_files': 'ortools ' + 'tools/doc'
}, {
'output_dir': 'dotnet',
'project name': 'OR-Tools',
'title': '.Net Reference',
'doxyfile': 'dotnet.doxy.in',
'headerfile': 'dotnet.header.html.in',
'footerfile': 'all.footer.html.in',
'styleSheetfile': 'all.styleSheet.css.in',
'input_files': 'ortools ' + 'tools/doc'
}, {
'output_dir': 'java',
'project name': 'OR-Tools',
'title': 'Java Reference',
'doxyfile': 'java.doxy.in',
'headerfile': 'java.header.html.in',
'footerfile': 'all.footer.html.in',
'styleSheetfile': 'all.styleSheet.css.in',
'input_files': 'ortools ' + 'tools/doc'
}]
return sections
if __name__ == '__main__':
version_file = open('Version.txt', 'r')
version_file_data = version_file.read()
version_file.close()
major_pattern = re.compile(r'OR_TOOLS_MAJOR=(\d)')
minor_pattern = re.compile(r'OR_TOOLS_MINOR=(\d)')
major = major_pattern.findall(version_file_data)[0]
minor = minor_pattern.findall(version_file_data)[0]
version_number = f'{major}.{minor}'
main(version_number)