diff options
author | Martin Wimpress <[email protected]> | 2015-04-21 07:53:34 +0100 |
---|---|---|
committer | Stefano Karapetsas <[email protected]> | 2015-05-06 14:40:32 +0200 |
commit | 37ff9fcae6e45c813d65a7b0c407026b874b3298 (patch) | |
tree | d97f1f92826a20e13dc234d99ea38afc9cab9d9b | |
parent | e771a4d6545937fb5ff1629dc2cca2282ec8a599 (diff) | |
download | mate-terminal-37ff9fcae6e45c813d65a7b0c407026b874b3298.tar.bz2 mate-terminal-37ff9fcae6e45c813d65a7b0c407026b874b3298.tar.xz |
Replace mate-terminal.wrapper with one adapted from gnome-terminal.wrapper that support double quoted commands.
Closes https://github.com/mate-desktop/mate-terminal/pull/88
-rwxr-xr-x | mate-terminal.wrapper | 121 |
1 files changed, 79 insertions, 42 deletions
diff --git a/mate-terminal.wrapper b/mate-terminal.wrapper index 4d528c9..10f44f2 100755 --- a/mate-terminal.wrapper +++ b/mate-terminal.wrapper @@ -1,44 +1,81 @@ -#!/usr/bin/env python +k#! /usr/bin/perl -w -import sys -import os -import subprocess +my $login=0; -newargs = ['mate-terminal'] -oldargs = sys.argv[1:] - -while True: - try: - arg = oldargs.pop(0) - - if arg == '-display': - os.environ['DISPLAY'] = oldargs.pop(0) - elif arg == '-name': - newargs.append('--window-with-profile=' + oldargs.pop(0)) - elif arg == '-n': - sys.stderr.write('Set an icon in your profile') - elif arg == '-T' or arg == '-title': - newargs.append('-t') - newargs.append(oldargs.pop(0)) - elif arg == '-ls' or arg == '+ls': - sys.stderr.write('Login shell not supported. Set in your profile.') - elif arg == '-geometry': - newargs.append('--geometry=' + oldargs.pop(0)) - elif arg == '-fn': - newargs.append('--font=' + oldargs.pop(0)) - elif arg == '-fg': - newargs.append('--foreground=' + oldargs.pop(0)) - elif arg == '-bg': - newargs.append('--background=' + oldargs.pop(0)) - elif arg == '-tn': - newargs.append('--termname=' + oldargs.pop(0)) - elif arg == '-h' or arg == '--help': - newargs.append('--help') - elif arg == '-e': - newargs.append('-x') - newargs += oldargs - break - except IndexError: - break - -subprocess.call(newargs) +while ($opt = shift(@ARGV)) +{ + if ($opt eq '-display') + { + $ENV{'DISPLAY'} = shift(@ARGV); + } + elsif ($opt eq '-name') + { + $arg = shift(@ARGV); + push(@args, "--window-with-profile=$arg"); + } + elsif ($opt eq '-n') + { + # Accept but ignore + print STDERR "$0: to set an icon, please use -name <profile> and set a profile icon\n" + } + elsif ($opt eq '-T' || $opt eq '-title') + { + push(@args, '-t', shift(@ARGV)); + } + elsif ($opt eq '-ls') + { + $login = 1; + } + elsif ($opt eq '+ls') + { + $login = 0; + } + elsif ($opt eq '-geometry') + { + $arg = shift(@ARGV); + push(@args, "--geometry=$arg"); + } + elsif ($opt eq '-fn') + { + $arg = shift(@ARGV); + push(@args, "--font=$arg"); + } + elsif ($opt eq '-fg') + { + $arg = shift(@ARGV); + push(@args, "--foreground=$arg"); + } + elsif ($opt eq '-bg') + { + $arg = shift(@ARGV); + push(@args, "--background=$arg"); + } + elsif ($opt eq '-tn') + { + $arg = shift(@ARGV); + push(@args, "--termname=$arg"); + } + elsif ($opt eq '-e') + { + $arg = shift(@ARGV); + if (@ARGV) + { + push(@args, '-x', $arg, @ARGV); + last; + } + else + { + push(@args, '-e', $arg); + } + last; + } + elsif ($opt eq '-h' || $opt eq '--help') + { + push(@args, '--help'); + } +} +if ($login == 1) +{ + @args = ('--login', @args); +} +exec('mate-terminal',@args); |