• Re: it's a shame... python error over error

    From aotto1968@aotto1968@t-online.de to comp.lang.python on Mon Dec 16 08:08:46 2024
    From Newsgroup: comp.lang.python

    On 13.12.24 11:36, aotto1968 wrote:
    it's a shame...
    almost every tool I touch that uses "python" in some way has some configuration error because apparently a __private__ python
    installation __isn't__ properly "understood".

    I think after ~30 years *python* should be able to handle a shared-library proper __or__ switch to a *static-build* by default.

    example here is the "mono-build" with the following installation.

    make[1]: Verzeichnis „HOME/src/mono.git/acceptance-tests“ wird betreten HOME/ext/x86_64-suse-linux-gnu/debug/bin/python3: error while loading shared libraries: libpython3.12d.so.1.0: cannot open
    shared object file: No such file or directory
    make[2]: Für das Ziel „install-exec-am“ ist nichts zu tun.
    make[2]: Für das Ziel „install-data-am“ ist nichts zu tun.
    make[2]: Verzeichnis „HOME/src/mono.git/acceptance-tests“ wird verlassen make[1]: Verzeichnis „HOME/src/mono.git/acceptance-tests“ wird verlassen [debug]dev1usr@linux02:~/src/mono.git> ldd HOME/ext/x86_64-suse-linux-gnu/debug/bin/python3
            linux-vdso.so.1 (0x00007ffd18e9a000)
            libpython3.12d.so.1.0 => HOME/ext/x86_64-suse-linux-gnu/debug/lib64/libpython3.12d.so.1.0 (0x00007f9c5d374000)
            libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f9c5d350000)
            libdl.so.2 => /lib64/libdl.so.2 (0x00007f9c5d349000)
            libutil.so.1 => /lib64/libutil.so.1 (0x00007f9c5d345000)
            libm.so.6 => /lib64/libm.so.6 (0x00007f9c5d1f9000)
            libc.so.6 => /lib64/libc.so.6 (0x00007f9c5d002000)
            /lib64/ld-linux-x86-64.so.2 (0x00007f9c5dab4000)


    If I read the answers I come to the conclusion that the "supporters" at python doesn't ever understand the problem.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Peter J. Holzer@hjp-python@hjp.at to comp.lang.python on Mon Dec 16 16:30:53 2024
    From Newsgroup: comp.lang.python


    --77uwacozsxv7kufg
    Content-Type: text/plain; charset=us-ascii
    Content-Disposition: inline
    Content-Transfer-Encoding: quoted-printable

    On 2024-12-16 08:08:46 +0100, aotto1968 via Python-list wrote:
    On 13.12.24 11:36, aotto1968 wrote:
    it's a shame...
    almost every tool I touch that uses "python" in some way has some configuration error because apparently a __private__ python installation __isn't__ properly "understood".
    [...]
    =20
    If I read the answers I come to the conclusion that the "supporters" at p=
    ython

    We are not "the supporters at python". None of us is paid for doing
    support. Most of us are just users of Python discussing the language and helping each other when we can (some of us are also contributors to
    Python).

    doesn't ever understand the problem.

    Quite possibly, but in that case you haven't explained it well enough.

    hp

    --=20
    _ | Peter J. Holzer | Story must make more sense than reality.
    |_|_) | |
    | | | hjp@hjp.at | -- Charles Stross, "Creative writing
    __/ | http://www.hjp.at/ | challenge!"

    --77uwacozsxv7kufg
    Content-Type: application/pgp-signature; name="signature.asc"

    -----BEGIN PGP SIGNATURE-----

    iQIzBAABCgAdFiEETtJbRjyPwVTYGJ5k8g5IURL+KF0FAmdgR6cACgkQ8g5IURL+ KF0taQ/+PwGYRa7jzGzQJtKL7kkzzOYzD6pNe8jVxRHdJ/zjywgDw9EYZytLP6Uw jKd7p26JkGWKsoKt2rYAj7FCwICP+HEoGnNeLXUeZXzIFWRT49F1A9OsWKpK9xVn zh6+gywcQR6Ud+e3BAjExUqY2j3pKF3dpnA3Q+AclmruU5CSd+ykHH7LEYaeI6Tx i5iM+wIO4a8bGEleoBYqpARvfBRiR87dI7691TdikrqcnL5f8VeGGtjRjOl1jqBO lk1OWiePc3OzlO26UeZQNGIzkHr48d1uj3Eoa42auGslwNoAoPMP6CSypYgUh/I/ mS5pdLE08fdwL5ryWsj/WHvVuBo2+RFsbVTY/6F/7Vz/ZCOC/fPFrXKD8LO7x3Y9 4A/LIKms0iyS0Vdxt7kHWEZ6Ou7Ols43pVjmU/HKFSCjW6YHrQv1k8M9pkIbsOfy VXmJo29ry7v01QwyP9Q+fw2y0qc5GyvmJPo5NVgCV/r7mWXskyvNUekMsW9hw/uc hJNMDaSa1zHnx8ImdJIQcjb1AHogWd/ml9b7BkNI+qbSmK1iESKg2+QdwMAQyJGt /jU/cEiwY1LNwvDENF8jEOtxzHWAJVbRHA+kg3g6ilexkQy766Y98Ib8Jht3SxBY 6UunnrvNH7Z9V/o288QYhZAwpwddEQbofnSevyMCIq0fQXM2+g0=
    =w9wK
    -----END PGP SIGNATURE-----

    --77uwacozsxv7kufg--
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Grant Edwards@grant.b.edwards@gmail.com to comp.lang.python on Mon Dec 16 14:06:56 2024
    From Newsgroup: comp.lang.python

    On 2024-12-16, aotto1968 via Python-list <python-list@python.org> wrote:

    If I read the answers I come to the conclusion that the "supporters"
    at python doesn't ever understand the problem.

    You should definitely demand to speak to the manager and request your
    money back.

    --
    Grant

    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Michael Torrie@torriem@gmail.com to comp.lang.python on Tue Dec 17 21:30:06 2024
    From Newsgroup: comp.lang.python

    On 12/16/24 12:08 AM, aotto1968 via Python-list wrote:
    If I read the answers I come to the conclusion that the "supporters" at python doesn't ever understand the problem.

    Sorry you feel that way. Various people gave the best advice they could
    based on what you had provided. You were given some good advice and
    even a few very specific things to try to determine the root problem
    which you don't seem to have done. I've used linux for 30 years and
    I've never seen a relative path used for a linker search path. What
    provided this path to the linker?
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Wed Dec 25 12:05:18 2024
    From Newsgroup: comp.lang.python

    I get angry…

    next python error…

    1) The OpenSUSE command "cnf" checks if a special package feature is installed. 2) I recently compiled **my** SQLite3 library specifically tailored to **my** requirement and installed it in **my** SQLite3
    project directory and never changed the OpenSUSE installation.
    3) "cnf" seems to use "Python" internally, but is **not** able to configure the *Python* environment to use only "OpenSUSE"'s
    own "Python" and "Sqlite3" software.
    4) Now the "cnf" fails with "Python" which apparently tries to use **my** SQLite3.

    what a shame.


    cnf jmc
    Traceback (most recent call last):
    File "/usr/bin/cnf", line 9, in <module>
    import scout
    File "/usr/lib/python3.6/site-packages/scout/__init__.py", line 10, in <module>
    import sqlite3
    File "/usr/lib64/python3.6/sqlite3/__init__.py", line 23, in <module>
    from sqlite3.dbapi2 import *
    File "/usr/lib64/python3.6/sqlite3/dbapi2.py", line 27, in <module>
    from _sqlite3 import *
    ImportError: /usr/lib64/python3.6/lib-dynload/_sqlite3.cpython-36m-x86_64-linux-gnu.so: undefined symbol: sqlite3_trace

    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Wed Dec 25 12:20:52 2024
    From Newsgroup: comp.lang.python

    On 25.12.24 12:05, aotto1968 wrote:
    I get angry…

    next python error…

    1) The OpenSUSE command "cnf" checks if a special package feature is installed.
    2) I recently compiled **my** SQLite3 library specifically tailored to **my** requirement and installed it in **my** SQLite3
    project directory and never changed the OpenSUSE installation.
    3) "cnf" seems to use "Python" internally, but is **not** able to configure the *Python* environment to use only "OpenSUSE"'s
    own "Python" and "Sqlite3" software.
    4) Now the "cnf" fails with "Python" which apparently tries to use **my** SQLite3.

    what a shame.


    cnf jmc
    Traceback (most recent call last):
      File "/usr/bin/cnf", line 9, in <module>
        import scout
      File "/usr/lib/python3.6/site-packages/scout/__init__.py", line 10, in <module>
        import sqlite3
      File "/usr/lib64/python3.6/sqlite3/__init__.py", line 23, in <module>
        from sqlite3.dbapi2 import *
      File "/usr/lib64/python3.6/sqlite3/dbapi2.py", line 27, in <module>
        from _sqlite3 import *
    ImportError: /usr/lib64/python3.6/lib-dynload/_sqlite3.cpython-36m-x86_64-linux-gnu.so: undefined symbol: sqlite3_trace


    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python

    head /usr/bin/cnf
    #!/usr/bin/python3

    import gettext
    import os
    ...

    2) os "root" python
    ls -al /usr/bin/python3
    lrwxrwxrwx 1 root root 9 2. Dez 13:16 /usr/bin/python3 -> python3.6
    ls -al /usr/bin/python3.6
    -rwxr-xr-x 2 root root 10560 2. Dez 13:16 /usr/bin/python3.6

    3) using **my** local non-root library
    ls -al NHI1_EXT/lib64/libsqlite3.so.0
    lrwxrwxrwx 1 dev1usr users 19 23. Dez 22:09 NHI1_EXT/lib64/libsqlite3.so.0 -> libsqlite3.so.0.8.6
    ls -al NHI1_EXT/lib64/libsqlite3.so.0.8.6
    -rwxr-xr-x 1 dev1usr users 3851872 23. Dez 22:09 NHI1_EXT/lib64/libsqlite3.so.0.8.6
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Chris Angelico@rosuav@gmail.com to comp.lang.python on Thu Dec 26 09:55:30 2024
    From Newsgroup: comp.lang.python

    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    Yes. And YOU were the one who installed a new root Python. This is a
    feature. You have the power to update Python on your system.

    You managed to make a build of Python that attempts to link to a DLL
    using a relative path. That's a fault of the build that means it won't
    work as root. I don't understand the confusion here; isn't the
    solution here to build a new version with an absolute path, and update
    your installation?

    ChrisA
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Michael Torrie@torriem@gmail.com to comp.lang.python on Wed Dec 25 20:55:47 2024
    From Newsgroup: comp.lang.python

    On 12/25/24 3:55 PM, Chris Angelico via Python-list wrote:
    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    I think he means the cnf is using the "root" OS python in /usr/bin, but /usr/bin/python3 is trying to import his local build of sqlite3, which
    cause it to fail. I assume he would like cnf to not try to import his
    local sqlite3, and instead use the normal system one. If this is the
    case, then somehow his local, non-root sqlite3 library is being picked
    up by the system version of python.

    Aotto might want to run the "env" command and see if there are any
    search paths that have to do with Python. I can see how this could be a security issue. If you can figure out what's happening you might want to
    open a ticket with the OpenSUSE developers. This is Python related, but
    it's not necessarily python's fault per se.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Michael Torrie@torriem@gmail.com to comp.lang.python on Wed Dec 25 20:57:26 2024
    From Newsgroup: comp.lang.python

    On 12/25/24 8:55 PM, Michael Torrie wrote:
    This is Python related, but
    it's not necessarily python's fault per se.

    It's also a good reminder to use venv. Then there's no way of
    activating your custom python with its custom sqlite3 library unless you explicitly activate the venv.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Chris Angelico@rosuav@gmail.com to comp.lang.python on Thu Dec 26 16:46:26 2024
    From Newsgroup: comp.lang.python

    On Thu, 26 Dec 2024 at 14:57, Michael Torrie via Python-list <python-list@python.org> wrote:

    On 12/25/24 3:55 PM, Chris Angelico via Python-list wrote:
    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    I think he means the cnf is using the "root" OS python in /usr/bin, but /usr/bin/python3 is trying to import his local build of sqlite3, which
    cause it to fail. I assume he would like cnf to not try to import his
    local sqlite3, and instead use the normal system one. If this is the
    case, then somehow his local, non-root sqlite3 library is being picked
    up by the system version of python.

    Right. That's exactly what would happen if he'd built Python using
    absolute paths to libraries, which is the normal way to do it. And so
    the solution is to rebuild Python using absolute paths to libraries.

    ChrisA
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Thu Dec 26 08:34:43 2024
    From Newsgroup: comp.lang.python

    On 25.12.24 23:55, Chris Angelico wrote:
    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    Yes. And YOU were the one who installed a new root Python. This is a
    feature. You have the power to update Python on your system.

    You managed to make a build of Python that attempts to link to a DLL
    using a relative path. That's a fault of the build that means it won't
    work as root. I don't understand the confusion here; isn't the
    solution here to build a new version with an absolute path, and update
    your installation?

    ChrisA

    sorry you don't understand the problem…

    You managed to make a build of Python that attempts to link to a DLL

    I never touch the OpenSUSE python. the OpenSUSE python try to use my
    sqalite3.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Thu Dec 26 08:35:59 2024
    From Newsgroup: comp.lang.python

    On 26.12.24 06:46, Chris Angelico wrote:
    On Thu, 26 Dec 2024 at 14:57, Michael Torrie via Python-list <python-list@python.org> wrote:

    On 12/25/24 3:55 PM, Chris Angelico via Python-list wrote:
    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list
    <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because: >>>>
    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    I think he means the cnf is using the "root" OS python in /usr/bin, but
    /usr/bin/python3 is trying to import his local build of sqlite3, which
    cause it to fail. I assume he would like cnf to not try to import his
    local sqlite3, and instead use the normal system one. If this is the
    case, then somehow his local, non-root sqlite3 library is being picked
    up by the system version of python.

    Right. That's exactly what would happen if he'd built Python using
    absolute paths to libraries, which is the normal way to do it. And so
    the solution is to rebuild Python using absolute paths to libraries.

    ChrisA

    next I don't change the OpenSUSE python and the OpenSUSE python is using *my* sqlite3.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Thu Dec 26 08:42:08 2024
    From Newsgroup: comp.lang.python

    On 26.12.24 04:55, Michael Torrie wrote:
    On 12/25/24 3:55 PM, Chris Angelico via Python-list wrote:
    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list
    <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    I think he means the cnf is using the "root" OS python in /usr/bin, but /usr/bin/python3 is trying to import his local build of sqlite3, which
    cause it to fail. I assume he would like cnf to not try to import his
    local sqlite3, and instead use the normal system one. If this is the
    case, then somehow his local, non-root sqlite3 library is being picked
    up by the system version of python.

    Aotto might want to run the "env" command and see if there are any
    search paths that have to do with Python. I can see how this could be a security issue. If you can figure out what's happening you might want to
    open a ticket with the OpenSUSE developers. This is Python related, but
    it's not necessarily python's fault per se.

    Yes I using with *my* user *my* environment but never touch the *root* environment at all.

    the *root* python try to use *my* sqlite3 because *my* environment
    fit to *my* needs.

    /* just a reminder */

    sqlite3 have a "special" (worse) setup that a change to the configuration
    also change the "api" ( a sqlite_function disappear or arrive ).
    If a tool like python using an extension that is linked to sqlite3 that extension
    will likely FAIL is I get an OTHER sqlite3 which is NOT the one the extension was build with.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Thu Dec 26 08:47:52 2024
    From Newsgroup: comp.lang.python

    On 26.12.24 04:55, Michael Torrie wrote:
    On 12/25/24 3:55 PM, Chris Angelico via Python-list wrote:
    On Thu, 26 Dec 2024 at 09:27, aotto1968 via Python-list
    <python-list@python.org> wrote:
    It is not only an *usage* error it is also an *security* error because:

    1) "cnf" is using OS python
    2) os "root" python
    3) using **my** local non-root library

    I think he means the cnf is using the "root" OS python in /usr/bin, but /usr/bin/python3 is trying to import his local build of sqlite3, which
    cause it to fail. I assume he would like cnf to not try to import his
    local sqlite3, and instead use the normal system one. If this is the
    case, then somehow his local, non-root sqlite3 library is being picked
    up by the system version of python.

    Aotto might want to run the "env" command and see if there are any
    search paths that have to do with Python. I can see how this could be a security issue. If you can figure out what's happening you might want to
    open a ticket with the OpenSUSE developers. This is Python related, but
    it's not necessarily python's fault per se.

    You don't understand the problem if you think "/usr/bin/env" will solve the problem → this will make it more worse.

    A "personal" python will use a "personal" configuration and probably is *not* build with sqlite3 support at all.

    a *root* tool should never ever use/call a non *root* (personal) setup.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Michael Torrie@torriem@gmail.com to comp.lang.python on Thu Dec 26 11:33:29 2024
    From Newsgroup: comp.lang.python

    On 12/25/24 10:46 PM, Chris Angelico wrote:
    Right. That's exactly what would happen if he'd built Python using
    absolute paths to libraries, which is the normal way to do it. And so
    the solution is to rebuild Python using absolute paths to libraries.

    You're right. Definitely appears to be a pretty major mis-configuration
    of his system. Not much we can do about that.

    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Fri Dec 27 07:46:56 2024
    From Newsgroup: comp.lang.python

    On 26.12.24 19:33, Michael Torrie wrote:
    On 12/25/24 10:46 PM, Chris Angelico wrote:
    Right. That's exactly what would happen if he'd built Python using
    absolute paths to libraries, which is the normal way to do it. And so
    the solution is to rebuild Python using absolute paths to libraries.

    You're right. Definitely appears to be a pretty major mis-configuration
    of his system. Not much we can do about that.


    no, your are wrong.

    The problem is NOT that my user-account has a miss-configuration because my user-account works pretty well…

    The problem is that the *default* /usr/bin/python3 OpenSUSE installation using parts of *my* local *user* setup.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Chris Angelico@rosuav@gmail.com to comp.lang.python on Mon Dec 30 17:10:18 2024
    From Newsgroup: comp.lang.python

    On Mon, 30 Dec 2024 at 15:02, aotto1968 via Python-list <python-list@python.org> wrote:
    You managed to make a build of Python that attempts to link to a DLL

    I never touch the OpenSUSE python. the OpenSUSE python try to use my sqalite3.

    You keep saying this, but do you even know what "make install" does?

    Are you capable of admitting that you were wrong, or are you going to
    keep digging this hole?

    ChrisA
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Michael Torrie@torriem@gmail.com to comp.lang.python on Mon Dec 30 10:29:12 2024
    From Newsgroup: comp.lang.python

    On 12/26/24 12:34 AM, aotto1968 via Python-list wrote:
    sorry you don't understand the problem…

    You managed to make a build of Python that attempts to link to a DLL

    I never touch the OpenSUSE python. the OpenSUSE python try to use my sqalite3.

    The *only* mechanism that would cause the system python binary to try to
    load modules and libraries from your local install is your environment (environment variables).

    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From aotto1968@aotto1968@t-online.de to comp.lang.python on Fri Jan 3 23:16:24 2025
    From Newsgroup: comp.lang.python

    On 30.12.24 18:29, Michael Torrie wrote:
    On 12/26/24 12:34 AM, aotto1968 via Python-list wrote:
    sorry you don't understand the problem…

    > You managed to make a build of Python that attempts to link to a DLL

    I never touch the OpenSUSE python. the OpenSUSE python try to use my
    sqalite3.

    The *only* mechanism that would cause the system python binary to try to
    load modules and libraries from your local install is your environment (environment variables).


    that is right because MY environment variable point to MY local user stuff.

    The CORE problem is that OpenSUSE (Linux) python use MY env.

    If I call a OS feature like "cnf" this should NOT interact with my private user stuff.

    the OpenSUSE do it right because OpenSUSE use /usr/bin/python in "cnf" BUT the python think to interact with MY env.

    To make it short: The OS python will NEVER proper work if LOCAL user stuff is used.
    --- Synchronet 3.20a-Linux NewsLink 1.114
  • From Chris Angelico@rosuav@gmail.com to comp.lang.python on Sat Jan 4 09:25:19 2025
    From Newsgroup: comp.lang.python

    On Sat, 4 Jan 2025 at 09:22, aotto1968 via Python-list
    <python-list@python.org> wrote:

    On 30.12.24 18:29, Michael Torrie wrote:
    On 12/26/24 12:34 AM, aotto1968 via Python-list wrote:
    sorry you don't understand the problem…

    > You managed to make a build of Python that attempts to link to a DLL >>
    I never touch the OpenSUSE python. the OpenSUSE python try to use my
    sqalite3.

    The *only* mechanism that would cause the system python binary to try to load modules and libraries from your local install is your environment (environment variables).


    that is right because MY environment variable point to MY local user stuff.

    The CORE problem is that OpenSUSE (Linux) python use MY env.

    If I call a OS feature like "cnf" this should NOT interact with my private user stuff.

    the OpenSUSE do it right because OpenSUSE use /usr/bin/python in "cnf" BUT the
    python think to interact with MY env.

    To make it short: The OS python will NEVER proper work if LOCAL user stuff is used.
    People have tried in vain to explain this to you. You refuse to
    listen. Go and argue with your OS instead of us; we're not the ones in
    charge of this. Maybe if you argue enough, you'll start to understand
    what "make install" does.
    ChrisA
    --- Synchronet 3.20a-Linux NewsLink 1.114