mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-23 01:47:33 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			188 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			188 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python
 | ||
| # -*- coding: utf-8 -*-
 | ||
| #
 | ||
| # Python script to generate ReSTructured Text .inc snippets
 | ||
| # with version-based content for this IDF version
 | ||
| 
 | ||
| from __future__ import print_function
 | ||
| from __future__ import unicode_literals
 | ||
| from io import open
 | ||
| import subprocess
 | ||
| import os
 | ||
| import sys
 | ||
| import re
 | ||
| 
 | ||
| TEMPLATES = {
 | ||
|     "en" : {
 | ||
|         "git-clone" : {
 | ||
|             "template" : """
 | ||
| To obtain a local copy: open terminal, navigate to the directory you want to put ESP8266_RTOS_SDK, and clone the repository using ``git clone`` command::
 | ||
| 
 | ||
|     cd ~/esp
 | ||
|     git clone %(clone_args)s--recursive https://github.com/espressif/ESP8266_RTOS_SDK.git
 | ||
| 
 | ||
| ESP8266_RTOS_SDK will be downloaded into ``~/esp/ESP8266_RTOS_SDK``.
 | ||
| 
 | ||
| .. note::
 | ||
| 
 | ||
|     %(extra_note)s
 | ||
| 
 | ||
| .. note::
 | ||
| 
 | ||
|     %(zipfile_note)s
 | ||
| """
 | ||
|             ,"master" : 'This command will clone the master branch, which has the latest development ("bleeding edge") version of ESP8266_RTOS_SDK. It is fully functional and updated on weekly basis with the most recent features and bugfixes.'
 | ||
|             ,"branch" : 'The ``git clone`` option ``-b %(clone_arg)s`` tells git to clone the %(ver_type)s in the ESP8266_RTOS_SDK repository corresponding to this version of the documentation.'
 | ||
|             ,"zipfile" : {
 | ||
|                 "stable" : 'As a fallback, it is also possible to download a zip file of this stable release from the `Releases page`_. Do not download the "Source code" zip file(s) generated automatically by GitHub, they do not work with ESP8266_RTOS_SDK.'
 | ||
|                 ,"unstable" : 'GitHub\'s "Download zip file" feature does not work with ESP8266_RTOS_SDK, a ``git clone`` is required. As a fallback, `Stable version`_ can be installed without Git.'
 | ||
|                 },  # zipfile
 | ||
|             },  # git-clone
 | ||
|         "version-note" : {
 | ||
|             "master" : """
 | ||
| .. note::
 | ||
|      This is documentation for the master branch (latest version) of ESP8266_RTOS_SDK. This version is under continual development. `Stable version`_ documentation is available, as well as other :doc:`/versions`.
 | ||
| """
 | ||
|             ,"stable" : """
 | ||
| .. note::
 | ||
|      This is documentation for stable version %s of ESP8266_RTOS_SDK. Other :doc:`/versions` are also available.
 | ||
| """
 | ||
|             ,"branch" : """
 | ||
| .. note::
 | ||
|      This is documentation for %s ``%s`` of ESP8266_RTOS_SDK. Other :doc:`/versions` are also available.
 | ||
| """
 | ||
|             },  # version-note
 | ||
|     }, # en
 | ||
|     "zh_CN" : {
 | ||
|         "git-clone" : {
 | ||
|             "template" : """
 | ||
| 获取本地副本:打开终端,切换到你要存放 ESP8266_RTOS_SDK 的工作目录,使用 ``git clone`` 命令克隆远程仓库::
 | ||
| 
 | ||
|     cd ~/esp
 | ||
|     git clone %(clone_args)s--recursive https://github.com/espressif/ESP8266_RTOS_SDK.git
 | ||
| 
 | ||
| ESP8266_RTOS_SDK 将会被下载到 ``~/esp/ESP8266_RTOS_SDK`` 目录下。
 | ||
| 
 | ||
| .. note::
 | ||
| 
 | ||
|     %(extra_note)s
 | ||
| 
 | ||
| .. note::
 | ||
| 
 | ||
|     %(zipfile_note)s
 | ||
| """
 | ||
|             ,"master" : '此命令将克隆 master 分支,该分支保存着 ESP8266_RTOS_SDK 的最新版本,它功能齐全,每周都会更新一些新功能并修正一些错误。'
 | ||
|             ,"branch" : '``git clone`` 命令的 ``-b %(clone_arg)s`` 选项告诉 git 从 ESP8266_RTOS_SDK 仓库中克隆与此版本的文档对应的分支。'
 | ||
|             ,"zipfile" : {
 | ||
|                 "stable" : '作为备份,还可以从 `Releases page`_ 下载此稳定版本的 zip 文件。不要下载由 GitHub 自动生成的"源代码"的 zip 文件,它们不适用于 ESP8266_RTOS_SDK。'
 | ||
|                 ,"unstable" : 'GitHub 中"下载 zip 文档"的功能不适用于 ESP8266_RTOS_SDK,所以需要使用 ``git clone`` 命令。作为备份,可以在没有安装 Git 的环境中下载 `Stable version`_ 的 zip 归档文件。'
 | ||
|                 },  # zipfile
 | ||
|             },  # git-clone
 | ||
|         "version-note" : {
 | ||
|             "master" : """
 | ||
| .. note::
 | ||
|      这是ESP8266_RTOS_SDK master 分支(最新版本)的文档,该版本在持续开发中。还有 `Stable version`_ 的文档,以及其他版本的文档 :doc:`/versions` 供参考。
 | ||
|      This is documentation for the master branch (latest version) of ESP8266_RTOS_SDK. This version is under continual development. `Stable version`_ documentation is available, as well as other :doc:`/versions`.
 | ||
| """
 | ||
|             ,"stable" : """
 | ||
| .. note::
 | ||
|      这是ESP8266_RTOS_SDK 稳定版本 %s 的文档,还有其他版本的文档 :doc:`/versions` 供参考。
 | ||
| """
 | ||
|             ,"branch" : """
 | ||
| .. note::
 | ||
|      这是ESP8266_RTOS_SDK %s ``%s`` 版本的文档,还有其他版本的文档 :doc:`/versions` 供参考。
 | ||
| """
 | ||
|             },  # version-note
 | ||
|     }# zh_CN
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| def main():
 | ||
|     if len(sys.argv) != 3:
 | ||
|         print("Usage: gen-git-clone.py <language> <output file path>")
 | ||
|         sys.exit(1)
 | ||
| 
 | ||
|     language = sys.argv[1]
 | ||
|     out_dir = sys.argv[2]
 | ||
|     if not os.path.exists(out_dir):
 | ||
|         print("Creating directory %s" % out_dir)
 | ||
|         os.mkdir(out_dir)
 | ||
| 
 | ||
|     template = TEMPLATES[language]
 | ||
| 
 | ||
|     version, ver_type, is_stable = get_version()
 | ||
| 
 | ||
|     write_git_clone_inc(template["git-clone"], out_dir, version, ver_type, is_stable)
 | ||
|     write_version_note(template["version-note"], out_dir, version, ver_type, is_stable)
 | ||
|     print("Done")
 | ||
| 
 | ||
| 
 | ||
| def write_git_clone_inc(template, out_dir, version, ver_type, is_stable):
 | ||
|     zipfile = template["zipfile"]
 | ||
|     if version == "master":
 | ||
|         args = {
 | ||
|             "clone_args" : "",
 | ||
|             "extra_note" : template["master"],
 | ||
|             "zipfile_note" : zipfile["unstable"]
 | ||
|         }
 | ||
|     else:
 | ||
|         args = {
 | ||
|             "clone_args" : "-b %s " % version,
 | ||
|             "extra_note" : template["branch"] % {"clone_arg" : version, "ver_type" : ver_type},
 | ||
|             "zipfile_note" : zipfile["stable"] if is_stable else zipfile["unstable"]
 | ||
|         }
 | ||
|     out_file = os.path.join(out_dir, "git-clone.inc")
 | ||
|     with open(out_file, "w", encoding='utf-8') as f:
 | ||
|         f.write(template["template"] % args)
 | ||
|     print("%s written" % out_file)
 | ||
| 
 | ||
| 
 | ||
| def write_version_note(template, out_dir, version, ver_type, is_stable):
 | ||
|     if version == "master":
 | ||
|         content = template["master"]
 | ||
|     elif ver_type == "tag" and is_stable:
 | ||
|         content = template["stable"] % version
 | ||
|     else:
 | ||
|         content = template["branch"] % (ver_type, version)
 | ||
|     out_file = os.path.join(out_dir, "version-note.inc")
 | ||
|     with open(out_file, "w", encoding='utf-8') as f:
 | ||
|         f.write(content)
 | ||
|     print("%s written" % out_file)
 | ||
| 
 | ||
| 
 | ||
| def get_version():
 | ||
|     """
 | ||
|     Returns a tuple of (name of branch/tag, type branch/tag, is_stable)
 | ||
|     """
 | ||
|     # Trust what RTD says our version is, if it is set
 | ||
|     version = os.environ.get("READTHEDOCS_VERSION", None)
 | ||
|     if version == "latest":
 | ||
|         return ("master", "branch", False)
 | ||
| 
 | ||
|     # Otherwise, use git to look for a tag
 | ||
|     try:
 | ||
|         tag = subprocess.check_output(["git", "describe", "--tags", "--exact-match"]).strip()
 | ||
|         if isinstance(tag, bytes):
 | ||
|             tag = tag.decode()
 | ||
|         is_stable = re.match(r"v[0-9\.]+$", tag) is not None
 | ||
|         return (tag, "tag", is_stable)
 | ||
|     except subprocess.CalledProcessError:
 | ||
|         pass
 | ||
| 
 | ||
|     # No tag, look for a branch
 | ||
|     refs = subprocess.check_output(["git", "for-each-ref", "--points-at", "HEAD", "--format", "%(refname)"])
 | ||
|     print("refs:\n%s" % refs)
 | ||
|     refs = refs.split(b"\n")
 | ||
|     # Note: this looks for branches in 'origin' because GitLab CI doesn't check out a local branch
 | ||
|     branches = [ r.replace(b"refs/remotes/origin/",b"").strip() for r in refs if r.startswith(b"refs/remotes/origin/") ]
 | ||
|     if len(branches) == 0:
 | ||
|         # last resort, return the commit (may happen on Gitlab CI sometimes, unclear why)
 | ||
|         return (subprocess.check_output(["git", "rev-parse", "--short", "HEAD"]).strip(), "commit", False)
 | ||
|     if "master" in branches:
 | ||
|         return ("master", "branch", False)
 | ||
|     else:
 | ||
|         return (branches[0], "branch", False)  # take whatever the first branch is
 | ||
| 
 | ||
| if __name__ == "__main__":
 | ||
|     main()
 | 
