| #!/usr/bin/env bash |
|
|
|
|
| function parse_yaml { |
| local prefix=$2 |
| local s='[[:space:]]*' w='[a-zA-Z0-9_]*' fs=$(echo @|tr @ '\034') |
| sed -ne "s|^\($s\):|\1|" \ |
| -e "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); |
| } |
| }' |
| } |
| main_config_yml=$1 |
| local_root=$2 |
| if [[ ${main_config_yml} == "hdfs://"* ]]; then |
| config_filename=`basename ${main_config_yml}` |
| echo 'download config from ${main_config_yml}...' |
| local_config="${local_root}/config" && mkdir -p ${local_config} |
| hadoop fs -get ${main_config_yml} ${local_config}/ |
| echo 'finish download config from ${main_config_yml}...' |
| main_config_yml=${local_config}/${config_filename} |
| fi |
|
|
| compgen -A variable > ~/.env-vars |
| eval $(parse_yaml ${main_config_yml}) |
|
|
| |
| options="" |
| for var in `compgen -A variable | grep -Fxvf ~/.env-vars` |
| do |
| if [[ ${var} == "model_"* || ${var} == "data_"* || ${var} == "options" ]]; then |
| continue |
| fi |
| if [[ ${!var} == "true" ]]; then |
| varname=`echo ${var} | sed 's/\_/\-/g'` |
| options=${options}" --${varname}" |
| else |
| varname=`echo ${var} | sed 's/\_/\-/g'` |
| options=${options}" --${varname} ${!var}" |
| fi |
| done |
|
|