Skip to content

Instantly share code, notes, and snippets.

@kascote
Created May 24, 2017 19:15
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save kascote/c4c2d8bc223307bae7f9f9e92a2b73c5 to your computer and use it in GitHub Desktop.
Save kascote/c4c2d8bc223307bae7f9f9e92a2b73c5 to your computer and use it in GitHub Desktop.
Parse Rails's database.yml and start psql
#!/bin/bash
parse_yaml() {
local prefix=$2
local s='[[:space:]]*' w='[a-zA-Z0-9_]*' fs=$(echo @|tr @ '\034')
sed -ne "s|^\($s\)\($w\)$s:$s\"\(.*\)\"$s\$|\1$fs\2$fs\3|p" \
-e "s|^\($s\)\($w\)$s:$s\(.*\)$s\$|\1$fs\2$fs\3|p" $1 |
awk -F$fs '{
indent = length($1)/2;
vname[indent] = $2;
for (i in vname) {if (i > indent) {delete vname[i]}}
if (length($3) > 0) {
vn=""; for (i=0; i<indent; i++) {vn=(vn)(vname[i])("_")}
printf("%s%s%s=\"%s\"\n", "'$prefix'",vn, $2, $3);
}
}'
}
# read yaml file
eval $(parse_yaml config/database.yml "db_")
PGPASSWORD=$db_default_password psql -h $db_default_host -U $db_default_username $db_development_database
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment