Linuxで動作するJuliaプログラムでは、コンソールウィンドウのサイズが変更されたときに専用のアクションを起動する必要があります。では、ジュリアでは、システム信号SIGWINCH(ウィンドウのサイズ変更)をインターセプトして、必要なアクションを実行する関数をそれにアタッチできますか?
Adaでは、それを宣言するのはかなり簡単です。
protected Signalhandler is
procedure Handlewindowresizing;
pragma Attach_Handler (Handlewindowresizing, SIGWINCH);
end Signalhandler;
SCHEMERのアイデアに基づく暫定的な解決策:SIGWINCH割り込み監視を実行するCライブラリを使用しようとします。
myLibrary.h
void Winresize (void Sig_Handler());
myLibrary.c
#include "myLibrary.h"
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
void Winresize(void sig_handler (void)) {
signal(SIGWINCH, sig_handler);
}
コンパイルとライブラリの準備
gcc -c -Wall -fPIC myLibrary.c
gcc -shared -fPIC -o myLibrary.so myLibrary.o
C-Libraryを使用するJuliaのプログラム:
function getc1()
ret = ccall(:jl_tty_set_mode, Int32, (Ptr{Cvoid},Int32), stdin.handle, true)
ret == 0 || error("unable to switch to raw mode")
c = read(stdin, UInt8)
ccall(:jl_tty_set_mode, Int32, (Ptr{Cvoid},Int32), stdin.handle, false)
c
end
function traitement() println(displaysize(stdout)); end
Mon_traitement_c = @cfunction(traitement, Cvoid, ())
ccall((:Winresize, "/home/Emile/programmation/Julia/myLibrary.so"), Cvoid, (Ptr{Cvoid},), Mon_traitement_c)
while true
println(getc1())
end
Juliaプログラムは正しく実行されますが、ターミナルウィンドウのサイズが変更されると、セグメンテーションエラー(コアダンプ)が発行され、プログラムはコード139で終了したと言われます。
だから問題は、このセグメンテーション違反がどこから来るのか?コンパイルモデルから?Juliaは、Cが信号監視を管理するメモリ部分でコード実行を制御する権利を持っていませんか?
Sig_handlerのprintln操作を削除すると、セグメンテーション違反が抑制されます。
curr_size = displaysize(stdout)
new_size = curr_size
function traitement() global new_size ; new_size = displaysize(stdout); return end
Mon_traitement_c = @cfunction(traitement, Cvoid, ())
ccall((:Winresize, "/home/Emile/programmation/Julia/myLibrary.so"), Cvoid, (Ptr{Cvoid},), Mon_traitement_c)
while true
global curr_size, new_size
if new_size != curr_size
curr_size = new_size
println(curr_size)
end
sleep(0.1)
end