App-XWindowManagerUtils
view release on metacpan or search on metacpan
lib/App/XWindowManagerUtils.pm view on Meta::CPAN
my $match = 1;
for my $query (@positive_query) {
if (!$query->(
join("|", grep {defined} ($row->{title}, $row->{kde_activity_guid}, $row->{kde_activity_name}))
)) {
$match = 0; goto L1;
}
}
L1:
unless ($match) {
log_trace "Skipping window id=%s title=<%s>: does not match all positive query in %s", $row->{id}, $row->{title}, $args{query};
next LINE;
}
} # QUERY
} # FILTER
push @rows, $row;
} # for line
unless ($args{detail}) {
@rows = map { $_->{id} } @rows;
}
[200, "OK", \@rows];
}
$SPEC{get_xwm_window_kde_activity} = {
v => 1.1,
summary => "Get the KDE activity GUID(s) of a specific window",
description => <<'MARKDOWN',
A window can be displayed in more than one KDE activities, so this utility can
return a comma-separated list of GUIDs.
MARKDOWN
args => {
id => {
summary => 'Window ID, specified in hex form with 0x prefix, e.g. 0x05a0000e',
schema => ['str*'],
req => 1,
pos => 0,
},
},
deps => {
all => [
{prog => 'wmctrl'},
{prog => 'xprop'},
],
},
};
sub get_xwm_window_kde_activity {
my %args = @_;
my $id = $args{id} or return [400, "Please specify id"];
system({capture_stdout => \my $stdout, capture_stderr => \my $stderr},
"xprop", "-id", $id, "_KDE_NET_WM_ACTIVITIES");
if ($?) {
if ($stderr =~ /BadWindow.*invalid Window parameter/) {
return [404, "No such window ID"];
} else {
return [500, "Can't successfully run xprop"];
}
} else {
# sample output: _KDE_NET_WM_ACTIVITIES(STRING) = "40eabb80-2103-48af-8977-23b6e06fbcc3"
my ($guid) = $stdout =~ /^_KDE_NET_WM_ACTIVITIES.+"([^"]+)"/;
return [200, "OK", $guid];
}
}
1;
# ABSTRACT: Utilities related to X Window Manager
__END__
=pod
=encoding UTF-8
=head1 NAME
App::XWindowManagerUtils - Utilities related to X Window Manager
=head1 VERSION
This document describes version 0.003 of App::XWindowManagerUtils (from Perl distribution App-XWindowManagerUtils), released on 2026-04-06.
=head1 SYNOPSIS
=head1 DESCRIPTION
This distribution includes several utilities related to "X Window Manager":
=over
=item * L<get-xwm-window-kde-activity>
=item * L<list-xwm-windows>
=back
Under the hood, it's currently a wrapper to tools like C<wmctrl>, etc.
C<wmctrl> works on EWMH-compliant X11 window managers. This means mainstream
desktop environments like KWin, Xfwm, Mutter (GNOME). It works partially or
doesn't work with minimalist window managers like dwm, suckless. It partially
works with Wayland where there is an X compatibility layer, e.g. GNOME Wayland,
KDE Plasma Wayland.
=head1 FUNCTIONS
=head2 get_xwm_window_kde_activity
Usage:
get_xwm_window_kde_activity(%args) -> [$status_code, $reason, $payload, \%result_meta]
Get the KDE activity GUID(s) of a specific window.
( run in 1.508 second using v1.01-cache-2.11-cpan-bbb979687b5 )