OF-Scraper icon indicating copy to clipboard operation
OF-Scraper copied to clipboard

uvloop issue

Open gfl43r9nd opened this issue 8 months ago • 1 comments

I'm trying to install ofscraper on ubuntu 25.04 and I get the following error installing uvloop. Using pythong 3.13.3, which appears to be the default in ubuntu 25.04

Building wheels for collected packages: uvloop
  Building wheel for uvloop (pyproject.toml) ... error
  error: subprocess-exited-with-error
  
  × Building wheel for uvloop (pyproject.toml) did not run successfully.
  │ exit code: 1
  ╰─> [449 lines of output]
      /tmp/pip-build-env-hu4tp6b6/overlay/lib/python3.13/site-packages/setuptools/config/_apply_pyprojecttoml.py:82: SetuptoolsDeprecationWarning: `project.license` as a TOML table is deprecated
      !!
      
              ********************************************************************************
              Please use a simple string containing a SPDX expression for `project.license`. You can also use `project.license-files`. (Both options available on setuptools>=77.0.0).
      
              By 2026-Feb-18, you need to update your project and remove deprecated calls
              or your builds will no longer be supported.
      
              See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details.
              ********************************************************************************
      
      !!
        corresp(dist, value, root_dir)
      /tmp/pip-build-env-hu4tp6b6/overlay/lib/python3.13/site-packages/setuptools/config/_apply_pyprojecttoml.py:61: SetuptoolsDeprecationWarning: License classifiers are deprecated.
      !!
      
              ********************************************************************************
              Please consider removing the following classifiers in favor of a SPDX license expression:
      
              License :: OSI Approved :: Apache Software License
              License :: OSI Approved :: MIT License
      
              See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details.
              ********************************************************************************
      
      !!
        dist._finalize_license_expression()
      /tmp/pip-build-env-hu4tp6b6/overlay/lib/python3.13/site-packages/setuptools/dist.py:759: SetuptoolsDeprecationWarning: License classifiers are deprecated.
      !!
      
              ********************************************************************************
              Please consider removing the following classifiers in favor of a SPDX license expression:
      
              License :: OSI Approved :: Apache Software License
              License :: OSI Approved :: MIT License
      
              See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details.
              ********************************************************************************
      
      !!
        self._finalize_license_expression()
      running bdist_wheel
      running build
      running build_py
      creating build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/_version.py -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/_testbase.py -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/_noop.py -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/__init__.py -> build/lib.linux-x86_64-cpython-313/uvloop
      running egg_info
      writing uvloop.egg-info/PKG-INFO
      writing dependency_links to uvloop.egg-info/dependency_links.txt
      writing requirements to uvloop.egg-info/requires.txt
      writing top-level names to uvloop.egg-info/top_level.txt
      reading manifest file 'uvloop.egg-info/SOURCES.txt'
      reading manifest template 'MANIFEST.in'
      warning: no previously-included files matching '*' found under directory 'vendor/libuv/.git'
      warning: no previously-included files matching '*' found under directory 'vendor/libuv/docs'
      warning: no previously-included files matching '*' found under directory 'vendor/libuv/img'
      adding license file 'LICENSE-APACHE'
      adding license file 'LICENSE-MIT'
      writing manifest file 'uvloop.egg-info/SOURCES.txt'
      /tmp/pip-build-env-hu4tp6b6/overlay/lib/python3.13/site-packages/setuptools/command/build_py.py:212: _Warning: Package 'uvloop.handles' is absent from the `packages` configuration.
      !!
      
              ********************************************************************************
              ############################
              # Package would be ignored #
              ############################
              Python recognizes 'uvloop.handles' as an importable package[^1],
              but it is absent from setuptools' `packages` configuration.
      
              This leads to an ambiguous overall configuration. If you want to distribute this
              package, please make sure that 'uvloop.handles' is explicitly added
              to the `packages` configuration field.
      
              Alternatively, you can also rely on setuptools' discovery methods
              (for example by using `find_namespace_packages(...)`/`find_namespace:`
              instead of `find_packages(...)`/`find:`).
      
              You can read more about "package discovery" on setuptools documentation page:
      
              - https://setuptools.pypa.io/en/latest/userguide/package_discovery.html
      
              If you don't want 'uvloop.handles' to be distributed and are
              already explicitly excluding 'uvloop.handles' via
              `find_namespace_packages(...)/find_namespace` or `find_packages(...)/find`,
              you can try to use `exclude_package_data`, or `include-package-data=False` in
              combination with a more fine grained `package-data` configuration.
      
              You can read more about "package data files" on setuptools documentation page:
      
              - https://setuptools.pypa.io/en/latest/userguide/datafiles.html
      
      
              [^1]: For Python, any directory (with suitable naming) can be imported,
                    even if it does not contain any `.py` files.
                    On the other hand, currently there is no concept of package data
                    directory, all directories are treated like packages.
              ********************************************************************************
      
      !!
        check.warn(importable)
      /tmp/pip-build-env-hu4tp6b6/overlay/lib/python3.13/site-packages/setuptools/command/build_py.py:212: _Warning: Package 'uvloop.includes' is absent from the `packages` configuration.
      !!
      
              ********************************************************************************
              ############################
              # Package would be ignored #
              ############################
              Python recognizes 'uvloop.includes' as an importable package[^1],
              but it is absent from setuptools' `packages` configuration.
      
              This leads to an ambiguous overall configuration. If you want to distribute this
              package, please make sure that 'uvloop.includes' is explicitly added
              to the `packages` configuration field.
      
              Alternatively, you can also rely on setuptools' discovery methods
              (for example by using `find_namespace_packages(...)`/`find_namespace:`
              instead of `find_packages(...)`/`find:`).
      
              You can read more about "package discovery" on setuptools documentation page:
      
              - https://setuptools.pypa.io/en/latest/userguide/package_discovery.html
      
              If you don't want 'uvloop.includes' to be distributed and are
              already explicitly excluding 'uvloop.includes' via
              `find_namespace_packages(...)/find_namespace` or `find_packages(...)/find`,
              you can try to use `exclude_package_data`, or `include-package-data=False` in
              combination with a more fine grained `package-data` configuration.
      
              You can read more about "package data files" on setuptools documentation page:
      
              - https://setuptools.pypa.io/en/latest/userguide/datafiles.html
      
      
              [^1]: For Python, any directory (with suitable naming) can be imported,
                    even if it does not contain any `.py` files.
                    On the other hand, currently there is no concept of package data
                    directory, all directories are treated like packages.
              ********************************************************************************
      
      !!
        check.warn(importable)
      copying uvloop/cbhandles.pxd -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/cbhandles.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/dns.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/errors.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/loop.pxd -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/loop.pyi -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/loop.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/lru.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/pseudosock.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/py.typed -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/request.pxd -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/request.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/server.pxd -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/server.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/sslproto.pxd -> build/lib.linux-x86_64-cpython-313/uvloop
      copying uvloop/sslproto.pyx -> build/lib.linux-x86_64-cpython-313/uvloop
      creating build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/async_.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/async_.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/basetransport.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/basetransport.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/check.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/check.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/fsevent.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/fsevent.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/handle.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/handle.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/idle.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/idle.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/pipe.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/pipe.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/poll.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/poll.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/process.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/process.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/stream.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/stream.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/streamserver.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/streamserver.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/tcp.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/tcp.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/timer.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/timer.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/udp.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      copying uvloop/handles/udp.pyx -> build/lib.linux-x86_64-cpython-313/uvloop/handles
      creating build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/__init__.py -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/consts.pxi -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/debug.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/flowcontrol.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/python.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/stdlib.pxi -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/system.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      copying uvloop/includes/uv.pxd -> build/lib.linux-x86_64-cpython-313/uvloop/includes
      running build_ext
      checking for a BSD-compatible install... /usr/bin/install -c
      checking whether build environment is sane... yes
      checking for a race-free mkdir -p... /usr/bin/mkdir -p
      checking for gawk... gawk
      checking whether make sets $(MAKE)... yes
      checking whether make supports nested variables... yes
      checking whether to enable maintainer-specific portions of Makefiles... yes
      checking build system type... x86_64-pc-linux-gnu
      checking host system type... x86_64-pc-linux-gnu
      checking for gcc... gcc
      checking whether the C compiler works... yes
      checking for C compiler default output file name... a.out
      checking for suffix of executables...
      checking whether we are cross compiling... no
      checking for suffix of object files... o
      checking whether the compiler supports GNU C... yes
      checking whether gcc accepts -g... yes
      checking for gcc option to enable C11 features... none needed
      checking whether gcc understands -c and -o together... yes
      checking whether make supports the include directive... yes (GNU style)
      checking dependency style of gcc... gcc3
      checking for gcc way to treat warnings as errors... -Werror
      checking if gcc supports __attribute__(( visibility("default") ))... yes
      checking if gcc supports -fvisibility=hidden... yes
      checking if gcc supports -fno-strict-aliasing flag... yes
      checking if gcc supports -fno-strict-aliasing flag... yes
      checking if gcc supports -g flag... yes
      checking if gcc supports -std=gnu89 flag... yes
      checking if gcc supports -Wall flag... yes
      checking if gcc supports -Wextra flag... yes
      checking if gcc supports -Wno-long-long flag... yes
      checking if gcc supports -Wno-unused-parameter flag... yes
      checking if gcc supports -Wstrict-prototypes flag... yes
      checking for ar... ar
      checking the archiver (ar) interface... ar
      checking how to print strings... printf
      checking for a sed that does not truncate output... /usr/bin/sed
      checking for grep that handles long lines and -e... /usr/bin/grep
      checking for egrep... /usr/bin/grep -E
      checking for fgrep... /usr/bin/grep -F
      checking for ld used by gcc... /usr/bin/ld
      checking if the linker (/usr/bin/ld) is GNU ld... yes
      checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B
      checking the name lister (/usr/bin/nm -B) interface... BSD nm
      checking whether ln -s works... yes
      checking the maximum length of command line arguments... 1572864
      checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop
      checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop
      checking for /usr/bin/ld option to reload object files... -r
      checking for objdump... objdump
      checking how to recognize dependent libraries... pass_all
      checking for dlltool... no
      checking how to associate runtime and link libraries... printf %s\n
      checking for archiver @FILE support... @
      checking for strip... strip
      checking for ranlib... ranlib
      checking command to parse /usr/bin/nm -B output from gcc object... ok
      checking for sysroot... no
      checking for a working dd... /usr/bin/dd
      checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1
      checking for mt... mt
      checking if mt is a manifest tool... no
      checking for stdio.h... yes
      checking for stdlib.h... yes
      checking for string.h... yes
      checking for inttypes.h... yes
      checking for stdint.h... yes
      checking for strings.h... yes
      checking for sys/stat.h... yes
      checking for sys/types.h... yes
      checking for unistd.h... yes
      checking for dlfcn.h... yes
      checking for objdir... .libs
      checking if gcc supports -fno-rtti -fno-exceptions... no
      checking for gcc option to produce PIC... -fPIC -DPIC
      checking if gcc PIC flag -fPIC -DPIC works... yes
      checking if gcc static flag -static works... yes
      checking if gcc supports -c -o file.o... yes
      checking if gcc supports -c -o file.o... (cached) yes
      checking whether the gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes
      checking whether -lc should be explicitly linked in... no
      checking dynamic linker characteristics... GNU/Linux ld.so
      checking how to hardcode library paths into programs... immediate
      checking whether stripping libraries is possible... yes
      checking if libtool supports shared libraries... yes
      checking whether to build shared libraries... yes
      checking whether to build static libraries... yes
      checking whether make supports nested variables... (cached) yes
      checking how to run the C preprocessor... gcc -E
      checking whether gcc is Clang... no
      checking whether pthreads work with -pthread... yes
      checking for joinable pthread attribute... PTHREAD_CREATE_JOINABLE
      checking whether more special flags are required for pthreads... no
      checking for PTHREAD_PRIO_INHERIT... yes
      checking for library containing dlopen... none required
      checking for library containing kstat_lookup... no
      checking for library containing gethostbyname... none required
      checking for library containing perfstat_cpu... no
      checking for library containing clock_gettime... none required
      checking for library containing sendfile... none required
      checking for library containing socket... none required
      checking for special C compiler options needed for large files... no
      checking for _FILE_OFFSET_BITS value needed for large files... no
      checking for sys/ahafs_evProds.h... no
      checking that generated files are newer than configure... done
      configure: creating ./config.status
      config.status: creating Makefile
      config.status: creating libuv.pc
      config.status: executing depfiles commands
      config.status: executing libtool commands
        CC       src/libuv_la-fs-poll.lo
        CC       src/libuv_la-idna.lo
        CC       src/libuv_la-inet.lo
        CC       src/libuv_la-random.lo
        CC       src/libuv_la-strscpy.lo
        CC       src/libuv_la-thread-common.lo
        CC       src/libuv_la-threadpool.lo
        CC       src/libuv_la-timer.lo
        CC       src/libuv_la-uv-data-getter-setters.lo
        CC       src/libuv_la-uv-common.lo
        CC       src/libuv_la-version.lo
        CC       src/libuv_la-strtok.lo
        CC       src/unix/libuv_la-async.lo
        CC       src/unix/libuv_la-core.lo
        CC       src/unix/libuv_la-dl.lo
        CC       src/unix/libuv_la-fs.lo
        CC       src/unix/libuv_la-getaddrinfo.lo
        CC       src/unix/libuv_la-getnameinfo.lo
        CC       src/unix/libuv_la-loop-watcher.lo
        CC       src/unix/libuv_la-loop.lo
        CC       src/unix/libuv_la-pipe.lo
        CC       src/unix/libuv_la-poll.lo
        CC       src/unix/libuv_la-process.lo
        CC       src/unix/libuv_la-random-devurandom.lo
        CC       src/unix/libuv_la-signal.lo
        CC       src/unix/libuv_la-stream.lo
        CC       src/unix/libuv_la-tcp.lo
        CC       src/unix/libuv_la-thread.lo
        CC       src/unix/libuv_la-tty.lo
        CC       src/unix/libuv_la-udp.lo
        CC       src/unix/libuv_la-linux.lo
        CC       src/unix/libuv_la-procfs-exepath.lo
        CC       src/unix/libuv_la-proctitle.lo
        CC       src/unix/libuv_la-random-getrandom.lo
        CC       src/unix/libuv_la-random-sysctl-linux.lo
      src/unix/linux.c: In function ‘uv_cpu_info’:
      src/unix/linux.c:1721:3: warning: ignoring return value of ‘fgets’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
       1721 |   fgets(buf, sizeof(buf), fp);  /* Skip first line. */
            |   ^~~~~~~~~~~~~~~~~~~~~~~~~~~
      src/unix/linux.c:1732:5: warning: ignoring return value of ‘fgets’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
       1732 |     fgets(buf, sizeof(buf), fp);  /* Skip rest of line. */
            |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~
      src/unix/linux.c:1812:5: warning: ignoring return value of ‘fscanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
       1812 |     fscanf(fp, "%llu", &(*cpus)[cpu].freq);
            |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
        CCLD     libuv.la
      building 'uvloop.loop' extension
      creating build/temp.linux-x86_64-cpython-313/uvloop
      x86_64-linux-gnu-gcc -fno-strict-overflow -Wsign-compare -DNDEBUG -g -O2 -Wall -fPIC -I/home/$USER/.venv/include -I/usr/include/python3.13 -I/tmp/pip-install-slevmowb/uvloop_8c41a31f913743168deea4996af77b27/vendor/libuv/include -c uvloop/loop.c -o build/temp.linux-x86_64-cpython-313/uvloop/loop.o -O2
      uvloop/loop.c:860:1: warning: ‘Py_UNICODE’ is deprecated [-Wdeprecated-declarations]
        860 | static CYTHON_INLINE size_t __Pyx_Py_UNICODE_strlen(const Py_UNICODE *u) {
            | ^~~~~~
      uvloop/loop.c: In function ‘__Pyx_Py_UNICODE_strlen’:
      uvloop/loop.c:861:5: warning: ‘Py_UNICODE’ is deprecated [-Wdeprecated-declarations]
        861 |     const Py_UNICODE *u_end = u;
            |     ^~~~~
      uvloop/loop.c: In function ‘__Pyx_init_assertions_enabled’:
      uvloop/loop.c:4446:39: error: implicit declaration of function ‘_PyInterpreterState_GetConfig’; did you mean ‘PyInterpreterState_GetID’? [-Wimplicit-function-declaration]
       4446 |     __pyx_assertions_enabled_flag = ! _PyInterpreterState_GetConfig(__Pyx_PyThreadState_Current->interp)->optimization_level;
            |                                       ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
            |                                       PyInterpreterState_GetID
      uvloop/loop.c:4446:105: error: invalid type argument of ‘->’ (have ‘int’)
       4446 |     __pyx_assertions_enabled_flag = ! _PyInterpreterState_GetConfig(__Pyx_PyThreadState_Current->interp)->optimization_level;
            |                                                                                                         ^~
      uvloop/loop.c: In function ‘__pyx_f_6uvloop_4loop_9UVProcess__after_fork’:
      uvloop/loop.c:110087:5: error: implicit declaration of function ‘_Py_RestoreSignals’ [-Wimplicit-function-declaration]
      110087 |     _Py_RestoreSignals();
             |     ^~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__pyx_pymod_exec_loop’:
      uvloop/loop.c:4637:38: error: implicit declaration of function ‘_PyDict_SetItem_KnownHash’; did you mean ‘_PyDict_GetItem_KnownHash’? [-Wimplicit-function-declaration]
       4637 |     (likely(PyDict_CheckExact(ns)) ? _PyDict_SetItem_KnownHash(ns, name, value, ((PyASCIIObject *) name)->hash) : PyObject_SetItem(ns, name, value))
            |                                      ^~~~~~~~~~~~~~~~~~~~~~~~~
      uvloop/loop.c:170547:7: note: in expansion of macro ‘__Pyx_SetNameInClass’
      170547 |   if (__Pyx_SetNameInClass(__pyx_t_2, __pyx_n_s_init, __pyx_t_6) < 0) __PYX_ERR(0, 3276, __pyx_L1_error)
             |       ^~~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_set_iter_next’:
      uvloop/loop.c:172680:19: error: implicit declaration of function ‘_PySet_NextEntry’ [-Wimplicit-function-declaration]
      172680 |         int ret = _PySet_NextEntry(iter_obj, ppos, value, &hash);
             |                   ^~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyUnicode_Join’:
      uvloop/loop.c:174030:13: error: implicit declaration of function ‘_PyUnicode_FastCopyCharacters’; did you mean ‘PyUnicode_CopyCharacters’? [-Wimplicit-function-declaration]
      174030 |             _PyUnicode_FastCopyCharacters(result_uval, char_pos, uval, 0, ulength);
             |             ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
             |             PyUnicode_CopyCharacters
      uvloop/loop.c: In function ‘__Pyx_PyGen_Send’:
      uvloop/loop.c:174515:13: error: implicit declaration of function ‘_PyGen_SetStopIterationValue’; did you mean ‘__Pyx_PyGen__FetchStopIterationValue’? [-Wimplicit-function-declaration]
      174515 |             _PyGen_SetStopIterationValue(result);
             |             ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
             |             __Pyx_PyGen__FetchStopIterationValue
      uvloop/loop.c: In function ‘__Pyx_Coroutine_AwaitableIterError’:
      uvloop/loop.c:175485:5: error: implicit declaration of function ‘_PyErr_FormatFromCause’ [-Wimplicit-function-declaration]
      175485 |     _PyErr_FormatFromCause(
             |     ^~~~~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyInt_As_int’:
      uvloop/loop.c:177390:27: error: too few arguments to function ‘_PyLong_AsByteArray’
      177390 |                 int ret = _PyLong_AsByteArray((PyLongObject *)v,
             |                           ^~~~~~~~~~~~~~~~~~~
      In file included from /usr/include/python3.13/longobject.h:107,
                       from /usr/include/python3.13/Python.h:81,
                       from uvloop/loop.c:22:
      /usr/include/python3.13/cpython/longobject.h:111:17: note: declared here
        111 | PyAPI_FUNC(int) _PyLong_AsByteArray(PyLongObject* v,
            |                 ^~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyInt_As_uint64_t’:
      uvloop/loop.c:177586:27: error: too few arguments to function ‘_PyLong_AsByteArray’
      177586 |                 int ret = _PyLong_AsByteArray((PyLongObject *)v,
             |                           ^~~~~~~~~~~~~~~~~~~
      /usr/include/python3.13/cpython/longobject.h:111:17: note: declared here
        111 | PyAPI_FUNC(int) _PyLong_AsByteArray(PyLongObject* v,
            |                 ^~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyInt_As_long’:
      uvloop/loop.c:177820:27: error: too few arguments to function ‘_PyLong_AsByteArray’
      177820 |                 int ret = _PyLong_AsByteArray((PyLongObject *)v,
             |                           ^~~~~~~~~~~~~~~~~~~
      /usr/include/python3.13/cpython/longobject.h:111:17: note: declared here
        111 | PyAPI_FUNC(int) _PyLong_AsByteArray(PyLongObject* v,
            |                 ^~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyInt_As_unsigned_long’:
      uvloop/loop.c:178092:27: error: too few arguments to function ‘_PyLong_AsByteArray’
      178092 |                 int ret = _PyLong_AsByteArray((PyLongObject *)v,
             |                           ^~~~~~~~~~~~~~~~~~~
      /usr/include/python3.13/cpython/longobject.h:111:17: note: declared here
        111 | PyAPI_FUNC(int) _PyLong_AsByteArray(PyLongObject* v,
            |                 ^~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyInt_As_unsigned_int’:
      uvloop/loop.c:178288:27: error: too few arguments to function ‘_PyLong_AsByteArray’
      178288 |                 int ret = _PyLong_AsByteArray((PyLongObject *)v,
             |                           ^~~~~~~~~~~~~~~~~~~
      /usr/include/python3.13/cpython/longobject.h:111:17: note: declared here
        111 | PyAPI_FUNC(int) _PyLong_AsByteArray(PyLongObject* v,
            |                 ^~~~~~~~~~~~~~~~~~~
      uvloop/loop.c: In function ‘__Pyx_PyInt_As_size_t’:
      uvloop/loop.c:178560:27: error: too few arguments to function ‘_PyLong_AsByteArray’
      178560 |                 int ret = _PyLong_AsByteArray((PyLongObject *)v,
             |                           ^~~~~~~~~~~~~~~~~~~
      /usr/include/python3.13/cpython/longobject.h:111:17: note: declared here
        111 | PyAPI_FUNC(int) _PyLong_AsByteArray(PyLongObject* v,
            |                 ^~~~~~~~~~~~~~~~~~~
      error: command '/usr/bin/x86_64-linux-gnu-gcc' failed with exit code 1
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
  ERROR: Failed building wheel for uvloop
Failed to build uvloop
ERROR: Failed to build installable wheels for some pyproject.toml based projects (uvloop)

gfl43r9nd avatar Apr 29 '25 14:04 gfl43r9nd

Many have had issues using python 3.13.x with ofscraper so it is not recommended to be used. the current python version that is the most stable for ofscraper is python 3.11.6.

cjb900 avatar Apr 29 '25 14:04 cjb900

Yeah I haven't tried to install on python 3.13

You should be able to install with a older python version with the deadsnakes repo, and then you can use something like uv

https://docs.astral.sh/uv/getting-started/installation/

with something like

uv tools install --python 3.l2 ofscraper 

datawhores avatar May 30 '25 13:05 datawhores

I'm closing this now Please open a new issue if needed

datawhores avatar May 30 '25 13:05 datawhores

Shouldn't this remain open until this script wroks with the latest versions of python?

gfl43r9nd avatar Sep 19 '25 17:09 gfl43r9nd