Browse Source

Convert s3.TUP plugin to s3 module (v0.10.0) (#12)

* Convert s3.TUP plugin to s3 module (v0.10.0)
integrate toolchain updater in then Main Menu
replace copy functionality in Toolchain Menu with backup function
new commandline options:
	./s3 tcupdate -b/--backup TOOLCHAIN-NAME #create backup archive in download folder
	./s3 tcupdate -d/--duplicate TOOLCHAIN-NAME NEW-TOOLCHAIN-NAME #create a copy of toolchain

* extend command line parameters (v0.10.1)
better support for scripted cross toolchain creation
new commandline options:
./s3 tcupdate -c/--create TEMPLATE-NAME #create cross toolchain based on given template name
./s3 tcupdate -s/--setup #installs build environment of crosstool-NG

* extend command line parameters (v0.10.2)
better support for scripted cross toolchain creation
new commandline options:
./s3 tcupdate TOOLCHAIN-NAME LIBRARY-KEY-1,LIBRARY-KEY-2,LIBRARY-KEY-n #update the specified toolchain with the specified libraries

* code optimization (v0.10.3)
pull/14/head
WXbet 5 years ago
committed by GitHub
parent
commit
cf009dd0ad
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 11
      s3
  2. 5
      support/functions/_misc
  3. 589
      support/functions/_plugin_update_toolchain
  4. 1
      support/translation/de
  5. 1
      support/translation/en

11
s3

@ -68,7 +68,7 @@ declare -a SHORT_READERS; declare -a SHORT_CARD_READERS; declare -A INTERNAL_
#filled arrays #filled arrays
config_cases=( all addons protocols readers card_readers ); config_cases=( all addons protocols readers card_readers );
s3opts=( help cedit clean enable_emu fix_me tccheck tcrepair upload update_me update_emu lang_select loadonly checkout ssh_profiles syscheck sysinfo svnup menu get_patch tedit svnpatch profiles svnrestore update ); # extendable with plugins s3opts=( help cedit clean enable_emu fix_me tccheck tcrepair tcupdate upload update_me update_emu lang_select loadonly checkout ssh_profiles syscheck sysinfo svnup menu get_patch tedit svnpatch profiles svnrestore update ); # extendable with plugins
CUSTOM_CONFDIR="not_set"; CUSTOM_CONFDIR="not_set";
pf_name="not_set"; pf_name="not_set";
UPX="not_set"; UPX="not_set";
@ -114,10 +114,10 @@ syscheck;[ ! "$sanity" == "1" ] && echo "sanity fail" && sleep 5 && bye;
_create_native_profile; # put native datas to toolchains and configs _create_native_profile; # put native datas to toolchains and configs
_get_config_con "$1"; # echo $addons;exit; _get_config_con "$1"; # echo $addons;exit;
_create_module_arrays; # fill module arrays _create_module_arrays; # fill module arrays
_fill_tc_array; # get # AVAI_TCLIST # INST_TCLIST # MISS_TCLIST _fill_tc_array; # get # AVAI_TCLIST # INST_TCLIST # MISS_TCLIST
read_s3cfg; # read simplebuild config read_s3cfg; # read simplebuild config
_set_dialog_types; # fill $gui vars _set_dialog_types; # fill $gui vars
_systype; # check used uname _systype; # check used uname
if [ ! -n "$1" ];then if [ ! -n "$1" ];then
[ "${s3cfg_vars[DIRECTMENU]}" == "1" ] && _dialog_checkout && exit; [ "${s3cfg_vars[DIRECTMENU]}" == "1" ] && _dialog_checkout && exit;
@ -198,6 +198,7 @@ else
else else
_nl;clear;_toolchain_repair "$2";sleep 2;exit; _nl;clear;_toolchain_repair "$2";sleep 2;exit;
fi;; fi;;
tcupdate) _nl;clear;tcupdate "$2" "$3" "$4" "1";sleep 2;exit;;
upload) if [ ! -n "$2" ];then upload) if [ ! -n "$2" ];then
_nl; _nl;
clear; clear;

5
support/functions/_misc

@ -172,7 +172,7 @@ _select_menu(){
revision_="$(REVISION)"; revision_="$(REVISION)";
_menutext="Simplebuild V$SIMPLEVERSION by Gorgone"; _menutext="Simplebuild V$SIMPLEVERSION by Gorgone";
smenu=$( smenu=$(
"$gui" "$st_" "$bt_" "$title_" "$nc_" --title "-[ $txt_start_menu ]-" --menu "\n $_menutext" 13 55 7 "Continue" "$txt_firstmenu_continue r$revision_" "CHANGE" "$txt_firstmenu_chose" "CEDIT" "$txt_firstmenu_cedit" "LANG" "$txt_firstmenu_lang" "EXIT" "$txt_firstmenu_exit"); "$gui" "$st_" "$bt_" "$title_" "$nc_" --title "-[ $txt_start_menu ]-" --menu "\n $_menutext" 13 55 7 "Continue" "$txt_firstmenu_continue r$revision_" "CHANGE" "$txt_firstmenu_chose" "CEDIT" "$txt_firstmenu_cedit" "TCUPDATE" "$txt_firstmenu_tcupdate" "LANG" "$txt_firstmenu_lang" "EXIT" "$txt_firstmenu_exit");
[ $? = 255 ] && _select_menu; [ $? = 255 ] && _select_menu;
case $smenu in case $smenu in
Continue) Continue)
@ -191,6 +191,9 @@ _select_menu(){
CEDIT) CEDIT)
s3cfg_menu; s3cfg_menu;
_select_menu;; _select_menu;;
TCUPDATE)
tcupdate;
_select_menu;;
LANG) LANG)
lang_select; lang_select;
cd "$workdir"; cd "$workdir";

