+###
+# list command
+
+COMMANDS+=('list')
+
+function list_help()
+{
+ echo 'List current dotfiles repositories.'
+ if [ "${1}" = '--one-line' ]; then return; fi
+
+ cat <<-EOF
+
+ usage: $0 ${COMMAND} [REPO]
+
+ List information for 'REPO' in a form simular to the 'clone'
+ command's arguments. If 'REPO' is not give, all repositories will
+ be listed. Examples:
+
+ $0 list public
+ public wget http://example.com/public-dotfiles.tar.gz
+ $0 list
+ public wget http://example.com/public-dotfiles.tar.gz
+ private git ssh://example.com/~/private-dotfiles.git
+ EOF
+}
+
+function list()
+{
+ # multi-repo case handled in main() by run_on_all_repos()
+ REPO=$(nonempty_option 'list' 'REPO' "${1}") || return 1
+ maxargs 'list' 1 "${@}" || return 1
+ if [ "${BASH_MAJOR}" -ge 4 ]; then
+ get_repo_source "${REPO}" || return 1
+ TRANSFER=$(nonempty_option 'list' 'TRANSFER' "${REPO_SOURCE_DATA['transfer']}") || return 1
+ URL=$(nonempty_option 'list' 'URL' "${REPO_SOURCE_DATA['url']}") || return 1
+ else
+ echo "WARNING: Bash version < 4.0, cannot use assuming all repos use git transfer" >&2
+ TRANSFER='git'
+ URL=$(git --git-dir "${REPO}/.git/" config remote.origin.url)
+ fi
+ echo "${REPO} ${TRANSFER} ${URL}"
+}
+