|  | @@ -9,8 +9,6 @@ from collections import OrderedDict
 | 
											
												
													
														|  |  from datetime import datetime, timezone
 |  |  from datetime import datetime, timezone
 | 
											
												
													
														|  |  import time
 |  |  import time
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -from setuptools import Command
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  def format_metavar(option):
 |  |  def format_metavar(option):
 | 
											
												
													
														|  |      if option.nargs in ("*", "..."):
 |  |      if option.nargs in ("*", "..."):
 | 
											
										
											
												
													
														|  | @@ -23,16 +21,8 @@ def format_metavar(option):
 | 
											
												
													
														|  |          raise ValueError(f"Can't format metavar {option.metavar}, unknown nargs {option.nargs}!")
 |  |          raise ValueError(f"Can't format metavar {option.metavar}, unknown nargs {option.nargs}!")
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -class build_usage(Command):
 |  | 
 | 
											
												
													
														|  | -    description = "generate usage for each command"
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    user_options = [("output=", "O", "output directory")]
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    def initialize_options(self):
 |  | 
 | 
											
												
													
														|  | -        pass
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    def finalize_options(self):
 |  | 
 | 
											
												
													
														|  | -        pass
 |  | 
 | 
											
												
													
														|  | 
 |  | +class BuildUsage:
 | 
											
												
													
														|  | 
 |  | +    """generate usage docs for each command"""
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def run(self):
 |  |      def run(self):
 | 
											
												
													
														|  |          print("generating usage docs")
 |  |          print("generating usage docs")
 | 
											
										
											
												
													
														|  | @@ -49,6 +39,7 @@ class build_usage(Command):
 | 
											
												
													
														|  |          # borgfs_parser = Archiver(prog='borgfs').build_parser()
 |  |          # borgfs_parser = Archiver(prog='borgfs').build_parser()
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          self.generate_level("", parser, Archiver)
 |  |          self.generate_level("", parser, Archiver)
 | 
											
												
													
														|  | 
 |  | +        return 0
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def generate_level(self, prefix, parser, Archiver, extra_choices=None):
 |  |      def generate_level(self, prefix, parser, Archiver, extra_choices=None):
 | 
											
												
													
														|  |          is_subcommand = False
 |  |          is_subcommand = False
 | 
											
										
											
												
													
														|  | @@ -123,10 +114,6 @@ class build_usage(Command):
 | 
											
												
													
														|  |          # HTML output:
 |  |          # HTML output:
 | 
											
												
													
														|  |          # A table using some column-spans
 |  |          # A table using some column-spans
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        def html_write(s):
 |  | 
 | 
											
												
													
														|  | -            for line in s.splitlines():
 |  | 
 | 
											
												
													
														|  | -                fp.write("    " + line + "\n")
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |          rows = []
 |  |          rows = []
 | 
											
												
													
														|  |          for group in parser._action_groups:
 |  |          for group in parser._action_groups:
 | 
											
												
													
														|  |              if group.title == "Common options":
 |  |              if group.title == "Common options":
 | 
											
										
											
												
													
														|  | @@ -265,10 +252,8 @@ class build_usage(Command):
 | 
											
												
													
														|  |              fp.write(indent + option.ljust(padding) + desc + "\n")
 |  |              fp.write(indent + option.ljust(padding) + desc + "\n")
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -class build_man(Command):
 |  | 
 | 
											
												
													
														|  | -    description = "build man pages"
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    user_options = []
 |  | 
 | 
											
												
													
														|  | 
 |  | +class BuildMan:
 | 
											
												
													
														|  | 
 |  | +    """build man pages"""
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      see_also = {
 |  |      see_also = {
 | 
											
												
													
														|  |          "create": ("delete", "prune", "check", "patterns", "placeholders", "compression", "rcreate"),
 |  |          "create": ("delete", "prune", "check", "patterns", "placeholders", "compression", "rcreate"),
 | 
											
										
											
												
													
														|  | @@ -308,12 +293,6 @@ class build_man(Command):
 | 
											
												
													
														|  |          "umount": "mount",
 |  |          "umount": "mount",
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    def initialize_options(self):
 |  | 
 | 
											
												
													
														|  | -        pass
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    def finalize_options(self):
 |  | 
 | 
											
												
													
														|  | -        pass
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |      def run(self):
 |  |      def run(self):
 | 
											
												
													
														|  |          print("building man pages (in docs/man)", file=sys.stderr)
 |  |          print("building man pages (in docs/man)", file=sys.stderr)
 | 
											
												
													
														|  |          import borg
 |  |          import borg
 | 
											
										
											
												
													
														|  | @@ -329,6 +308,7 @@ class build_man(Command):
 | 
											
												
													
														|  |          self.generate_level("", parser, Archiver, {"borgfs": borgfs_parser})
 |  |          self.generate_level("", parser, Archiver, {"borgfs": borgfs_parser})
 | 
											
												
													
														|  |          self.build_topic_pages(Archiver)
 |  |          self.build_topic_pages(Archiver)
 | 
											
												
													
														|  |          self.build_intro_page()
 |  |          self.build_intro_page()
 | 
											
												
													
														|  | 
 |  | +        return 0
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def generate_level(self, prefix, parser, Archiver, extra_choices=None):
 |  |      def generate_level(self, prefix, parser, Archiver, extra_choices=None):
 | 
											
												
													
														|  |          is_subcommand = False
 |  |          is_subcommand = False
 | 
											
										
											
												
													
														|  | @@ -548,3 +528,33 @@ class build_man(Command):
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          for option, desc in opts.items():
 |  |          for option, desc in opts.items():
 | 
											
												
													
														|  |              write(option.ljust(padding), desc)
 |  |              write(option.ljust(padding), desc)
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +def usage():
 | 
											
												
													
														|  | 
 |  | +    print(
 | 
											
												
													
														|  | 
 |  | +        textwrap.dedent(
 | 
											
												
													
														|  | 
 |  | +            """
 | 
											
												
													
														|  | 
 |  | +        Usage:
 | 
											
												
													
														|  | 
 |  | +            python scripts/gendocs.py build_usage  # build usage documentation
 | 
											
												
													
														|  | 
 |  | +            python scripts/gendocs.py build_man    # build man pages
 | 
											
												
													
														|  | 
 |  | +    """
 | 
											
												
													
														|  | 
 |  | +        )
 | 
											
												
													
														|  | 
 |  | +    )
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +def main(argv):
 | 
											
												
													
														|  | 
 |  | +    if len(argv) < 2 or len(argv) == 2 and argv[1] in ("-h", "--help"):
 | 
											
												
													
														|  | 
 |  | +        usage()
 | 
											
												
													
														|  | 
 |  | +        return 0
 | 
											
												
													
														|  | 
 |  | +    command = argv[1]
 | 
											
												
													
														|  | 
 |  | +    if command == "build_usage":
 | 
											
												
													
														|  | 
 |  | +        return BuildUsage().run()
 | 
											
												
													
														|  | 
 |  | +    if command == "build_man":
 | 
											
												
													
														|  | 
 |  | +        return BuildMan().run()
 | 
											
												
													
														|  | 
 |  | +    usage()
 | 
											
												
													
														|  | 
 |  | +    return 1
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +if __name__ == "__main__":
 | 
											
												
													
														|  | 
 |  | +    rc = main(sys.argv)
 | 
											
												
													
														|  | 
 |  | +    sys.exit(rc)
 |