589
support/functions/_plugin_update_toolchain

@ -1,17 +1,20 @@
#!/bin/bash #!/bin/bash
#simplebuild_plugin tcupdate (s3.TUP)
tcupdate(){ tcupdate(){
clear && _check_bin; pversion="0.10.2";
pversion="0.9.3";
pname="s3.TUP"; pname="s3.TUP";
pdesc="Plugin $pname v$pversion"; pdesc="Plugin $pname v$pversion";
configname="$configdir/plugin_update_toolchain.config"; configname="$configdir/plugin_update_toolchain.config";
#remove config CMDTC="$1";
if [ "$1" == "-r" ] || [ "$1" == "--reset" ];then OPTION1="$2";
OPTION2="$3";
FLAG="$4";
clear && _check_bin;
#backup config
if [ "$CMDTC" == "-r" ] || [ "$CMDTC" == "--reset" ];then
if [ -f "$configname" ];then if [ -f "$configname" ];then
if ! _check_github_api_limits 12; then if ! _check_github_api_limits 12; then
echo -e "$y_l""RESET -> Moving existing config file...""$re_"; echo -e "$y_l""RESET -> Moving existing config file...""$re_";
@ -42,68 +45,77 @@ tcupdate(){
#check config #check config
_check_config; _check_config;
if [ "$1" == "-c" ] || [ "$1" == "--create" ];then if [ "$CMDTC" == "-c" ] || [ "$CMDTC" == "--create" ];then #start toolchain builder menu
_create_tc; _create_tc "$OPTION1" "" "$FLAG";
bye; bye;
elif [ "$1" == "" ];then elif [ "$CMDTC" == "-s" ] || [ "$CMDTC" == "--setup" ];then #setup crosstool-NG
_fill_tc_array; _create_tc "" "$CMDTC" "$FLAG";
unset MENU_OPTIONS;COUNT=0 bye;
if [ "$systype" == "ok" ];then elif [ "$CMDTC" == "-b" ] || [ "$CMDTC" == "--backup" ];then #backup toolchain
if [ "$tcempty" == "0" ];then if _check_toolchain "$OPTION1";then
for i in "${INST_TCLIST[@]}";do _backup "$OPTION1" "$OPTION1" >/dev/null;
if [ ! "$i" == "native" ];then bye;
source "$tccfgdir/$i"; else
[ -f "$tcdir/$i/build.log.bz2" ] && tcdate=" ct-ng."$(date -r "$tcdir/$i/build.log.bz2" "+%Y-%m-%d %H:%M:%S") || tcdate=""; _nl && exit;
MENU_OPTIONS+=("$_toolchainname" "$_description\Z2$tcdate\Zn" "toolchain folder:$tcdir/$i | config file:$tccfgdir/$i");
counter;
fi;
done;
fi;
[ $COUNT -eq 0 ] && MENU_OPTIONS+=("" "no toolchains found" "no toolchains found") && counter;
fi; fi;
elif [ "$CMDTC" == "-d" ] || [ "$CMDTC" == "--duplicate" ];then #duplicate toolchain
out=$("$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--item-help" "--help-tags" "--default-item" "$3" "--ok-label" "Update" "--cancel-label" "Create" "--help-button" "--help-label" "Exit" "--extra-button" "--extra-label" "Copy" "--title" "-[ Toolchain Menu ]-" \ if _check_toolchain "$OPTION1";then
--menu "\nSelect one of the installed tool chains that you want to update:\n " \ ! _check_toolchain "$OPTION2" && _toolchain_repair "$(_backup "$OPTION1" "$OPTION2")" || echo -e "\n\n$r_l $txt_error:$y_l $OPTION2$w_l Toolchain already exists!""$rs_" && _nl && exit;
"${COUNT+10}" 0 0 "${MENU_OPTIONS[@]}"); bye;
ret="$?" else
_nl && exit;
tc=$(echo "$out" | awk '{printf $1}'); fi;
case $ret in elif [ "$CMDTC" == "" ];then
0) #Update toolchain unset menu_close;
tc_menu="1";; while [ ! $menu_close ]
1) #Start crosstool do
tc_menu="2"; #TOOLCHAIN MENU
_create_tc; _fill_tc_array;
tcupdate "" "0" "$tc";; unset MENU_OPTIONS;COUNT=0
2) #Exit if [ "$systype" == "ok" ];then
bye;; if [ "$tcempty" == "0" ];then
3) #Copy toolchain for i in "${INST_TCLIST[@]}";do
[ ! "$tc" == "" ] && _toolchain_repair "$(_copy "$tc")" || echo -e "$r_l $txt_error:$y_l $tc$w_l Toolchain $txt_n_installed""$rs_"; if [ ! "$i" == "native" ];then
sleep 2; source "$tccfgdir/$i";
tcupdate "" "0" "$tc";; [ -f "$tcdir/$i/build.log.bz2" ] && tcdate=" ct-ng."$(date -r "$tcdir/$i/build.log.bz2" "+%Y-%m-%d %H:%M:%S") || tcdate="";
esac; MENU_OPTIONS+=("$_toolchainname" "$_description\Z2$tcdate\Zn" "toolchain folder:$tcdir/$i | config file:$tccfgdir/$i");
counter;
fi;
done;
fi;
[ $COUNT -eq 0 ] && MENU_OPTIONS+=("" "no toolchains found" "no toolchains found") && counter;
fi;
clear;clear;
out=$("$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--item-help" "--help-tags" "--default-item" "$tc" "--ok-label" "Update" "--cancel-label" "Create" "--help-button" "--help-label" "$([ "$FLAG" == "1" ] && echo "Exit" || echo "Back")" "--extra-button" "--extra-label" "Backup" "--title" "-[ Toolchain Menu ]-" \
--menu "\nSelect one of the installed tool chains that you want to update:\n " \
"${COUNT+10}" 0 0 "${MENU_OPTIONS[@]}");
ret="$?";
tc=$(echo "$out" | awk '{printf $1}');
case $ret in
0) #Update toolchain
menu_close="1";;
1) #Start crosstool-NG
_create_tc;;
2) #Exit
[ "$FLAG" == "1" ] && bye || return;;
3) #Duplicate toolchain
_check_toolchain $tc && _backup "$tc" "$tc" >/dev/null || [ "$CMDTC" == "" ] && sleep 2 && tcupdate "$CMDTC" "$OPTION1" "$OPTION2" "$FLAG" || _nl && exit;
sleep 2;;
esac;
done;
else else
tc="$1" tc="$CMDTC";
[ "$2" == "" ] && tc_menu="0" || tc_menu="$2";
fi; fi;
#toolchain native not supported #toolchain native not supported and exists check
if [ "$tc" == "native" ];then if ! _check_toolchain $tc;then
echo -e "$r_l $txt_error:$y_l $tc$w_l Toolchain library update not supported!""$rs_"; [ "$CMDTC" == "" ] && sleep 2 && tcupdate "$CMDTC" "$OPTION1" "$OPTION2" "$FLAG" || _nl && exit;
_nl;
exit;
fi; fi;
#toolchain exists check #load toolchain config
[ -f "$tccfgdir/$tc" ] && source "$tccfgdir/$tc"; [ -f "$tccfgdir/$tc" ] && source "$tccfgdir/$tc";
if [ -d "$tcdir/$tc/bin" ];then cd "$tcdir/$tc/bin";
cd "$tcdir/$tc/bin";
else
echo -e "$r_l $txt_error:$y_l $tc$w_l Toolchain $txt_n_installed""$rs_";
[ "$1" == "" ] && sleep 2 && tcupdate "" "0" "$tc";
_nl;
exit;
fi;
#autodetect toolchain's sysroot, prefix, include, pkgconfig folder #autodetect toolchain's sysroot, prefix, include, pkgconfig folder
compilername="$_compiler""gcc";compilername=$(realpath -s $compilername); compilername="$_compiler""gcc";compilername=$(realpath -s $compilername);
@ -121,86 +133,104 @@ tcupdate(){
prefixdir="$PWD" prefixdir="$PWD"
pkg=$(find * | grep -m1 "/pkgconfig") && pkgdir="$prefixdir/$pkg" || pkgdir="$prefixdir"; pkg=$(find * | grep -m1 "/pkgconfig") && pkgdir="$prefixdir/$pkg" || pkgdir="$prefixdir";
#build menu items from config file backxit=$menu_close;
unset MENU_OPTIONS;COUNT=0;unset libs; unset menu_close;
for i in "${LIBS[@]}" while [ ! $menu_close ]
do do
[ "${!i}" == "0" ] && continue; cd "$prefixdir"
libkey=$i; #LIBRARY UPDATE MENU
libname="$i"_name;libname=${!libname}; unset MENU_OPTIONS;COUNT=0;unset libs;
libdesc="$i"_desc;libdesc=${!libdesc}; for i in "${LIBS[@]}"
libversion="$i"_version;libversion=${!libversion}; do
libcheck="$i"_check;libcheck=${!libcheck}; [ "${!i}" == "0" ] && continue;
libversioncheck=$(echo "$libcheck" | awk '{printf $2}') libkey=$i;
libcheck=$(echo "$libcheck" | awk '{printf $1}') libname="$i"_name;libname=${!libname};
liburl="$i"_url;liburl=${!liburl}; libdesc="$i"_desc;libdesc=${!libdesc};
libversioncurrent=$(_get_version "$pkgdir/$libcheck" "$libversioncheck"); libversion="$i"_version;libversion=${!libversion};
libversioncompare=$(_compare_version $libversion $(echo $libversioncurrent | sed -e 's/^$/0.0.0/g')); libcheck="$i"_check;libcheck=${!libcheck};
libtasks="$i"_tasks[@];libtasks=("${!libtasks}"); libversioncheck=$(echo "$libcheck" | awk '{printf $2}')
libexports="$i"_exports[@];libexports=("${!libexports}"); libcheck=$(echo "$libcheck" | awk '{printf $1}')
libconfigure="$i"_configure[@];libconfigure=("${!libconfigure}"); liburl="$i"_url;liburl=${!liburl};
libmake="$i"_make[@];libmake=("${!libmake}"); libversioncurrent=$(_get_version "$pkgdir/$libcheck" "$libversioncheck");
libversioncompare=$(_compare_version $libversion $(echo $libversioncurrent | sed -e 's/^$/0.0.0/g'));
libtasks="$i"_tasks[@];libtasks=("${!libtasks}");
libexports="$i"_exports[@];libexports=("${!libexports}");
libconfigure="$i"_configure[@];libconfigure=("${!libconfigure}");
libmake="$i"_make[@];libmake=("${!libmake}");
MENU_OPTIONS+=("$i" "$libname $libversion $([ $libversioncurrent ] && echo $libversioncompare) $(echo $libversioncurrent | sed -e 's/^$/ ---/g')" "$([ $libversioncurrent ] && echo "on" || echo "off")" "$([ $libname ] && echo "$libname $libversion: $liburl")");counter; MENU_OPTIONS+=("$i" "$libname $libversion $([ $libversioncurrent ] && echo $libversioncompare) $(echo $libversioncurrent | sed -e 's/^$/ ---/g')" "$([ $libversioncurrent ] && echo "on" || echo "off")" "$([ $libname ] && echo "$libname $libversion: $liburl")");counter;
# 0 key 1 desc 2 version 3 checkversion 4 checkfile 5 current version 6 url 7 tasks array # 0 key 1 desc 2 version 3 checkversion 4 checkfile 5 current version 6 url 7 tasks array
lib=("$libkey" "$libname" "$libversion" "$libversioncheck" "$libcheck" "$libversioncurrent" "$liburl" "(${libtasks[*]@Q})"); lib=("$libkey" "$libname" "$libversion" "$libversioncheck" "$libcheck" "$libversioncurrent" "$liburl" "(${libtasks[*]@Q})");
libs+=("(${lib[*]@Q})"); libs+=("(${lib[*]@Q})");
done; done;
[ $COUNT -eq 0 ] && MENU_OPTIONS+=("" "no libraries found" "no libraries found") && counter; [ $COUNT -eq 0 ] && MENU_OPTIONS+=("" "no libraries found" "no libraries found") && counter;
opts=$("$gui" "--item-help" "--help-tags" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--default-item" "$3" "--ok-label" "Start" "--help-button" "--help-label" "Info" "--cancel-label" "$([ "$tc_menu" == "1" ] && echo "Back" || echo "Exit")" "--title" "-[ Library Update Menu - \Z2$tc\Zn ]-" "$cl_"\ if [ ${#OPTION1} -gt 0 ];then #Force build library call
"\nSelect all libraries to update in toolchain's SYSROOT folder:\n$prefixdir\n\n library version NEW CURRENT" \ opts=$(echo "$OPTION1" | tr ',' "\n");
"${COUNT+12}" 70 0 "${MENU_OPTIONS[@]}"); ret="0";
else
#SSL select check clear;clear;
[ $(echo $opts | tr ' ' '\n' | grep -c "SSL_") -gt 1 ] && echo -e $r_l"\n\nPlease select only one SSL version!"$re_ && sleep 3 && tcupdate $tc; opts=$("$gui" "--item-help" "--help-tags" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--default-item" "$lkey" "--ok-label" "Start" "--help-button" "--help-label" "Info" "--cancel-label" "$([ "$backxit" == "1" ] && echo "Back" || echo "Exit")" "--title" "-[ Library Update Menu - \Z2$tc\Zn ]-" "$cl_"\
"\nSelect all libraries to update in toolchain's SYSROOT folder:\n$prefixdir\n\n library version NEW CURRENT" \
#HELP section "${COUNT+12}" 70 0 "${MENU_OPTIONS[@]}");
first=$(echo "$opts" | awk '{printf $1}'); ret="$?"
libkey=$(echo "$opts" | awk '{printf $2}';); fi;
if [ "$first" == "HELP" ];then #SSL select check
sp=$(printf '%*s' 90 | tr ' ' '='); [ $(echo $opts | tr ' ' '\n' | grep -c "SSL_") -gt 1 ] && echo -e $r_l"\n\nPlease select only one SSL version!"$re_ && sleep 3 && [ ${#OPTION1} -gt 0 ] && menu_close=1 && continue;
txt=$(cat "$configname" | grep ""$libkey"=\|"$libkey"_");
bcd=$(cat "$configname" | grep ""$libkey"_tasks");
txt=$(echo -e "Toolchain: $tcdir/$tc\nCompiler: $compilername\nSysroot: $sr\nPrefix: $prefixdir\nInclude: $incdir\n$sp\n\nLibrary configuration:\n$txt\n\nBuild command:\n$(_replace_tokens "$(_tidy_tasks "$bcd" "$libkey")")");
tempfile=$(mktemp) && echo -e "$txt" > "$tempfile";
"$gui" "$st_" "$nc_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--textbox" "$tempfile" 30 80;
rm "$tempfile" 2>/dev/null;
tcupdate $tc $tc_menu $libkey;
fi;
#BUILD section case $ret in
ts=$(date +%F)_$(date +%T); 0) #Start - Build library
tmpdir="/tmp/lib_source/$ts"; ts=$(date +%F)_$(date +%T);
icount=$(echo $opts | wc -w);i=0; tmpdir="/tmp/lib_source/$ts";
for o in $opts;do icount=$(echo $opts | wc -w);i=0;
unset buildtasks; for o in $opts;do
for l in "${libs[@]}";do unset buildtasks;
declare -a lib="${l[*]}"; #populate libs array element for l in "${libs[@]}";do
[ ! "$o" == "${lib[0]}" ] && continue || ((i++)); declare -a lib="${l[*]}"; #populate libs array element
logfile="$ldir/"$ts"_update_toolchain_"$_toolchainname"_"${lib[1]}"_"${lib[2]}".log" [ ! "$o" == "${lib[0]}" ] && continue || ((i++));
logfile="$ldir/"$ts"_update_toolchain_"$_toolchainname"_"${lib[1]}"_"${lib[2]}".log"
#generate build command list #generate build command list
declare -a libtasks="${lib[7]}"; #populate tasks array element declare -a libtasks="${lib[7]}"; #populate tasks array element
for task in "${libtasks[@]}";do for task in "${libtasks[@]}";do
task=$(_replace_tokens "$task"); #replace tokens task=$(_replace_tokens "$task"); #replace tokens
buildtasks+=("$task"); buildtasks+=("$task");
done done
_build "($i/$icount) $tc: library ${lib[1]} ${lib[2]}" $(_extract $(_dl "${lib[6]}" "${lib[1]} ${lib[2]}") "$tmpdir") "$logfile" "${buildtasks[@]}"; _build "($i/$icount) $tc: library ${lib[1]} ${lib[2]}" $(_extract $(_dl "${lib[6]}" "${lib[1]} ${lib[2]}") "$tmpdir" 2>/dev/null) "$logfile" "${buildtasks[@]}";
done; done;
[ "${#buildtasks[@]}" == "0" ] && echo -e "$r_l $txt_error:$y_l $o$w_l Library not found in config file""$rs_";
done;
[ -d "$tmpdir" ] && rm -r "$tmpdir";;
1) #Exit/Back
menu_close="1";;
2) #Info
first=$(echo "$opts" | awk '{printf $1}');
lkey=$(echo "$opts" | awk '{printf $2}';);
if [ "$first" == "HELP" ];then
sp=$(printf '%*s' 90 | tr ' ' '=');
txt=$(cat "$configname" | grep ""$lkey"=\|"$lkey"_");
bcd=$(cat "$configname" | grep ""$lkey"_tasks");
txt=$(echo -e "Toolchain: $tcdir/$tc\nCompiler: $compilername\nSysroot: $sr\nPrefix: $prefixdir\nInclude: $incdir\n$sp\n\nLibrary configuration:\n$txt\n\nBuild command:\n$(_replace_tokens "$(_tidy_tasks "$bcd" "$lkey")")");
tempfile=$(mktemp) && echo -e "$txt" > "$tempfile";
"$gui" "$st_" "$nc_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--ok-label" "Back" "--textbox" "$tempfile" 30 80;
rm "$tempfile" 2>/dev/null;
fi;;
esac;
#Exit loop if build library is forced
[ ${#OPTION1} -gt 0 ] && menu_close=1;
done; done;
[ -d "$tmpdir" ] && rm -r "$tmpdir";
#Reopen update menu #Reopen previous menu
[ ${#OPTION1} -gt 0 ] && exit;
if [ ${#opts} -gt 0 ];then if [ ${#opts} -gt 0 ];then
tcupdate $tc $tc_menu $libkey; tcupdate "$tc" "$OPTION1" "$OPTION2" "$backxit";
else else
[ "$tc_menu" == "1" ] && tcupdate "" "0" "$tc"; [ "$backxit" == "1" ] && tcupdate "" "$OPTION1" "$OPTION2" "$FLAG" || bye;
fi; fi;
bye;
}; };
_create_tc(){ _create_tc(){
_sz; # Prepare DIALOG settings _sz; # Prepare DIALOG settings
@ -208,155 +238,175 @@ _create_tc(){
ctsrcdir="$ctdir/source"; ctsrcdir="$ctdir/source";
cttpldir="$ctdir/templates"; cttpldir="$ctdir/templates";
tplempty=0; #ct-ng must not be run as root unless you forcing it by config
[ ! -d "$cttpldir" ] && mkdir --parents "$cttpldir"; ! _check_root && START_BUILD=1 || [ "$CTNG_BUILD_AS_ROOT" == "1" ] && START_BUILD=1 || START_BUILD=0;
cd "$cttpldir";
if [ "$(ls -A "$cttpldir")" ];then
TPL_LIST=(*);
else
tplempty=1;
fi;
unset MENU_OPTIONS;COUNT=0;
if [ "$tplempty" == "0" ];then
for t in "${TPL_LIST[@]}";do
desc=$(sed -n -e '/#toolchain template/ s/.*\: *//p' $t);
[ ! "$desc" ] && desc="no description available";
[ -d "$tcdir/$t" ] && [ -f "$tccfgdir/$t" ] && color="\Z1" || color="";
MENU_OPTIONS+=("$t" "$color$desc\Zn" "off" "template filename:$cttpldir/$t");counter;
counter;
done;
fi;
[ $COUNT -eq 0 ] && MENU_OPTIONS+=("" "no templates found" "no templates found") && counter;
opts=$("$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--item-help" "--help-tags" "--default-item" "$3" "--ok-label" "Start" "--cancel-label" "Setup" "--help-button" "--help-label" "$([ $tc_menu ] && echo "Back" || echo "Exit")" "--title" "-[ Cross Toolchain Template Menu ]-" "$cl_"\ local menu_close;
"\nSelect on of the templates to create the cross toolchain you want:\n\n\Z1NOTE: If you create a cross toolchain from a template with a red colored description, an existing one with the same name will be replaced without asking!\Zn" \ while [ ! $menu_close ]
"${COUNT+11}" 0 0 "${MENU_OPTIONS[@]}"); do
ret="$?" if [ ${#2} -gt 0 ];then #Force setup call
ret="1";
elif [ ${#1} -gt 0 ];then #Force build toolchain call
opts="$1";
ret="0";
else #Show Template Menu
tplempty=0;
[ ! -d "$cttpldir" ] && mkdir --parents "$cttpldir";
cd "$cttpldir";
case $ret in if [ "$(ls -A "$cttpldir")" ];then
0) #Start - Build cross toolchain TPL_LIST=(*);
if [ -f "$ctsrcdir/ct-ng" ]; then else
icount=$(echo $opts | wc -w);i=0; tplempty=1;
fi;
for tpl in $opts;do #CROSS TOOLCHAIN TEMPLATE MENU
if [ -f "$cttpldir/$tpl" ]; then unset MENU_OPTIONS;COUNT=0;
if [ "$tplempty" == "0" ];then
logfile="$ldir/$(date +%F)_$(date +%T)_update_toolchain_crosstoolchain_"$tpl".log"; ((i++)); for t in "${TPL_LIST[@]}";do
desc=$(sed -n -e '/#toolchain template/ s/.*\: *//p' $t);
clear; [ ! "$desc" ] && desc="no description available";
sp=$(printf '%*s' 80 | tr ' ' '=') [ -d "$tcdir/$t" ] && [ -f "$tccfgdir/$t" ] && color="\Z1" || color="";
echo -e "$sp\nbuild ($i/$icount): command list for cross toolchain $tpl:\n$sp" | tee -a "$logfile"; MENU_OPTIONS+=("$t" "$color$desc\Zn" "off" "template filename:$cttpldir/$t");counter;
counter;
#copy template and patching them done;
echo "rm \"$ctsrcdir/.config*\" 2>/dev/null;cp --no-preserve=mode,ownership -f \"$cttpldir/$tpl\" \"$ctsrcdir/.config\";" | tee -a "$logfile"; fi;
rm "$ctsrcdir/.config*" 2>/dev/null;cp --no-preserve=mode,ownership -f "$cttpldir/$tpl" "$ctsrcdir/.config";
[ $COUNT -eq 0 ] && MENU_OPTIONS+=("" "no templates found" "no templates found") && counter;
clear;clear;
opts=$("$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--item-help" "--help-tags" "--default-item" "$tpl" "--ok-label" "Start" "--cancel-label" "Setup" "--help-button" "--help-label" "$([ "$3" == "1" ] && echo "Exit" || echo "Back")" "--title" "-[ Cross Toolchain Template Menu ]-" "$cl_"\
"\nSelect on of the templates to create the cross toolchain you want:\n\n\Z1NOTE: If you create a cross toolchain from a template with a red colored description, an existing one with the same name will be replaced without asking!\Zn" \
"${COUNT+11}" 0 0 "${MENU_OPTIONS[@]}");
ret="$?";
fi;
case $ret in
0) #Start - Build cross toolchain
if [ -f "$ctsrcdir/ct-ng" ]; then
icount=$(echo $opts | wc -w);i=0;
for tpl in $opts;do
if [ -f "$cttpldir/$tpl" ]; then
logfile="$ldir/$(date +%F)_$(date +%T)_update_toolchain_crosstoolchain_"$tpl".log"; ((i++));
#CT_LOCAL_TARBALLS_DIR aka cache folder for downloads clear;
echo "sed -i \"s#.*CT_LOCAL_TARBALLS_DIR=.*#CT_LOCAL_TARBALLS_DIR=\"$dldir\"#g\" \"$ctsrcdir/.config\";" | tee -a "$logfile"; sp=$(printf '%*s' 80 | tr ' ' '=')
sed -i "s#.*CT_LOCAL_TARBALLS_DIR=.*#CT_LOCAL_TARBALLS_DIR=\"$dldir\"#g" "$ctsrcdir/.config"; echo -e "$sp\nbuild ($i/$icount): command list for cross toolchain $tpl:\n$sp" | tee -a "$logfile";
#CT_PREFIX_DIR aka folder that contains the final toolchain
echo "sed -i \"s#.*CT_PREFIX_DIR=.*#CT_PREFIX_DIR=\"$tcdir/$tpl\"#g\" \"$ctsrcdir/.config\";" | tee -a "$logfile"; #copy template and patching them
sed -i "s#.*CT_PREFIX_DIR=.*#CT_PREFIX_DIR=\"$tcdir/$tpl\"#g" "$ctsrcdir/.config"; echo "rm \"$ctsrcdir/.config*\" 2>/dev/null;cp --no-preserve=mode,ownership -f \"$cttpldir/$tpl\" \"$ctsrcdir/.config\";" | tee -a "$logfile";
#CT_ALLOW_BUILD_AS_ROOT aka force build as root rm "$ctsrcdir/.config*" 2>/dev/null;cp --no-preserve=mode,ownership -f "$cttpldir/$tpl" "$ctsrcdir/.config";
_check_root && [ "$CTNG_BUILD_AS_ROOT" == "1" ] && echo "echo -e \"\nCT_EXPERIMENTAL=y\nCT_ALLOW_BUILD_AS_ROOT=y\nCT_ALLOW_BUILD_AS_ROOT_SURE=y\" >>\"$ctsrcdir/.config\";" | tee -a "$logfile";
_check_root && [ "$CTNG_BUILD_AS_ROOT" == "1" ] && echo -e "\nCT_EXPERIMENTAL=y\nCT_ALLOW_BUILD_AS_ROOT=y\nCT_ALLOW_BUILD_AS_ROOT_SURE=y" >>"$ctsrcdir/.config";
#run build #CT_LOCAL_TARBALLS_DIR aka cache folder for downloads
bcl=$(printf '%s\n' "${CTNG_BUILD_tasks[@]}"); echo "sed -i \"s#.*CT_LOCAL_TARBALLS_DIR=.*#CT_LOCAL_TARBALLS_DIR=\"$dldir\"#g\" \"$ctsrcdir/.config\";" | tee -a "$logfile";
echo -e "cd \"$ctsrcdir\";\n$(_replace_tokens "$bcl")\n$sp" | tee -a "$logfile"; sed -i "s#.*CT_LOCAL_TARBALLS_DIR=.*#CT_LOCAL_TARBALLS_DIR=\"$dldir\"#g" "$ctsrcdir/.config";
sleep 2; #CT_PREFIX_DIR aka folder that contains the final toolchain
echo "sed -i \"s#.*CT_PREFIX_DIR=.*#CT_PREFIX_DIR=\"$tcdir/$tpl\"#g\" \"$ctsrcdir/.config\";" | tee -a "$logfile";
cd "$ctsrcdir"; sed -i "s#.*CT_PREFIX_DIR=.*#CT_PREFIX_DIR=\"$tcdir/$tpl\"#g" "$ctsrcdir/.config";
#generate build command list #CT_ALLOW_BUILD_AS_ROOT aka force build as root
unset buildtasks; _check_root && [ "$CTNG_BUILD_AS_ROOT" == "1" ] && echo "echo -e \"\nCT_EXPERIMENTAL=y\nCT_ALLOW_BUILD_AS_ROOT=y\nCT_ALLOW_BUILD_AS_ROOT_SURE=y\" >>\"$ctsrcdir/.config\";" | tee -a "$logfile";
for task in "${CTNG_BUILD_tasks[@]}";do _check_root && [ "$CTNG_BUILD_AS_ROOT" == "1" ] && echo -e "\nCT_EXPERIMENTAL=y\nCT_ALLOW_BUILD_AS_ROOT=y\nCT_ALLOW_BUILD_AS_ROOT_SURE=y" >>"$ctsrcdir/.config";
task=$(_replace_tokens "$task"); #replace tokens
buildtasks+=("$task");
done;
( eval "${buildtasks[@]}" ) 2>&1;
err=$(grep '\[ERROR\]' "$ctsrcdir/build.log" | wc -l)
#save build.log in logs #run build
cat "$ctsrcdir/build.log" >>"$logfile"; bcl=$(printf '%s\n' "${CTNG_BUILD_tasks[@]}");
echo -e "cd \"$ctsrcdir\";\n$(_replace_tokens "$bcl")\n$sp" | tee -a "$logfile";
if [ ! $err -gt 0 ]; then sleep 2;
#get target from build.log
target=$(sed -n -e '/target = / s/.*\= *//p' "$ctsrcdir/build.log");
#compress toolchain
_compress "$dldir/Toolchain-$tpl.tar.xz" "$tcdir/$tpl" | "$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--title" " -[ Compress cross toolchain $tpl... ]- " "$pb_" "$_lines" "$_cols";
#create toolchain.cfg if [ $START_BUILD -eq 1 ]; then
desc=$(sed -n -e '/#toolchain template/ s/.*\: *//p' "$cttpldir/$tpl"); cd "$ctsrcdir";
_create_toolchaincfg "$tcdir/$tpl" "$tpl" "$target" "" "" "$desc" "" "$dldir/Toolchain-$tpl.tar.xz"; #generate build command list
unset buildtasks;
for task in "${CTNG_BUILD_tasks[@]}";do
task=$(_replace_tokens "$task"); #replace tokens
buildtasks+=("$task");
done;
( eval "${buildtasks[@]}" ) 2>&1;
err=$(grep '\[ERROR\]' "$ctsrcdir/build.log" | wc -l)
#save build.log in logs
cat "$ctsrcdir/build.log" >>"$logfile";
if [ ! $err -gt 0 ]; then
#get target from build.log
target=$(sed -n -e '/target = / s/.*\= *//p' "$ctsrcdir/build.log");
#compress toolchain
_compress "$dldir/Toolchain-$tpl.tar.xz" "$tcdir/$tpl" | "$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--title" " -[ Compress cross toolchain $tpl... ]- " "$pb_" "$_lines" "$_cols";
#create toolchain.cfg
desc=$(sed -n -e '/#toolchain template/ s/.*\: *//p' "$cttpldir/$tpl");
_create_toolchaincfg "$tcdir/$tpl" "$tpl" "$target" "" "" "$desc" "" "$dldir/Toolchain-$tpl.tar.xz";
else
_paktc_timer 10;
fi;
else
echo -e "$r_l""\nERROR -> The execution of crosstool-NG was aborted\n because it must not run as root!\n""$re_" | tee -a "$logfile";
_paktc_timer 10;
fi;
else else
_paktc_timer 10; echo -e "$r_l $txt_error:$y_l $tpl$w_l Template $txt_n_installed""$rs_";
sleep 2;
fi; fi;
else done;
[ "$tpl" == "" ] && echo -e "$r_l $txt_error:$y_l $tc$w_l Template $txt_n_installed""$rs_"; else
sleep 2; echo -e "$r_l""\nCHECK -> crosstool-NG is not setup correctly. Please run 'Setup' from menu!\n""$re_";
fi; _paktc_timer 10;
done; fi;;
else 1) #Setup - Setup crosstool-NG
echo -e "$r_l""\nCHECK -> crosstool-NG is not setup correctly. Please run 'Setup' from menu!\n""$re_"; logfile="$ldir/$(date +%F)_$(date +%T)_update_toolchain_crosstool-NG_setup.log"
_paktc_timer 10; (
fi; bcl=$(printf '%s\n' "${CTNG_SETUP_tasks[@]}");
_create_tc;; sp=$(printf '%*s' 80 | tr ' ' '=')
1) #Setup - Setup crosstool-NG echo -e "$sp\nbuild command list for crosstool-NG:\n$sp\ncd "$ctsrcdir"\n$(_replace_tokens "$bcl")\n$sp";
logfile="$ldir/$(date +%F)_$(date +%T)_update_toolchain_crosstool-NG_setup.log" sleep 2;
(
bcl=$(printf '%s\n' "${CTNG_SETUP_tasks[@]}"); if [ $START_BUILD -eq 1 ]; then
sp=$(printf '%*s' 80 | tr ' ' '=') # setup crosstool wc
echo -e "$sp\nbuild command list for crosstool-NG:\n$sp\ncd "$ctsrcdir"\n$(_replace_tokens "$bcl")\n$sp"; echo "Cleanup source directory "$ctsrcdir/"..."
sleep 2; rm -rf "$ctsrcdir" 2>/dev/null;
mkdir --parents "$ctsrcdir";
#ct-ng must not be run as root unless you know what you are doing by forcing it cd "$ctsrcdir";
! _check_root && RUN_SETUP=1 || RUN_SETUP=0; #generate setup command list
[ "$CTNG_BUILD_AS_ROOT" == "1" ] && RUN_SETUP=1; for task in "${CTNG_SETUP_tasks[@]}";do
if [ $RUN_SETUP -eq 1 ]; then task=$(_replace_tokens "$task"); #replace tokens
# setup crosstool wc setuptasks+=("$task");
echo "Cleanup source directory "$ctsrcdir/"..." done
rm -rf "$ctsrcdir" 2>/dev/null; ( eval "${setuptasks[@]}" ) 2>&1;
mkdir --parents "$ctsrcdir"; else
cd "$ctsrcdir"; echo -e "\nERROR -> The execution of crosstool-NG was aborted\n because it must not run as root!\n";
#generate setup command list fi;
for task in "${CTNG_SETUP_tasks[@]}";do ) | tee "$logfile" | "$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--title" " -[ Setup crosstool-NG... ]- " "$pb_" "$_lines" "$_cols";
task=$(_replace_tokens "$task"); #replace tokens _paktc_timer 10;;
setuptasks+=("$task"); 2) #Exit
done menu_close="1";
( eval "${setuptasks[@]}" ) 2>&1; return;;
else esac;
echo -e "\nERROR -> The execution of crosstool-NG was aborted\n because it must not run as root!\n";
fi; #Exit loop if setup or build toolchain are forced
) | tee "$logfile" | "$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--title" " -[ Setup crosstool-NG... ]- " "$pb_" "$_lines" "$_cols"; [ ${#2} -gt 0 ] || [ ${#1} -gt 0 ] && menu_close=1;
_paktc_timer 10;
_create_tc;; done;
2) #Exit
return;;
esac;
}; };
_copy(){ _backup(){
_sz; # Prepare DIALOG settings _sz; # Prepare DIALOG settings
nr=$(( $RANDOM % 100 )); src=$1;
newtc="$1-$nr"; dest=$2;
newtccfgfile="$tccfgdir/$newtc"; newtccfgfile="$tccfgdir/$dest";
xzfile="$dldir/Toolchain-$newtc.tar.xz"; xzfile="$dldir/Toolchain-$dest.tar.xz";
( (
#compress toolchain #compress toolchain
_compress "$xzfile" "$tcdir/$1" _compress "$xzfile" "$tcdir/$src"
#create toolchain.cfg #create toolchain.cfg
source "$tccfgdir/$1" && target="${_compiler%?}" && sysroot="$_sysroot" && lsd="$_libsearchdir" && desc="$_description" && info="$_tc_info"; source "$tccfgdir/$src" && target="${_compiler%?}" && sysroot="$_sysroot" && lsd="$_libsearchdir" && desc="$_description" && info="$_tc_info";
_create_toolchaincfg "$tcdir/$1" "$newtc" "$target" "$sysroot" "$lsd" "$desc" "$info" "$xzfile"; _create_toolchaincfg "$tcdir/$src" "$dest" "$target" "$sysroot" "$lsd" "$desc" "$info" "$xzfile";
) | "$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--title" " -[ Copy $1 to $newtc ... ]- " "$pb_" "$_lines" "$_cols"; ) | "$gui" "$st_" "$bt_" "$title_ - \Z0$pdesc\Zn" "--colors" "--title" " -[ Backup $src to $(basename "$xzfile")... ]- " "$pb_" "$_lines" "$_cols";
[ -f "$newtccfgfile" ] && echo "$newtc"; [ -f "$newtccfgfile" ] && echo "$dest";
}; };
_build(){ _build(){
_sz; # Prepare DIALOG settings _sz; # Prepare DIALOG settings
local desc="$1"; # Save 1. argument in a variable local desc="$1"; # Save 1. argument in a variable
local libsrcdir="$2"; # Save 2. argument in a variable local libsrcdir="$2"; # Save 2. argument in a variable
@ -506,8 +556,23 @@ else
fi; fi;
echo -e "\033[2K\r"; #remove characters from console echo -e "\033[2K\r"; #remove characters from console
}; };
_check_toolchain(){
if [ "$1" == "" ];then #toolchain parameter empty
echo -e "\n\n$r_l $txt_error:$y_l Parameter$w_l Toolchain not set!""$rs_";
return 1;
elif [ "$1" == "native" ];then #toolchain native not supported
echo -e "\n\n$r_l $txt_error:$y_l $1$w_l Toolchain library update not supported!""$rs_";
return 1;
elif [ ! -d "$tcdir/$1/bin" ];then #toolchain not installed
echo -e "\n\n$r_l $txt_error:$y_l $1$w_l Toolchain $txt_n_installed""$rs_";
return 1;
else
return 0;
fi;
};
_check_root(){ _check_root(){
! ((${EUID:-0} || "$(id -u)")); ! ((${EUID:-0} || "$(id -u)"));
}; };
_check_lib(){ _check_lib(){
case "$1" in case "$1" in

1
support/translation/de

@ -57,6 +57,7 @@ txt_help3="Taste [ENTER] zum fortsetzen..."
txt_firstmenu_continue="weiter mit lokalem SVN"; txt_firstmenu_continue="weiter mit lokalem SVN";
txt_firstmenu_chose="anderen SVN Stand (7000+) laden"; txt_firstmenu_chose="anderen SVN Stand (7000+) laden";
txt_firstmenu_cedit="$txt_conf""s Editor starten"; txt_firstmenu_cedit="$txt_conf""s Editor starten";
txt_firstmenu_tcupdate="Toolchain Updater starten";
txt_firstmenu_lang="Systemsprache manuell $txt_sel"; txt_firstmenu_lang="Systemsprache manuell $txt_sel";
txt_firstmenu_exit="simplebuild sofort beenden"; txt_firstmenu_exit="simplebuild sofort beenden";

1
support/translation/en

@ -48,6 +48,7 @@ txt_help3="[ENTER] to continue..."
txt_firstmenu_continue="continue with local SVN"; txt_firstmenu_continue="continue with local SVN";
txt_firstmenu_chose="load a different SVN (7000+)"; txt_firstmenu_chose="load a different SVN (7000+)";
txt_firstmenu_cedit="start configuration editor"; txt_firstmenu_cedit="start configuration editor";
txt_firstmenu_tcupdate="start toolchain updater";
txt_firstmenu_lang="manual system language selection"; txt_firstmenu_lang="manual system language selection";
txt_firstmenu_exit="close simplebuild now"; txt_firstmenu_exit="close simplebuild now";

Loading…
Cancel
Save