56 lines
1.6 KiB
Bash
Executable file
56 lines
1.6 KiB
Bash
Executable file
#!/bin/sh
|
|
|
|
set -x
|
|
set -e
|
|
set -u
|
|
|
|
# get current stuff
|
|
git clone git@github.com:ansible/ansible.git ansible_unified
|
|
cd ansible_unified/
|
|
git submodule init
|
|
git submodule update
|
|
|
|
# add submodules as remotes
|
|
git remote add core_modules git@github.com:ansible/ansible-modules-core.git
|
|
git remote add extras_modules git@github.com:ansible/ansible-modules-extras.git
|
|
git fetch --all
|
|
|
|
# remove submodules
|
|
echo "" > .gitmodules
|
|
git add .gitmodules
|
|
git rm --cached lib/ansible/modules/core/
|
|
git rm --cached lib/ansible/modules/extras/
|
|
git commit -am "removed core and extras submodules"
|
|
rm -rf lib/ansible/modules/core
|
|
rm -rf lib/ansible/modules/extras
|
|
|
|
# merge remotes into old submodule dirs
|
|
## core
|
|
git merge -s ours --allow-unrelated-histories --no-commit core_modules/devel
|
|
git read-tree --prefix=lib/ansible/modules/core -u core_modules/devel
|
|
git commit -am 'core modules back to main repo'
|
|
## extras
|
|
git merge -s ours --allow-unrelated-histories --no-commit extras_modules/devel
|
|
git read-tree --prefix=lib/ansible/modules/extras -u extras_modules/devel
|
|
git commit -am 'extras modules back to main repo'
|
|
|
|
for subdir in core extras
|
|
do
|
|
# unify directories
|
|
for mydir in $(find lib/ansible/modules/${subdir} -type d)
|
|
do
|
|
mkdir -p ${mydir/$subdir\//}
|
|
done
|
|
|
|
# move plugins
|
|
for myfile in $(find lib/ansible/modules/${subdir} -type f|grep -v '.github')
|
|
do
|
|
if [ -e ${myfile/$subdir\///} ]; then #mostly to avoid __init__.py clobering
|
|
echo "skipping ${myfile} as it already exists in destination"
|
|
else
|
|
git mv ${myfile} ${myfile/$subdir\//}
|
|
fi
|
|
done
|
|
|
|
git rm -rf lib/ansible/modules/${subdir}
|
|
done
|