Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

pypdfium2 on S390x (ubuntu22.04) #313

Closed
2 tasks done
sandeepb2013 opened this issue May 3, 2024 · 6 comments
Closed
2 tasks done

pypdfium2 on S390x (ubuntu22.04) #313

sandeepb2013 opened this issue May 3, 2024 · 6 comments

Comments

@sandeepb2013
Copy link

sandeepb2013 commented May 3, 2024

Checklist

  • I confirm to be using an official package of pypdfium2 from PyPI or GitHub/pypdfium2-team.

Description

Collecting pypdfium2==0.7.0
  Downloading pypdfium2-0.7.0.tar.gz (283 kB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 283.0/283.0 kB 5.7 MB/s eta 0:00:00
  Preparing metadata (setup.py) ... error
  error: subprocess-exited-with-error

  × python setup.py egg_info did not run successfully.
  │ exit code: 1
  ╰─> [51 lines of output]
      Cloning into '/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools'...
      Checking patch gclient_scm.py...
      error: while searching for:
            # to stdout
            self.Print('')
          cfg = gclient_utils.DefaultIndexPackConfig(url)
          clone_cmd = cfg + ['clone', '--no-checkout', '--progress']
          if self.cache_dir:
            clone_cmd.append('--shared')
          if options.verbose:

      error: patch failed: gclient_scm.py:1005
      error: gclient_scm.py: patch does not apply
      Errors:
        failed to resolve infra/3pp/tools/git/linux-s390x@version:[email protected] (line 24): no such package: infra/3pp/tools/git/linux-s390x
        failed to resolve infra/3pp/tools/cpython3/linux-s390x@version:[email protected] (line 21): no such package: infra/3pp/tools/cpython3/linux-s390x
      /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools/bootstrap_python3: line 32: [email protected]_bin/python3/bin/python3: No such file or directory
      Bundled Python 3.11 not found. Use VPYTHON_BYPASS if prebuilt cpython not available on this platform: open /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools/.cipd_bin/.cipd/pkgs/0/Q0Cp0RrnNtgKaxaeq4XKs9qiPu1botnPjuw_0EWxduUC/3.11/.versions/cpython3.cipd_version: no such file or directory
      Errors:
        failed to resolve infra/3pp/tools/git/linux-s390x@version:[email protected] (line 24): no such package: infra/3pp/tools/git/linux-s390x
        failed to resolve infra/3pp/tools/cpython3/linux-s390x@version:[email protected] (line 21): no such package: infra/3pp/tools/cpython3/linux-s390x
      /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools/bootstrap_python3: line 32: [email protected]_bin/python3/bin/python3: No such file or directory
      Bundled Python 3.11 not found. Use VPYTHON_BYPASS if prebuilt cpython not available on this platform: open /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools/.cipd_bin/.cipd/pkgs/0/Q0Cp0RrnNtgKaxaeq4XKs9qiPu1botnPjuw_0EWxduUC/3.11/.versions/cpython3.cipd_version: no such file or directory
      Traceback (most recent call last):
        File "<string>", line 2, in <module>
        File "<pip-setuptools-caller>", line 34, in <module>
        File "/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/setup.py", line 19, in <module>
          build_pdfium.main(DefaultArgs)
        File "/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/build_pdfium.py", line 275, in main
          patch_pdfium()
        File "/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/build_pdfium.py", line 132, in patch_pdfium
          _apply_patchset(PdfiumPatches, PDFiumDir)
        File "/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/build_pdfium.py", line 126, in _apply_patchset
          run_cmd(f"git apply -v {patch}", cwd=cwd)
        File "/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/build_pdfium.py", line 75, in run_cmd
          subprocess.run(command, cwd=cwd, shell=True)
        File "/usr/lib/python3.10/subprocess.py", line 503, in run
          with Popen(*popenargs, **kwargs) as process:
        File "/usr/lib/python3.10/subprocess.py", line 971, in __init__
          self._execute_child(args, executable, preexec_fn, close_fds,
        File "/usr/lib/python3.10/subprocess.py", line 1863, in _execute_child
          raise child_exception_type(errno_num, err_msg, err_filename)
      FileNotFoundError: [Errno 2] No such file or directory: '/tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/pdfium'
      Using DepotTools-provided binaries.
      DepotTools: Download ...
      git clone --depth 1 https://chromium.googlesource.com/chromium/tools/depot_tools.git /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools
      git apply -v /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/patches/gclient_scm.patch
      PDFium: Download ...
      /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools/gclient config --unmanaged https://pdfium.googlesource.com/pdfium.git
      /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/depot_tools/gclient sync --no-history --shallow
      git apply -v /tmp/pip-install-7pg5yzok/pypdfium2_4b1a7bde13d04c959f78c22011e153e6/sourcebuild/patches/public_headers.patch
      [end of output]

  note: This error originates from a subprocess, and is likely not a problem with pip.
error: metadata-generation-failed

Install Info

Python 3.10.12 (main, Nov 20 2023, 15:14:05) [GCC 11.4.0]
Linux-6.6.2-s390x-with-glibc2.35
WARNING: Package(s) not found: pypdfium2

Validity

  • I confirm that I ran all commands, and pasted the whole output.
@mara004
Copy link
Member

mara004 commented May 3, 2024

That is expected; our binary provider doesn't currently build for S390x.
But you can head over to https://github.com/bblanchon/pdfium-binaries/issues and ask the author whether he's willing to add support for S390x, then I could incorporate it in pypdfium2.

AFAIK, S390x is somewhat uncommon in the PyPI world, though. Not even pillow or pikepdf build for it.
You might have more luck on Anaconda (S390x is in their default build matrix), but they don't really provide (py)pdfium, aside from a feedstock that repacks the pdfium-binaries.

Otherwise, you could try to build pdfium from source (I don't know whether Google's toolchain supports S390x as build host). But you should use a recent version of pypdfium2 for that, not 0.7.0 (who depends on that old version, I wonder?).

@mara004
Copy link
Member

mara004 commented May 3, 2024

Another hint: If you have libreoffice, you might be able to simply use the pdfium binary it ships with.
For me that is /usr/lib/libreoffice/program/libpdfiumlo.so. Just symlink to /usr/local/lib/libpdfium.so or something, determine the pdfium version, and then install with system-provided binary.

@mara004
Copy link
Member

mara004 commented May 5, 2024

Regarding the failure of implicit sourcebuild, this seems to be due to outdated patches. I can see it's a bit problematic we're using latest pdfium with potentially non-latest patches.

Newer versions do not trigger an implicit sourcebuild anymore if no binary was found. I think it's better for callers to consciously invoke the build process if desired.

@sandeepb2013
Copy link
Author

Hi @mara004 ,

Thanks for quick response.
bblanchon/pdfium-binaries#93.
`Possible values

  • "x86"
  • "x64"
  • "arm"
  • "arm64"
  • "mipsel"
  • "mips64el"
  • "s390x"
  • "ppc64"
  • "riscv32"
  • "riscv64"
  • "e2k"
  • "loong64"`

@mara004
Copy link
Member

mara004 commented May 7, 2024

Yes, these are the architectures listed by the toolchain's help, and s390x is among them.
But what do you want to express with that? Again, as for adding a binary package, you'd have to discuss that with upstream. The binaries aren't built here, just repacked with a python wrapper.

@mara004
Copy link
Member

mara004 commented May 14, 2024

Closing; further actions are up to affected users, pdfium-binaries and pdfium.

@mara004 mara004 closed this as not planned Won't fix, can't repro, duplicate, stale May 14, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants