Еще один Python API для доступа libnotify , наряду с поддержкой звука уведомлений (с бэкэнд vlc ) .

Внимание: Ну, вы, чтобы пройти строгую продюсеру установки, которая всегда не может быть предпочтительным выбором. Но это довольно уверенно, вы узнаете что -то новое.
Я продемонстрирую процедуру установки на Solus Linux .
gcc , glibc , glibc-devel . Я использую gcc 9.3.0 . $ sudo eopkg it gcc, glibc, glibc-devel
$ gcc --version # check versionCython мы также установим pip . Я использую Python3.7.6 . $ sudo eopkg it python3, python3-devel, pip
$ python3 --version
$ python3 -m pip install --user Cythonlibnotify , libnotify-devel , который даст нам программный интерфейс для разговора с Libnotify из нашей C-Library. $ sudo eopkg it libnotify libnotify-devel$ notify-send " Summary " " Body of Notification "vlc , которая будет использоваться для воспроизведения звука уведомлений, может быть полезным для предупреждения пользователя. $ sudo eopkg it vlc vlc-develДавайте сначала перейдем к удобному месту в иерархии каталогов вашей машины, где вы можете клонировать это репо и начать работу.
$ git clone https://github.com/itzmeanjan/pynotif.git Западайте в каталог pynotif и проверьте содержание каталогов.
$ 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 Во-первых, мы собираемся libnotification , что будет составлено в статическую С-библиотеку. Имена файлов довольно эксплуатационны, для какой цели они служат.
$ cd libnotification
$ ls
play_sound.c play_sound.h send_notification.c send_notification.hВремя скомпилировать каждый из этих файлов C и генерировать объектный код.
$ 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 Теперь нам нужно архивировать эти объектные файлы в статическую библиотеку, которая будет вызвана из Cython Code (*.pyx файл) .
$ ar rcs libnotification.a play_sound.o send_notification.oПоскольку мы получили статическую библиотеку, скомпилированные объектные коды могут быть удалены сейчас. Вы можете рассмотреть возможность проверки сгенерированной статической библиотеки.
$ rm * .o
$ file libnotification.a
libnotification.a: current ar archive Теперь мы перейдем к каталогу pynotif , который содержит код цинтона, необходимый для общения с C-Library, libnotification.a .
$ cd ../pynotif
$ ls
pynotif.pyx setup.py pynotif.pyx содержит код цинтона для взаимодействия с libnotification.a , который должен быть составлен в эквивалентный C -код C (с использованием компилятора Cython) . Затем мы создадим библиотеку расширения C (динамически связанная библиотека) , которая может быть вызвана с 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 , как наш статически связанный общий объект, который представляет интерес. ./build Directory & pynotif.c можно удалить. Но вам может быть заинтересован в том, чтобы взглянуть на pynotif.c , который генерируется C -код из pynotif.pyx Cython .
$ rm build/ pynotif.c -rv
$ file pynotif.cpython- * .so # check it out Теперь вы можете использовать pynotif , но только из этого рабочего каталога. Давайте сначала проверим это.
$ 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
...Но мы хотим сделать его доступным для всех сценариев, установленных на этой машине, не так ли? Затем мы установим эту библиотеку в какое -то стандартное место.
$ python3 setup.py install --user Теперь перейдите в $HOME Directory и вызовите подсказку Python3 Repl.
$ cd
$ python3
>> import pynotif # and it works as expected Поздравляем, вы успешно построили и установили pynotif из C-Library. Теперь используйте как вы хотите.
Благодарю вас