docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
# Utility functions used in conf.py
|
|
|
|
#
|
|
|
|
# Copyright 2017 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
2018-09-07 13:46:50 +02:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
from io import open
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
import os
|
|
|
|
import shutil
|
2019-05-21 09:51:39 +08:00
|
|
|
|
|
|
|
try:
|
|
|
|
import urllib.request
|
|
|
|
_urlretrieve = urllib.request.urlretrieve
|
|
|
|
except ImportError:
|
|
|
|
# Python 2 fallback
|
|
|
|
import urllib
|
|
|
|
_urlretrieve = urllib.urlretrieve
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
|
2018-12-01 09:25:08 +01:00
|
|
|
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
def run_cmd_get_output(cmd):
|
|
|
|
return os.popen(cmd).read().strip()
|
|
|
|
|
2018-12-01 09:25:08 +01:00
|
|
|
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
def files_equal(path_1, path_2):
|
|
|
|
if not os.path.exists(path_1) or not os.path.exists(path_2):
|
|
|
|
return False
|
|
|
|
file_1_contents = ''
|
2018-09-07 13:46:50 +02:00
|
|
|
with open(path_1, "r", encoding='utf-8') as f_1:
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
file_1_contents = f_1.read()
|
|
|
|
file_2_contents = ''
|
2018-09-07 13:46:50 +02:00
|
|
|
with open(path_2, "r", encoding='utf-8') as f_2:
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
file_2_contents = f_2.read()
|
|
|
|
return file_1_contents == file_2_contents
|
|
|
|
|
2018-12-01 09:25:08 +01:00
|
|
|
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
def copy_file_if_modified(src_file_path, dst_file_path):
|
|
|
|
if not files_equal(src_file_path, dst_file_path):
|
|
|
|
dst_dir_name = os.path.dirname(dst_file_path)
|
|
|
|
if not os.path.isdir(dst_dir_name):
|
|
|
|
os.makedirs(dst_dir_name)
|
|
|
|
shutil.copy(src_file_path, dst_file_path)
|
|
|
|
|
2018-12-01 09:25:08 +01:00
|
|
|
|
docs: speed up incremental builds
On each documentation build (‘make html’), doxygen regenerates XML
files. In addition to that, gen-dxd.py regenerates API reference
files under _build/inc/. This results in Sphinx flagging about half
of the input files as modified, and incremental builds taking long
time.
With this change, XML files generated by Doxygen are copied into
docs/xml_in directory only when they are changed. Breathe is pointed
to docs/xml_in directory instead of docs/xml. In addition to that,
gen-dxd.py is modified to only write to the output file when contents
change.
Overall, incremental build time (with no source files changed) is
reduced from ~7 minutes to ~8 seconds (on a particular OS X
computer).
Due to the way Breathe includes Doxygen XML files, there is still
going to be a massive rebuild every time functions, enums, macros,
structures are added or removed from the header files scanned
by Doxygen, but at least individual .rst files can be edited
at a much faster pace.
2018-03-05 20:12:52 +08:00
|
|
|
def copy_if_modified(src_path, dst_path):
|
|
|
|
if os.path.isfile(src_path):
|
|
|
|
copy_file_if_modified(src_path, dst_path)
|
|
|
|
return
|
|
|
|
|
|
|
|
src_path_len = len(src_path)
|
|
|
|
for root, dirs, files in os.walk(src_path):
|
|
|
|
for src_file_name in files:
|
|
|
|
src_file_path = os.path.join(root, src_file_name)
|
|
|
|
dst_file_path = os.path.join(dst_path + root[src_path_len:], src_file_name)
|
|
|
|
copy_file_if_modified(src_file_path, dst_file_path)
|
2019-04-01 09:12:08 +08:00
|
|
|
|
|
|
|
|
2019-05-21 09:51:39 +08:00
|
|
|
def download_file_if_missing(from_url, to_path):
|
|
|
|
filename_with_path = to_path + "/" + os.path.basename(from_url)
|
|
|
|
exists = os.path.isfile(filename_with_path)
|
|
|
|
if exists:
|
|
|
|
print("The file '%s' already exists" % (filename_with_path))
|
|
|
|
else:
|
|
|
|
tmp_file, header = _urlretrieve(from_url)
|
|
|
|
with open(filename_with_path, 'wb') as fobj:
|
|
|
|
with open(tmp_file, 'rb') as tmp:
|
|
|
|
fobj.write(tmp.read())
|