tools/generate-devstack-plugins-list.sh
4fd874b4
 #!/bin/bash -ex
 
 # Copyright 2016 Hewlett Packard Enterprise Development Company, L.P.
 #
 # 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.
 
 # This script is intended to be run as a periodic proposal bot job
 # in OpenStack infrastructure, though you can run it as a one-off.
 #
 # In order to function correctly, the environment in which the
 # script runs must have
e3e80518
 #   * a writable doc/source directory relative to the current
 #     working directory
 #   AND ( (
4fd874b4
 #   * git
 #   * all git repos meant to be searched for plugins cloned and
 #     at the desired level of up-to-datedness
e3e80518
 #   * the environment variable git_dir pointing to the location
 #   * of said git repositories
 #   ) OR (
 #   * network access to the review.openstack.org Gerrit API
4fd874b4
 #     working directory
e3e80518
 #   * network access to https://git.openstack.org/cgit
 #   ))
4fd874b4
 #
 # If a file named data/devstack-plugins-registry.header or
 # data/devstack-plugins-registry.footer is found relative to the
 # current working directory, it will be prepended or appended to
 # the generated reStructuredText plugins table respectively.
 
c10989bf
 # Print the title underline for a RST table.  Argument is the length
 # of the first column, second column is assumed to be "URL"
 function title_underline {
     local len=$1
     while [[ $len -gt 0 ]]; do
         printf "="
         len=$(( len - 1))
     done
     printf " ===\n"
 }
 
4fd874b4
 (
 declare -A plugins
 
f3b6feb7
 if [[ -r data/devstack-plugins-registry.header ]]; then
     cat data/devstack-plugins-registry.header
 fi
4fd874b4
 
8ce3faf4
 sorted_plugins=$(python tools/generate-devstack-plugins-list.py)
 
c10989bf
 # find the length of the name column & pad
 name_col_len=$(echo "${sorted_plugins}" | wc -L)
 name_col_len=$(( name_col_len + 2 ))
 
 # ====================== ===
 # Plugin Name            URL
 # ====================== ===
 # foobar                 `git://... <http://...>`__
 # ...
 
17e45013
 printf "\n\n"
c10989bf
 title_underline ${name_col_len}
 printf "%-${name_col_len}s %s\n" "Plugin Name" "URL"
 title_underline ${name_col_len}
 
 for plugin in ${sorted_plugins}; do
     giturl="git://git.openstack.org/openstack/${plugin}"
     gitlink="https://git.openstack.org/cgit/openstack/${plugin}"
930bc437
     printf "%-${name_col_len}s %s\n" "${plugin}" "\`${giturl} <${gitlink}>\`__"
8ce3faf4
 done
e9820732
 
 title_underline ${name_col_len}
 
17e45013
 printf "\n\n"
4fd874b4
 
f3b6feb7
 if [[ -r data/devstack-plugins-registry.footer ]]; then
     cat data/devstack-plugins-registry.footer
 fi
4fd874b4
 ) > doc/source/plugin-registry.rst
e6f0d8cb
 
 if [[ -n ${1} ]]; then
     cp doc/source/plugin-registry.rst ${1}/doc/source/plugin-registry.rst
 fi