71d4dabbd4
For people doing X forwarding, wcons tiling has always been flaky. For confluent, we have a better cue, so give it more time for the sake of X forwarded users
199 lines
6.4 KiB
Perl
Executable File
199 lines
6.4 KiB
Perl
Executable File
#!/usr/bin/env perl
|
|
#A placeholder wcons, a fuller port from 1.3 is needed
|
|
use Getopt::Long qw(:config getopt_compat pass_through);
|
|
use File::Basename;
|
|
BEGIN { $::XCATROOT = $ENV{'XCATROOT'} ? $ENV{'XCATROOT'} : -d '/opt/xcat' ? '/opt/xcat' : '/usr'; }
|
|
use IO::Socket::UNIX;
|
|
use Time::HiRes qw/sleep/;
|
|
use lib "$::XCATROOT/lib/perl";
|
|
use xCAT::Client;
|
|
#use Data::Dumper;
|
|
use strict;
|
|
unless ($ENV{DISPLAY}) {
|
|
print '$DISPLAY not set';
|
|
exit 1;
|
|
}
|
|
my $mydir = dirname($0);
|
|
my $sb;
|
|
my $tilefact;
|
|
my $xrm="-xrm xterm.mainMenu.*.font:fixed -xrm xterm.vtMenu.*.font:fixed -xrm xterm.fontMenu.*.font:fixed -xrm xterm -xrm xterm.vt100.font6:grvga.737";
|
|
my $font = "5x7";
|
|
my $sizegeometry;
|
|
GetOptions(
|
|
#'sb' => \$sb,
|
|
'tile|t:i' => \$tilefact,
|
|
'geometry|g:s' => \$sizegeometry,
|
|
#'font|f=s' => \$font
|
|
);
|
|
my $noderange = $ARGV[$#ARGV];
|
|
my %conserverref = (command => 'nodels', noderange => $noderange, arg => ['nodehm.conserver']);
|
|
my @nodes;
|
|
my %conservers;
|
|
sub getconserver {
|
|
my $rsp = shift;
|
|
foreach (@{$rsp->{node}}) {
|
|
my $node = $_->{name};
|
|
if (ref $node) { $node = $node->[0]; }
|
|
push @nodes,$node;
|
|
if ($_->{data}->[0]->{contents}) {
|
|
$conservers{$node}=$_->{data}->[0]->{contents};
|
|
if (ref $conservers{$node}) { $conservers{$node} = $conservers{$node}->[0] };
|
|
}
|
|
}
|
|
}
|
|
xCAT::Client::submit_request(\%conserverref,\&getconserver);
|
|
|
|
|
|
unless ($ARGV[$#ARGV]) {
|
|
print "Usage: wcons <options> <noderange>\n";
|
|
exit 1;
|
|
}
|
|
pop @ARGV;
|
|
foreach (@nodes) {
|
|
if ($conservers{$_}) {
|
|
next;
|
|
}
|
|
if ($ENV{XCATHOST}) {
|
|
$conservers{$_} = $ENV{XCATHOST};
|
|
$conservers{$_} =~ s/:.*//;
|
|
next;
|
|
}
|
|
}
|
|
|
|
|
|
my $firstnode = shift @nodes;
|
|
unless ($firstnode) {
|
|
exit 1;
|
|
}
|
|
my $currx;
|
|
my $curry;
|
|
my $wmxo;
|
|
my $wmyo;
|
|
my $currx;
|
|
my $screenwidth;
|
|
my $screenheight;
|
|
my $window_width;
|
|
my $window_height;
|
|
my $panel_pad=0;
|
|
my $top_pad;
|
|
if (defined($tilefact)) {
|
|
my $rootinf = `xwininfo -root`;
|
|
foreach (split /\n/,$rootinf) {
|
|
if (/.*Width:\s+([0-9]*).*/) {
|
|
$screenwidth=$1;
|
|
} elsif (/.*Height:\s+([0-9]*).*/) {
|
|
$screenheight=$1;
|
|
}
|
|
}
|
|
$rootinf = `xwininfo -name "Top Panel" 2> /dev/null`;
|
|
foreach (split /\n/,$rootinf) {
|
|
if (/-geometry\s+([0-9]+)x([0-9]+)\+([0-9]+)\+([0-9]+)/) {
|
|
if ($1 > 640 and $2 < 480 and $3 == 0 and $4 == 0) {
|
|
$panel_pad=$2;
|
|
}
|
|
}
|
|
}
|
|
if ($panel_pad == 0) {
|
|
$rootinf = `xwininfo -name "Top Expanded Edge Panel" 2> /dev/null`;
|
|
foreach (split /\n/,$rootinf) {
|
|
if (/-geometry\s+([0-9]+)x([0-9]+)\+([0-9]+)\+([0-9]+)/) {
|
|
if ($1 > 640 and $2 < 480 and $3 == 0 and $4 == 0) {
|
|
$panel_pad=$2;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
$ENV{CONSCONTROLPATH} = "/tmp/wconscontrol.$firstnode.$$";
|
|
system("xterm $xrm -bg black -fg white -title $firstnode -n $firstnode -geometry $sizegeometry+0+0 ".join(" ",@ARGV)." -e /bin/bash -c \"/bin/true ".$ENV{DISPLAY}." $firstnode $firstnode & let SDATE=`date +%s`+5; $mydir/rcons $firstnode ".$conservers{$firstnode}."; if [ \\\$SDATE -gt \\`date +%s\\` ]; then echo Press enter to close; read SDATE; fi \" &");
|
|
$ENV{CONSCONTROLPATH} = "";
|
|
my $remainwait = 2;
|
|
if (-x "/opt/confluent/bin/confetty" or -x "/usr/bin/confetty" or -x "/usr/local/bin/confetty" ) {
|
|
$remainwait = 10;
|
|
}
|
|
while (not -S "/tmp/wconscontrol.$firstnode.$$" and $remainwait > 0) {
|
|
sleep(0.1);
|
|
$remainwait -= 0.1;
|
|
}
|
|
my $xinfo;
|
|
if (-S "/tmp/wconscontrol.$firstnode.$$") { # confluent mode
|
|
my $controlchannel = IO::Socket::UNIX->new(Type=>SOCK_STREAM(), Peer => "/tmp/wconscontrol.$firstnode.$$");
|
|
print $controlchannel "GETWINID\n";
|
|
my $winid = <$controlchannel>;
|
|
$winid = <$controlchannel>;
|
|
$xinfo = `xwininfo -id $winid`;
|
|
} else {
|
|
$xinfo = `xwininfo -name $firstnode`;
|
|
}
|
|
|
|
my @xinfl = split(/\n/,$xinfo);
|
|
my $side_pad;
|
|
my $wmxo;
|
|
my $wmyo;
|
|
foreach (@xinfl) {
|
|
if (/.*Absolute upper-left X:\s*([0-9]*).*/) {
|
|
$side_pad = $1;
|
|
} elsif (/.*Absolute upper-left Y:\s*([0-9]*).*/) {
|
|
$top_pad = $1-$panel_pad;
|
|
} elsif (/.*Width:\s*([0-9]*).*/) {
|
|
$window_width = $1;
|
|
} elsif (/.*Height:\s*([0-9]*).*/) {
|
|
$window_height = $1;
|
|
} elsif (/.*-gemotery \d+x\d+\+(\d+)(\d+)/) {
|
|
$wmxo=$1;
|
|
$wmyo=$2;
|
|
}
|
|
}
|
|
$window_width += $side_pad*2; #add the side border, assuming symmetric left and right borders
|
|
$window_height += $side_pad+$top_pad; #Add the titlebar and bottom border, which is guessed to probably be equal to the sides, doesn't hold true in all cases, i.e. window maker, but it's the currently best approximation
|
|
$screenwidth-=$wmxo; #Subtract a factor that 1.3 did, not sure why precisely
|
|
$screenheight-=$wmyo;
|
|
$currx=$window_width;
|
|
$curry=$panel_pad; #+$top_pad;
|
|
my $maxcol = int($screenwidth/$window_width);
|
|
unless ($tilefact or $tilefact > $maxcol) {
|
|
$tilefact=$maxcol;
|
|
}
|
|
if ($tilefact==1) {
|
|
$curry+=$window_height;
|
|
$currx=0;
|
|
}
|
|
} else {
|
|
my $geo;
|
|
if ($sizegeometry) {
|
|
$geo = "-g $sizegeometry ";
|
|
}
|
|
system("xterm $xrm $geo-bg black -fg white -title $firstnode -n $firstnode ".join(" ",@ARGV)." -e /bin/bash -c \"$mydir/xtcd.pl ".$ENV{DISPLAY}." $firstnode $firstnode & let SDATE=`date +%s`+5; $mydir/rcons $firstnode ".$conservers{$firstnode}."; if [ \\\$SDATE -gt \\`date +%s\\` ]; then echo Press enter to close; read SDATE; fi\" &");
|
|
|
|
}
|
|
my $geometry="";
|
|
foreach (@nodes) {
|
|
if ($tilefact) {
|
|
my $corrected_x=$currx+$wmxo;
|
|
my $corrected_y=$curry+$wmyo;
|
|
$geometry="-geometry $sizegeometry+$corrected_x+$corrected_y";
|
|
$currx+=$window_width;
|
|
if ($currx >= ($tilefact * $window_width)) {
|
|
$currx=0;
|
|
$curry+=$window_height;
|
|
if (($curry+$window_height) > $screenheight) {
|
|
$curry = $panel_pad; #+$top_pad;
|
|
}
|
|
}
|
|
} elsif ($sizegeometry) {
|
|
$geometry = "-geometry $sizegeometry";
|
|
}
|
|
|
|
system("xterm $xrm -bg black -fg white ".join(" ",@ARGV)." -title $_ -n $_ $geometry -e /bin/bash -c \"$mydir/xtcd.pl .".$ENV{DISPLAY}." $_ $_ & let SDATE=`date +%s`+5; $mydir/rcons $_ ".$conservers{$_}."; if [ \\\$SDATE -gt \\`date +%s\\` ]; then echo Press enter to close; read SDATE; fi\" &");
|
|
}
|
|
|
|
|
|
#print Dumper(\@ARGV);
|
|
|
|
#MYDIR=`dirname $0`
|
|
#for n in $NODES
|
|
#do
|
|
# xterm -bg black -fg white ".join(" ",@ARGV)." -T $n -n $n -e $MYDIR/rcons $n &
|
|
#done
|