私は現在使用していますロックするロック画面。すべてのキーストロークを傍受してウィンドウマネージャに到達するのを防ぎます(私の場合はフラックスボックス)。これは良いことです。
しかし、画面がロックされている場合でも(画面のロックを解除せずに)、特定のカスタムキーボードショートカットを使用できたらと思います。このショートカットは私が書いたスクリプトを実行します。
私はショートカットをハードコードするためにslockのソースコードを変更することを検討しました。しかし、slockがsetuidとして実行されるので、これは完全にマイナーではありません。用意された解決策があったらと思います。
(解決策には画面ロックの切り替えを含めることができます。私は画面ロックをslockに設定していません。)
答え1
残念ながら、このようなキーボードショートカットをハードコードする必要があります。画面ロックは常にキーボードを制御します。つまり、画面ロックは、キーストロークを受け取ることができる実行中の唯一のXクライアントです。そうでない場合、他のアプリケーションはキーの押下を受け取ります。キャッチは、XGrabKeyboard
Xlib(slockで使用されるライブラリ)で実装された関数で発生します。通常、Xlibはよく文書化されており、興味がある場合は、そのマンページをインストールしてみることもできますman XGrabKeyboard
。他のマンページにも同様に、さまざまな異なるライブラリ機能に「X」プレフィックスが付いています。
setuid
私が理解したところによると、これはスクリプトがめちゃくちゃになるのではないかと心配していますか?その場合、最初の本能はfork()
起動時の作業速度を遅くし、パイプを使用して親と子の間の通信を行うことです。見ているソースコード、340行を中心に分岐してパイプを設定できますsetuid
。ショートカットを作成したら、パイプを使用して親と子の間で通信できます。基本的にやるべきことはメッセージを送るだけです。子供と両親は、いつ自分のスクリプトを実行する必要があるかを知っています。 Cでパイプするのはとても簡単です。したがって、実装をあまり操作したくない場合は、ここにパイプ全体の例があります。このウェブサイト:
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
int main(void)
{
int fd[2], nbytes;
pid_t childpid;
char string[] = "Hello, world!\n";
char readbuffer[80];
pipe(fd);
if((childpid = fork()) == -1)
{
perror("fork");
exit(1);
}
if(childpid == 0)
{
/* Child process closes up input side of pipe */
close(fd[0]);
/* Send "string" through the output side of pipe */
write(fd[1], string, (strlen(string)+1));
exit(0);
}
else
{
/* Parent process closes up output side of pipe */
close(fd[1]);
/* Read in a string from the pipe */
nbytes = read(fd[0], readbuffer, sizeof(readbuffer));
printf("Received string: %s", readbuffer);
}
return(0);
}