Outra API do Python para acessar libnotify , juntamente com o suporte ao som do Notification (com o back -end vlc ) .

CUIDADO: Bem, você que você passa por um produto rigoroso de instalação, que pode não ser uma escolha preferida sempre. Mas é bastante seguro, você aprenderá algo novo.
Vou demonstrar procedimento de instalação no Solus Linux .
gcc , glibc , glibc-devel . Vou usar gcc 9.3.0 . $ sudo eopkg it gcc, glibc, glibc-devel
$ gcc --version # check versionCython , também instalaremos pip . Estou usando Python3.7.6 . $ sudo eopkg it python3, python3-devel, pip
$ python3 --version
$ python3 -m pip install --user Cythonlibnotify , libnotify-devel , que nos dará uma interface programática para conversar com a libnotificação da nossa biblioteca C. $ sudo eopkg it libnotify libnotify-devel$ notify-send " Summary " " Body of Notification "vlc , que será usado para reproduzir som de notificação, pode ser útil para alertar o usuário. $ sudo eopkg it vlc vlc-develVamos primeiro a um local conveniente na hierarquia de diretórios da sua máquina, onde você pode clonar esse repositório e começar a funcionar.
$ git clone https://github.com/itzmeanjan/pynotif.git Entre no diretório pynotif e verifique o conteúdo dos diretórios.
$ cd pynotif
$ tree -h
.
├── [4.0K] libnotification
│ ├── [2.4K] play_sound.c
│ ├── [ 45] play_sound.h
│ ├── [2.4K] send_notification.c
│ └── [ 235] send_notification.h
├── [1.0K] LICENSE
├── [4.0K] pynotif
│ ├── [1.5K] pynotif.pyx
│ └── [1.1K] setup.py
├── [7.0K] README.md
├── [4.0K] sound
│ ├── [ 30K] button_sound.wav
│ └── [ 29K] when.mp3
└── [4.0K] ss
└── [ 71K] screenshot.png
4 directories, 11 files Primeiro, vamos libnotification , que será compilado em uma biblioteca C estática. Os nomes dos arquivos são bastante auto-explicativos, para que finalidade eles servem.
$ cd libnotification
$ ls
play_sound.c play_sound.h send_notification.c send_notification.hHora de compilar cada um desses arquivos C e gerar código de objeto.
$ gcc -c play_sound.c
$ gcc -I /usr/include/glib-2.0/ -I /usr/include/gdk-pixbuf-2.0/ -I /usr/lib64/glib-2.0/include/ -c send_notification.c Agora precisamos arquivar esses arquivos de objeto em uma biblioteca estática, que será invocada do código Cython (*.pyx arquivo) .
$ ar rcs libnotification.a play_sound.o send_notification.oComo obtivemos biblioteca estática, os códigos de objetos compilados podem ser removidos agora. Você pode considerar verificar o tipo de biblioteca estática gerada.
$ rm * .o
$ file libnotification.a
libnotification.a: current ar archive Agora, entraremos no diretório pynotif , que possui o código do Cython, necessário para conversar com a biblioteca C, libnotification.a .
$ cd ../pynotif
$ ls
pynotif.pyx setup.py pynotif.pyx mantém o código Cython para interface com libnotification.a , que deve ser compilada em código C equivalente (usando o Cython Compiler) . Em seguida, construiremos a biblioteca de extensão C (biblioteca dinamicamente vinculada) , que pode ser invocada do Python.
$ python3 setup.py build_ext --inplace
Compiling pynotif.pyx because it changed.
[1/1] Cythonizing pynotif.pyx
running build_ext
building ' pynotif ' extension
creating build
creating build/temp.linux-x86_64-3.7
x86_64-solus-linux-gcc -pthread -Wno-unused-result -Wsign-compare -DNDEBUG -g -fwrapv -O3 -Wall -mtune=generic -march=x86-64 -g2 -pipe -fPIC -Wformat -Wformat-security -D_FORTIFY_SOURCE=2 -fstack-protector-strong --param ssp-buffer-size=32 -fasynchronous-unwind-tables -ftree-vectorize -feliminate-unused-debug-types -Wall -Wno-error -Wp,-D_REENTRANT -fno-semantic-interposition -O3 -falign-functions=32 -I/usr/include -mtune=generic -march=x86-64 -g2 -pipe -fPIC -Wformat -Wformat-security -D_FORTIFY_SOURCE=2 -fstack-protector-strong --param ssp-buffer-size=32 -fasynchronous-unwind-tables -ftree-vectorize -feliminate-unused-debug-types -Wall -Wno-error -Wp,-D_REENTRANT -fno-semantic-interposition -O3 -falign-functions=32 -fPIC -I/usr/include/glib-2.0/ -I/usr/include/gdk-pixbuf-2.0/ -I/usr/lib64/glib-2.0/include/ -I../libnotification/ -I/usr/include/python3.7m -c pynotif.c -o build/temp.linux-x86_64-3.7/pynotif.o
x86_64-solus-linux-gcc -pthread -shared -Wl,--copy-dt-needed-entries -Wl,-O1 -Wl,-z,relro -Wl,-z,now -Wl,-z,max-page-size=0x1000 -Wl,-Bsymbolic-functions -Wl,--sort-common -Wl,--copy-dt-needed-entries -Wl,-O1 -Wl,-z,relro -Wl,-z,now -Wl,-z,max-page-size=0x1000 -Wl,-Bsymbolic-functions -Wl,--sort-common build/temp.linux-x86_64-3.7/pynotif.o -L/usr/lib64/ -L../libnotification/ -L/usr/lib64 -lvlc -lnotify -lnotification -lpython3.7m -o /home/anjan/Documents/my_programs/still_working/open/pynotif/pynotif/pynotif.cpython-37m-x86_64-linux-gnu.so
$ tree -h
.
├── [4.0K] build
│ └── [4.0K] temp.linux-x86_64-3.7
│ └── [203K] pynotif.o
├── [125K] pynotif.c
├── [146K] pynotif.cpython-37m-x86_64-linux-gnu.so
├── [1.5K] pynotif.pyx
└── [1.1K] setup.py
2 directories, 5 files pynotif.*.so acontece com o nosso objeto compartilhado estaticamente vinculado, que é de interesse. ./build Directory & pynotif.c pode ser excluído. Mas você pode estar interessado em dar uma olhada no pynotif.c , que é gerado código C do pynotif.pyx pelo compilador Cython .
$ rm build/ pynotif.c -rv
$ file pynotif.cpython- * .so # check it out Agora você pode usar pynotif , mas apenas deste diretório de trabalho. Vamos verificar isso primeiro.
$ python3
>>> import pynotif
>>> pynotif.__version__
' 0.1.0 '
>>> pynotif.startNotif(b " My Application " )
1
>>> pynotif.sendNotif(b " Summary " , b " Body of Notification " , 2, 1, b " /path/to/icon/file " , b " /path/to/notification/sound/file " )
1
>> pynotif.stopNotif ()
>>> help ()
help > pynotif # shows you API documentation
...Mas queremos disponibilizá -lo para todos os scripts instalados nesta máquina, não é? Em seguida, instalaremos esta biblioteca em algum local padrão.
$ python3 setup.py install --user Agora vá para $HOME Directory e Invoque o prompt Python3 Repl.
$ cd
$ python3
>> import pynotif # and it works as expected Parabéns, você construiu e instalou com sucesso pynotif a partir da biblioteca C. Agora use como você desejar.
Agradecendo a você