Question about php-config in Makefile
Closed this issue · 16 comments
I'm using few php-gtk3
builds, and found that one of them does not work after build
Fatal error: Uncaught Error: Class "Gtk" not found
Suppose that because makefile linked to global php-config
here:
https://github.com/scorninpc/php-gtk3/blob/master/Makefile#L110
I'm trying to add absolute (local version) path but it not works (maybe because of quotes, don't know)
Can be the reason?
Maybe it's better to add global variable like this one?
https://github.com/CopernicaMarketingSoftware/PHP-CPP/blob/master/Makefile#L20
I'm using this auto-build script for my app that replaces global php-config
path to local one:
https://github.com/YGGverse/Yoda/blob/main/INSTALL.sh#L198
It creates PHP/PHP-CPP/PHP-GTK dependencies in build
folder inside the project dir.
it work before, until I've installed new PHP-GTK instance for global PHP version, now it say that Gtk class not found, I suppose that because PHP-GTK configured with wrong paths somewhere..
Now my app still work with global PHP but don't work with local PHP/PHP-CPP/PHP-GTK build, e.g.:
php -dextension=php-gtk3.so app.php
- OK/path/to/local/php -dextension=php-gtk3.so app.php
- Gtk class not found
i dont see corelacionation between php-config and not load of extension @d47081
php-config are just used to install extension and headers
are you compiling with one version of php and running with another one?
/path/to/local/php -dextension=php-gtk3.so app.php - Gtk class not found
provide full output please
So pkg-config
is not globally called symlink here?
# https://github.com/scorninpc/php-gtk3/blob/master/Makefile#L110
GTKFLAGS = `pkg-config --cflags gtk+-3.0 gladeui-2.0 gtksourceview-3.0 ${MAC_INTEGRATIONFLAGS} ${LIBWNCKFLAGS}`
GTKLIBS = `pkg-config --libs gtk+-3.0 gladeui-2.0 gtksourceview-3.0 ${MAC_INTEGRATIONLIBS} ${LIBWNCKLIBS}`
are you compiling with one version of php and running with another one?
I'm compilling all PHP* dependencies into the local build
folder (to not touch globals, and don't use sudo for install)
but just installed php-gtk globally (for separated contribution tests) and now my local app builder does not work
like something calling to the globals in makefile yet
thanks for reply, maybe just builder issue if that is not common pkg-config
location
I'm using
INI_DIR = "/dev/null"
maybe reason in that?
anyway, php-config --ini-dir
return empty result, so I don't know what to provide here
INI_DIR
is only used to install
https://github.com/scorninpc/php-gtk3/blob/master/Makefile#L157
if you dont show me all the output, I really cannot help. If everyone can compile and run, it's work and you have or missing something, that I can just help if you help me to understant
I just can tell you, with this comment
php -dextension=php-gtk3.so app.php - OK
/path/to/local/php -dextension=php-gtk3.so app.php - Gtk class not found
is that you are compilling php-gtk with global php, and not with /path/to/local/php
, and, if you run /path/to/local/php -dextension=php-gtk3.so app.php
the error maybe are "cannot load shared extension"
if is that case, you need to see the complete error to try solve, or compile to /path/to/local/php
, not to global default php
I don't really know where is the problem, because remember I have another mystics with rust dependencies on one machine, now this magic happened..
Closing so, will share my solution if found.
On laptop everything building well, I have no idea what is wrong with other PC..
Found this output:
Warning: PHP Startup: php-gtk3: Unable to initialize module
Module compiled with module API=20220829
PHP compiled with module API=20230831
These options need to match
in Unknown on line 0
Fatal error: Uncaught Error: Class "Gtk" not found
It means that php-gtk3
configured with global php version 20220829 (php -i
), not local one 20230831 (/local/php -i
)
I have provided LOCAL extension dir in makefile but it building with GLOBAL php version yet
EXTENSION_DIR = "/home/.../Yoda/build/Linux/opt/php/lib/php/extensions/no-debug-non-zts-20230831"
of course I have changed php_config
path on php-cpp building.
upd
just found php-cpp's ${PHP_CONFIG} --ldflags
return empty path for my local php version
@d47081 i really need to see all complete message output!
like this:
I need to see command, i need to see full output
and please, provide output of -m
, like this
-m
flags return nothing, I have only this output
Warning: PHP Startup: php-gtk3: Unable to initialize module
Module compiled with module API=20220829
PHP compiled with module API=20230831
These options need to match
in Unknown on line 0
Fatal error: Uncaught Error: Class "Gtk" not found
here is related issue but I don't understand where I must define my local php version for compiller - I've set local php-config path for php-cpp
but can't find where can define for php-gtk3
, it uses global php version yet and drop this error
CopernicaMarketingSoftware/PHP-CPP#518
maybe I must to define INI_DIR
? because local build has no path for it, and I've set there /dev/null
when I set -dextension="/absolute/path/to/php-gtk3.so"
instead of -dextension="php-gtk3.so"
still same, so target library linked properly
I have correct EXTENSION_DIR path to local php-config version compilled.
if php-gtk3 does not need php headers why I get alert about incorrect php-gtk3 API version?
You may try to build this app by INSTALL.sh
and watch Makefiles generated in build/Linux/tmp
for php-cpp/php-gtk3
https://github.com/YGGverse/Yoda#auto
You are installing PHP-CPP
in a custom directory, https://github.com/YGGverse/Yoda/blob/main/INSTALL.sh#L15 without adding this to LD_LIBRARY_PATH
, so when you compile PHP-GTK3, compiller will use /usr/lib
one, not the compiled one
Thanks but still can't make it working
trying to set in php-gtk makefile:
LINKER_DEPENDENCIES = -L/path/to/build/Linux/usr/local/lib -lphpcpp ${GTKLIBS}
as defined in php-cpp makefile:
INSTALL_HEADERS = ${INSTALL_PREFIX}/include
INSTALL_LIB = ${INSTALL_PREFIX}/lib
and get same result
You can see search path priority. Compiler will use the first found
I can't help much, this is obviously a system/environment problem, but I believe this is the way to go
Found this solution:
LINKER_DEPENDENCIES = -Wl,-rpath=/path/to/build/Linux/usr/local/lib -lphpcpp ${GTKLIBS}
Thanks for help