+ print $menu_text;
+ print "\n[template set] command (?=help) > ";
+
+ $input = <STDIN>;
+ $input =~ s/[\r\n]//g;
+ while ( $input ne "d" ) {
+
+ # list template sets
+ #
+ if ( $input =~ /^\s*l\s*/i ) {
+ $count = 0;
+ while ( $count <= $#templateset_name ) {
+ if ( $count == $templateset_default ) {
+ print " *";
+ } else {
+ print " ";
+ }
+ if ( $count < 10 ) {
+ print " ";
+ }
+ $name = $templateset_name[$count];
+ $num_spaces = 35 - length($name);
+ for ( $i = 0 ; $i < $num_spaces ; $i++ ) {
+ $name = $name . " ";
+ }
+
+ print " $count. $name";
+ print "($templateset_id[$count])\n";
+
+ $count++;
+ }
+
+ # mark default template set
+ #
+ } elsif ( $input =~ /^\s*m\s*[0-9]+/i ) {
+ $old_def = $templateset_default;
+ $templateset_default = $input;
+ $templateset_default =~ s/^\s*m\s*//;
+ if ( ( $templateset_default > $#templateset_name ) || ( $templateset_default < 0 ) ) {
+ print "Cannot set default template set to $templateset_default. That template set does not exist.\n";
+ $templateset_default = $old_def;
+ }
+
+ # add template set
+ #
+ } elsif ( $input =~ /^\s*\+/ ) {
+ print "\nWhat is the name of this template (as shown to your users): ";
+ $name = <STDIN>;
+ $name =~ s/[\r\n]//g;
+ $templateset_name[ $#templateset_name + 1 ] = $name;
+ print "\n\nThe directory name should not contain any path information\n"
+ . "or slashes, and should be the name of the directory that the\n"
+ . "template set is found in within the SquirrelMail templates\n"
+ . "directory.\n\n";
+ print "What directory is this stored in (ex: default_advanced): ";
+ $name = <STDIN>;
+ $name =~ s/[\r\n]//g;
+ $templateset_id[ $#templateset_id + 1 ] = $name;
+
+ # detect template sets
+ #
+ } elsif ( $input =~ /^\s*t\s*/i ) {
+ print "\nStarting detection...\n\n";
+ opendir( DIR, "../templates" );
+ @files = readdir(DIR);
+ $cnt = 0;
+ while ( $cnt <= $#files ) {
+ if ( -d "../templates/" . $files[$cnt] && $files[$cnt] !~ /^\./ && $files[$cnt] ne "CVS" ) {
+ $filename = $files[$cnt];
+ $found = 0;
+ for ( $x = 0 ; $x <= $#templateset_id ; $x++ ) {
+ if ( $templateset_id[$x] eq $filename ) {
+ $found = 1;
+ last;
+ }
+ }
+ if ( $found != 1) {
+ print "** Found template set: $filename\n";
+ print " What is it's name (as shown to your users)? ";
+ $nm = <STDIN>;
+ $nm =~ s/[\n\r]//g;
+ $templateset_id[ $#templateset_id + 1 ] = $filename;
+ $templateset_name[ $#templateset_name + 1 ] = $nm;
+# FIXME: why are these two lines here?
+# $aTemplateSet[ $#templateset_name + 1 ] = $nm;
+# $aTemplateSet[ $#templateset_id + 1 ] = $filename;
+ }
+ }
+ $cnt++;
+ }
+ print "\n";
+ for ( $cnt= 0 ; $cnt <= $#templateset_id ; ) {
+ $filename = $templateset_id[$cnt];
+ if ( !(-d change_to_rel_path('SM_PATH . \'templates/' . $filename)) ) {
+ print " Removing \"$filename\" (template set directory not found)\n";
+ if ( $templateset_default gt $cnt ) { $templateset_default--; }
+ elsif ( $templateset_default eq $cnt ) { $templateset_default = 0; }
+ $offset = 0;
+ @new_templateset_name = ();
+ @new_templateset_id = ();
+ for ( $x = 0 ; $x < $#templateset_id ; $x++ ) {
+ if ( $templateset_id[$x] eq $filename ) {
+ $offset = 1;
+ }
+ if ( $offset == 1 ) {
+ $new_templateset_name[$x] = $templateset_name[ $x + 1 ];
+ $new_templateset_id[$x] = $templateset_id[ $x + 1 ];
+ } else {
+ $new_templateset_name[$x] = $templateset_name[$x];
+ $new_templateset_id[$x] = $templateset_id[$x];
+ }
+ }
+ @templateset_name = @new_templateset_name;
+ @templateset_id = @new_templateset_id;
+ } else { $cnt++; }
+ }
+ print "\nDetection complete!\n\n";
+
+ closedir DIR;
+
+ # remove template set
+ #
+ # undocumented functionality of removing last template set isn't that great
+ #} elsif ( $input =~ /^\s*-\s*[0-9]?/ ) {
+ } elsif ( $input =~ /^\s*-\s*[0-9]+/ ) {
+ if ( $input =~ /[0-9]+\s*$/ ) {
+ $rem_num = $input;
+ $rem_num =~ s/^\s*-\s*//g;
+ $rem_num =~ s/\s*$//;
+ } else {
+ $rem_num = $#templateset_name;
+ }
+ if ( $rem_num == $templateset_default ) {
+ print "You cannot remove the default template set!\n";
+ } else {
+ $count = 0;
+ @new_templateset_name = ();
+ @new_templateset_id = ();
+ while ( $count <= $#templateset_name ) {
+ if ( $count != $rem_num ) {
+ @new_templateset_name = ( @new_templateset_name, $templateset_name[$count] );
+ @new_templateset_id = ( @new_templateset_id, $templateset_id[$count] );
+ }
+ $count++;
+ }
+ @templateset_name = @new_templateset_name;
+ @templateset_id = @new_templateset_id;
+ if ( $templateset_default > $rem_num ) {
+ $templateset_default--;
+ }
+ }