You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							181 lines
						
					
					
						
							5.2 KiB
						
					
					
				
			
		
		
	
	
							181 lines
						
					
					
						
							5.2 KiB
						
					
					
				# --- SDE-COPYRIGHT-NOTE-BEGIN --- | 
						|
# This copyright note is auto-generated by ./scripts/Create-CopyPatch. | 
						|
# | 
						|
# Filename: package/.../stone/stone_gui_dialog.sh | 
						|
# Copyright (C) 2007 - 2008 The OpenSDE Project | 
						|
# Copyright (C) 2004 - 2006 The T2 SDE Project | 
						|
# Copyright (C) 1998 - 2003 Clifford Wolf | 
						|
# | 
						|
# More information can be found in the files COPYING and README. | 
						|
# | 
						|
# This program is free software; you can redistribute it and/or modify | 
						|
# it under the terms of the GNU General Public License as published by | 
						|
# the Free Software Foundation; version 2 of the License. A copy of the | 
						|
# GNU General Public License can be found in the file COPYING. | 
						|
# --- SDE-COPYRIGHT-NOTE-END --- | 
						|
# | 
						|
# Filename: gui_dialog.sh | 
						|
# Description: | 
						|
# ============ | 
						|
# This file provides the gui-functions implemented with | 
						|
# the use of dialog, i.e. a curses based menu-frontend. | 
						|
 | 
						|
gui_dialog_lines="$(   stty size | cut -d' ' -f1 )" | 
						|
gui_dialog_columns="$( stty size | cut -d' ' -f2  )" | 
						|
 | 
						|
gui_dialog_s70=$(( gui_dialog_columns - 10 )) | 
						|
gui_dialog_s62=$(( gui_dialog_columns - 18 )) | 
						|
gui_dialog_s15=$(( gui_dialog_lines - 10 )) | 
						|
 | 
						|
gui_dialog() { | 
						|
	dialog --stdout --title 'STONE - Setup Tool ONE - System Configuration' "$@" | 
						|
} | 
						|
 | 
						|
 | 
						|
# [ the following variables act as staticly declared variables in functions (in | 
						|
#   C), i.e. they keep their content even after return of the certain function | 
						|
#   to be used again and again in this function. ] | 
						|
# | 
						|
# Important is to know that an element of `gui_menu_tree_name' corresponds | 
						|
# to an element of `gui_menu_tree_value' by the same number, i.e. | 
						|
#      gui_menu_tree_value[0] contains the value of gui_menu_tree_name[0] | 
						|
# | 
						|
declare -a gui_menu_tree_name | 
						|
declare -a gui_menu_tree_value | 
						|
gui_menu_tree_id=-1 | 
						|
 | 
						|
# Use: gui_menu "ID" "Title" "Text" "Action" [ "Text" "Action" [ .. ] ] | 
						|
# | 
						|
