Merge "Add driver list to doc build"
This commit is contained in:
		
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -30,6 +30,7 @@ tags | ||||
| # Files created by Sphinx build | ||||
| doc/build | ||||
| doc/source/_static/cinder.conf.sample | ||||
| doc/source/drivers.rst | ||||
|  | ||||
| #Files created for API reference | ||||
| api-ref/build | ||||
|   | ||||
							
								
								
									
										24
									
								
								doc/ext/cinder_driverlist.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								doc/ext/cinder_driverlist.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| # Copyright 2016 Dell Inc. | ||||
| # All Rights Reserved. | ||||
| # | ||||
| #    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. | ||||
| # | ||||
|  | ||||
| from cinder import utils | ||||
|  | ||||
|  | ||||
| def setup(app): | ||||
|     print('** Generating driver list...') | ||||
|     rv = utils.execute('./tools/generate_driver_list.py', ['docs']) | ||||
|     print(rv[0]) | ||||
|  | ||||
| @@ -35,6 +35,7 @@ extensions = ['sphinx.ext.autodoc', | ||||
|               'oslosphinx', | ||||
|               'stevedore.sphinxext', | ||||
|               'oslo_config.sphinxconfiggen', | ||||
|               'ext.cinder_driverlist', | ||||
|               ] | ||||
|  | ||||
| config_generator_config_file = '../../cinder/config/cinder-config-generator.conf' | ||||
|   | ||||
| @@ -1,6 +0,0 @@ | ||||
| =================== | ||||
|  Available Drivers | ||||
| =================== | ||||
|  | ||||
| .. list-plugins:: oslo_messaging.notify.drivers | ||||
|     :detailed: | ||||
| @@ -44,9 +44,20 @@ Developer Docs | ||||
|    database_architecture | ||||
|    scheduler-filters | ||||
|    scheduler-weights | ||||
|    drivers | ||||
|    oslo-middleware | ||||
|  | ||||
| Drivers | ||||
| ======= | ||||
|  | ||||
| Cinder maintains drivers for volume backends, backup targets, and fibre | ||||
| channel zone manager fabric types. The list of the available drivers can be | ||||
| found here: | ||||
|  | ||||
| .. toctree:: | ||||
|    :maxdepth: 1 | ||||
|  | ||||
|    drivers | ||||
|  | ||||
| API Extensions | ||||
| ============== | ||||
|  | ||||
|   | ||||
| @@ -15,30 +15,55 @@ | ||||
| """Generate list of cinder drivers""" | ||||
|  | ||||
| import os | ||||
| import sys | ||||
|  | ||||
| from cinder.interface import util | ||||
|  | ||||
|  | ||||
| def format_description(desc): | ||||
| class Output(object): | ||||
|  | ||||
|     def __init__(self, base_dir): | ||||
|         # At this point we don't care what was passed in, just a trigger | ||||
|         # to write this out to the doc tree for now | ||||
|         self.driver_file = None | ||||
|         if len(sys.argv) > 1: | ||||
|             self.driver_file = open( | ||||
|                 '%s/doc/source/drivers.rst' % base_dir, 'w+') | ||||
|             self.driver_file.write('===================\n') | ||||
|             self.driver_file.write('Available Drivers\n') | ||||
|             self.driver_file.write('===================\n\n') | ||||
|  | ||||
|     def __enter__(self): | ||||
|         return self | ||||
|  | ||||
|     def __exit__(self, type, value, traceback): | ||||
|         self.driver_file.close() | ||||
|  | ||||
|     def write(self, text): | ||||
|         if self.driver_file: | ||||
|             self.driver_file.write('%s\n' % text) | ||||
|         else: | ||||
|             print(text) | ||||
|  | ||||
|  | ||||
| def format_description(desc, output): | ||||
|     desc = desc or '<None>' | ||||
|     lines = desc.rstrip('\n').split('\n') | ||||
|     for line in lines: | ||||
|         print('    %s' % line) | ||||
|         output.write('    %s' % line) | ||||
|  | ||||
|  | ||||
| def print_drivers(drivers, config_name): | ||||
|     # for driver in drivers.sort(key=lambda x: x.class_fqn): | ||||
| def print_drivers(drivers, config_name, output): | ||||
|     for driver in sorted(drivers, key=lambda x: x.class_fqn): | ||||
|         print(driver.class_name) | ||||
|         print('-' * len(driver.class_name)) | ||||
|         output.write(driver.class_name) | ||||
|         output.write('-' * len(driver.class_name)) | ||||
|         if driver.version: | ||||
|             print('* Version: %s' % driver.version) | ||||
|         print('* %s=%s' % (config_name, driver.class_fqn)) | ||||
|         print('* Description::') | ||||
|         print('') | ||||
|         format_description(driver.desc) | ||||
|         print('') | ||||
|     print('') | ||||
|             output.write('* Version: %s' % driver.version) | ||||
|         output.write('* %s=%s' % (config_name, driver.class_fqn)) | ||||
|         output.write('* Description:') | ||||
|         format_description(driver.desc, output) | ||||
|         output.write('') | ||||
|     output.write('') | ||||
|  | ||||
|  | ||||
| def main(): | ||||
| @@ -48,17 +73,18 @@ def main(): | ||||
|     os.chdir(cinder_root) | ||||
|  | ||||
|     try: | ||||
|         print('VOLUME DRIVERS') | ||||
|         print('==============') | ||||
|         print_drivers(util.get_volume_drivers(), 'volume_driver') | ||||
|         with Output(cinder_root) as output: | ||||
|             output.write('Volume Drivers') | ||||
|             output.write('==============') | ||||
|             print_drivers(util.get_volume_drivers(), 'volume_driver', output) | ||||
|  | ||||
|         print('BACKUP DRIVERS') | ||||
|         print('==============') | ||||
|         print_drivers(util.get_backup_drivers(), 'backup_driver') | ||||
|             output.write('Backup Drivers') | ||||
|             output.write('==============') | ||||
|             print_drivers(util.get_backup_drivers(), 'backup_driver', output) | ||||
|  | ||||
|         print('FC ZONE MANAGER DRIVERS') | ||||
|         print('=======================') | ||||
|         print_drivers(util.get_fczm_drivers(), 'zone_driver') | ||||
|             output.write('FC Zone Manager Drivers') | ||||
|             output.write('=======================') | ||||
|             print_drivers(util.get_fczm_drivers(), 'zone_driver', output) | ||||
|     finally: | ||||
|         os.chdir(cur_dir) | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Jenkins
					Jenkins