gui_menu() { | 
						|
	# `cmd_ar' acts as a kind of mapper between the choosen category | 
						|
	# and the function's/command's name that is responsible for what | 
						|
	# next is to do. This command/function is finally executed. | 
						|
	local -a cmd_ar | 
						|
 | 
						|
	# Although dialog does folding itself, we're forced | 
						|
	# to do it directly, because we need the number of | 
						|
	# lines to compute the size of a widget. | 
						|
	local id="$1" title="$( echo "$2" | fmt -$gui_dialog_s62 )" | 
						|
	local y_text=$( echo "$title" | wc -l ) y_menu=$(( ($#-2) / 2 )) | 
						|
	local nr=1 x="'" y choosen= ; shift 2 | 
						|
 | 
						|
	[ $(( $y_text + $y_menu )) -gt $gui_dialog_s15 ] && \ | 
						|
				y_menu=$(( gui_dialog_s15 - y_text )) | 
						|
 | 
						|
	if [ $id = main ] ; then local cmd="gui_dialog --cancel-label Exit" | 
						|
	elif [ "$gui_nocancel" = 1 ] ; then cmd="gui_dialog --no-cancel" | 
						|
	else local cmd="gui_dialog --cancel-label Back" ; fi | 
						|
 | 
						|
	# In case of having been in the current menu before (found out by | 
						|
	# checking the current ID for the ones saved in `gui_menu_tree_name[]'), | 
						|
	# make the old item be cursored again. | 
						|
	local default= count | 
						|
	for (( count=$gui_menu_tree_id; $count >= 0; count-- )) | 
						|
	do | 
						|
		if [ "${gui_menu_tree_name[$count]}" = $id ] ; then | 
						|
			default="${gui_menu_tree_value[$count]}" | 
						|
			gui_menu_tree_id=$(( $count - 1 )) | 
						|
			break | 
						|
		fi | 
						|
	done | 
						|
 | 
						|
	cmd="$cmd --default-item \${default:-0}" | 
						|
	cmd="$cmd --menu '${title//$x/$x\\$x$x}'" | 
						|
	cmd="$cmd $(( $y_text + $y_menu +  6 )) $gui_dialog_s70 $y_menu" | 
						|
 | 
						|
	while [ $# -gt 0 ] ; do | 
						|
		y="${2#\*}" | 
						|
		if [ -z "$default" -a "$y" != "$2" ] ; then | 
						|
			default="$nr" | 
						|
		fi | 
						|
		if [ -z "$y" ] ; then | 
						|
			if [ -z "$1" ] ; then | 
						|
				# this line should become a blank one | 
						|
				cmd="$cmd ' ' ' '" | 
						|
			else | 
						|
				# the purpose of this line is only to | 
						|
				# display additional information about | 
						|
				# the item before | 
						|
				cmd="$cmd '-' '${1//$x/$x\\$x$x}'" | 
						|
			fi | 
						|
		else | 
						|
			cmd="$cmd $nr '${1//$x/$x\\$x$x}'" | 
						|
			cmd_ar[$nr]="$y" | 
						|
			((nr++)) | 
						|
		fi | 
						|
 | 
						|
		shift ; shift | 
						|
	done | 
						|
 | 
						|
	# `choosen' gets the choosen item that represents in fact | 
						|
	# the dereferencer for `cmd_ar'. | 
						|
	choosen="$(eval "$cmd")" | 
						|
 | 
						|
	if [ $? -eq 0 ]; then | 
						|
		# if enter is pressed on an ``additional information line'', | 
						|
		# do nothing. | 
						|
		[ "$choosen" = "-" ] && return 0 | 
						|
 | 
						|
		gui_menu_tree_id=$(( $gui_menu_tree_id + 1 )) | 
						|
		gui_menu_tree_name[$gui_menu_tree_id]=$id | 
						|
		gui_menu_tree_value[$gui_menu_tree_id]=$choosen | 
						|
 | 
						|
		eval "${cmd_ar[$choosen]}" | 
						|
		return 0 | 
						|
	else | 
						|
		return 1 | 
						|
	fi | 
						|
} | 
						|
 | 
						|
# Use: gui_input "Text" "Default" "VarName" | 
						|
# | 
						|
gui_input() { | 
						|
	local headlines="$( echo "$1" | fmt -$gui_dialog_s62 )"	\ | 
						|
	      height=$(( $(echo "$headlines" | wc -l) + 7 )) tmp cmd | 
						|
 | 
						|
	if [ "$gui_nocancel" = 1 ] ; then cmd="gui_dialog --no-cancel" | 
						|
	else local cmd="gui_dialog --cancel-label Back" ; fi | 
						|
 | 
						|
	if tmp="$($cmd --inputbox "$headlines" $height $gui_dialog_s70 "$2")"; then | 
						|
		eval "$3='$tmp'" | 
						|
	fi | 
						|
} | 
						|
 | 
						|
# Use: gui_message "Text" | 
						|
# | 
						|
gui_message() { | 
						|
	local headlines="$( echo "$1" | fmt -$gui_dialog_s62 )" | 
						|
	gui_dialog --msgbox "$headlines" \ | 
						|
		$(( $( echo "$headlines" | wc -l ) + 4 )) $gui_dialog_s70 | 
						|
} | 
						|
 | 
						|
# Use: gui_yesno "Text" | 
						|
# | 
						|
gui_yesno() { | 
						|
	local headlines="$( echo "$1" | fmt -$gui_dialog_s62 )" | 
						|
	gui_dialog --yesno "$headlines" \ | 
						|
		$(( $( echo "$headlines" | wc -l ) + 4 )) $gui_dialog_s70 | 
						|
} | 
						|
 | 
						|
 | 
						|
# Use: gui_edit "Text" "File" | 
						|
# | 
						|
gui_edit() { | 
						|
	# find editor | 
						|
	for x in $EDITOR vi nvi emacs xemacs pico ; do | 
						|
		if type -p $x > /dev/null | 
						|
		then xx=$x ; break ; fi | 
						|
	done | 
						|
	if [ "$xx" ] ; then | 
						|
		eval "$xx $2" | 
						|
	else | 
						|
		gui_message "Cannot find any editor. Make sure \$EDITOR is set." | 
						|
	fi | 
						|
} | 
						|
 | 
						|
# Use: gui_cmd "Title" "Command" | 
						|
# (Title isn't used in this GUI type) | 
						|
gui_cmd() { | 
						|
	shift ; eval "$@" | 
						|
	read -p "Press ENTER to continue." | 
						|
}
 | 
						|
 |