pkgsrc-Changes archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

CVS commit: pkgsrc/devel/py-mercurial



Module Name:    pkgsrc
Committed By:   wiz
Date:           Wed Dec 11 23:27:34 UTC 2024

Modified Files:
        pkgsrc/devel/py-mercurial: Makefile PLIST distinfo version.mk
Removed Files:
        pkgsrc/devel/py-mercurial/patches: patch-hgdemandimport_____init____.py
            patch-mercurial_bundle2.py patch-mercurial_exchange.py
            patch-mercurial_obsolete.py patch-mercurial_obsutil.py

Log Message:
py-mercurial: update to 6.9.

Update test status, two fixed, but a new core dump in test-locale.t, see
https://bz.mercurial-scm.org/show_bug.cgi?id=6948

Backwards Compatibility Changes

    This release drops support for Python 3.6 and 3.7.

    Starting with this release and hopefully for the forseeable
    future, we are now building wheels for most architectures.

    Python 3.13 changed how it handles docstrings (namely removing
    uniform leading whitespace for every line), which forced us to
    align the representation of our help text with this new behavior
    across all versions. Due to this and a lack of time and expertise
    from contributors, a lot of existing translations could be
    missing. The effort of i18n in general has died down many years
    ago, but if this matters to you, feel free to send your
    contributions.

New Features

    exchange: improve computation of relevant markers for large repos
    Add a Rust fast-path to speed up update (also for clone) from null (up to 4x faster)
    Introduced a new rev-branch-cache version (v2) that is mmap-resistant
    The branchmap's performance was improved
    Improved the performance of the fix for issue6528
    clonebundles: allow manifest to specify sha256 digest of bundles
    merge: improve working-copy mtime race handling
    profiling: add a py-spy profiling backend
    revlog: use an explicit config option to enable mmap usage for index
    revlog: use mmap by default is pre-population is available
    mmap: populate the mapping by default
    mmap: populate mapping in a background thread

Experimental features

    merge: add a config to allow conflict-free merge of changes on adjacent lines

Bug Fixes
    config.server.validate now also works on narrowed repositories
    convert: fix various leaked file descriptors
    stream: prefer keeping an open file handle to volatile file instead of copy
    dummysmtpd: fix EOF handling on newer versions of OpenSSL
    cext: correct the argument handling of b85encode()
    branchmap-v3: make sure we write the cache after detecting pure-topo mode
    rust: apply clippy lints
    copies: make sure deleted copy info do not overwriting unrelated ones
    rebase: don't call rewriteutil.precheck() with to-be-skipped commits
    phabricator: correct the default value of phabhunk.corpus
    linelog: correct the default value of annotateresult.lines
    largefiles: avoid a potentially undefined variable in exception case
    httppeer: move a variable to avoid a bad reference before assignment warning
    httppeer: avoid another bad reference before assignment warning
    tests: use packaging from setuptools instead of deprecated distutils
    manifest: type and fix unhexlify
    manifest: align some vfs option access on the fact we might not have options
    scmutils: read the requires file before writing to avoid unnecessary rewrite
    debugsparse: stop taking the store lock
    sparse: reliably avoid writing to store without a lock
    largefiles: sync up largefilesdirstate methods with dirstate base class
    shelve: raise an error when loading a corrupt state file in an impossible case
    monotone: replace %s interpolation with appropriate numeric specifiers
    shelve: consistently convert exception to bytes via stringutil.forcebytestr
    remotefilelog: honor the --format arg of the debugindex command
    remotefilelog: adapt the debugindex command to past API changes
    run-tests: add color to the progress output
    archive: defer opening the output until a file is matched
    help: add :config-doc:section.key shorthand to insert documentation
    censor: document the censor.policy option (issue6909)
    rust-revlog: don't try to open the data file if the index is empty
    bundlerepo: fix mismatches with repository and revlog classes
    revlog: make clearcaches() signature consistent with ManifestRevlog
    unionrepo: fix mismatches with revlog classes
    keepalive: fix a signature mismatch for a http.client.HTTPResponse subclass
    lfs: fix various signature mismatches for vfs subclasses
    store: fix a signature mismatch for a vfs subclass
    util: avoid a leaked file descriptor in util.makelock() exceptional case
    statichttprepo: fix httprangereader.read() for py3
    util: make mmapread() work on Windows again
    mdiff: tweak calls into bdiff.fixws to match its type hints
    base85: avoid a spurious use-before-initialized warning in pure module
    install: static data moved from setup.py to pyproject.toml
    upgrade: disable using the parallel workers optimization on macOS
    doc: generate separate commands/topics/extension pages
    extdiff: don't run gui programs when in a cli-only environment
    clonebundles: stop shell quoting HGCB_BUNDLE_BASENAME environment variable
    streamclone: disable the volatile file open handle optimization on Windows
    pytype: add relative timestamp to the output if ts is available
    hgweb: skip logging ConnectionAbortedError

Internal API Changes

    manifest: deprecated readdelta and readfast

Miscellaneous

    http: reuse Python's implementation of read/readline/readinto
    http: use urllib's cookie handler
    rev-branch-cache: schedule a write of the "v2" format if we read from "v1"
    rev-branch-cache: have debugupdatecache warm rbc too
    rev-branch-cache: reenable memory mapping of the revision data
    debugwireproto: redo logging to also work for https
    rust: use .cargo/config.toml instead of .cargo/config
    A whole bunch of typing improvements, which in turn found many bugs
    Test suite improvements
    Various packaging improvements

Below are many, many changes that have to do with building/testing wheels, adding some sharding to the CI and MacOS + Windows compatibility work:

    ci: abstract the branch matching regexp
    ci: add "sink" for parallel tests
    ci: for branches, use a single trigger
    packaging: explain why we purge while building wheels
    wheels: rely on the image config to be able to access the repository
    packaging: remove the i686 wheel from the linux-wheels target
    packaging: propagate the make option to packaging target
    packaging: factor the linux-wheels-x86_64 a bit
    wheel: add a target for amdx86_64-musl wheels
    wheel: also build the musl wheel in the ci
    wheel: reintroduce the building of i686 wheel
    wheels: also build the i686 wheel in the CI
    contrib: install the arm64 compiler tools in the Windows dependency script
    contrib: add a bat file to build all of the wheels on Windows
    wheels: remove deprecated blacklist
    wheels: make sure we create the dist/ directory in the make target
    contrib: add a script to build all of the wheels on macOS
    wheel: also build wheel for linux arm64 in the CI
    ci: add sink for wheels too
    run-tests: don't use shell call for subprocess
    run-tests: add a --hg-wheel options to test a pre-built wheel
    ci: unify the way check-pytype inherit the common setting
    ci: split the jobs on more stage
    ci: build a wheel and use it to run c tests
    tests: stabilize test-extdiff.t on macOS
    tests: disable test-git-interop.t with a requirements directive
    tests: disable a section of test-hgrc.t that may hit a zeroconf bug
    ci: add a runner for Windows 10
    tests: treat select as a built-in module on Windows
    tests: disable a section of test-paths.t that may hit a zeroconf bug
    tests: conditionalize missing output in test-racy-mutations.t on Windows
    tests: add a "missing" tests for manifest content in test-racy-mutations.t
    tests: bump the wait timeouts in test-racy-mutations.t
    test-install: use the global hg for the install step
    test-install: glob instance of "python" in warning
    ci: pre-adjust some identation
    setup: add a way to force the setup to translate (or fail)
    ci: use smaller VM to build wheel
    ci: use a pre-setup many-linux image to build wheel
    ci: build (and use) wheel for all supported version
    ci: automatically compute the python tag we use to identify tag
    run-tests: install wheel using --prefix instead of --user
    pycompat: drop some now useless workaround for makedirs
    wheel: build mac os wheel through the CI
    ci: use the macos wheel to run tests
    ci: use extends instead of <<: *x
    ci: move some variables closer to their usage
    ci: rationalize variable usage
    ci: abstract the of absolute /tmp/ path
    ci: move the "tempory work dir" to "concurrency-safe" location
    ci: adjust the starting port range to runner concurrency
    ci: have the mac test run if you trigger building the mac wheel
    run-tests: implement crude sharding support
    ci: shard the test run on mac os X
    dev-version: change the scheme of non tagged version
    wheel: enforce that translation being build for macos wheel
    run-tests: focus on listing the selected test for the shard tests
    run-tests: cleanup the "output" directory after the related tests
    tests: drop PYTHONPATH manipulation in test-pushvars.t
    windows: work around argument size limitation in test-bookmarks-pushpull.t
    windows: adjust PYTHONPATH update in test-status-color.t
    ci: use a concurrency safe TMP dir on Windows
    ci: again common element into a .windows template
    ci: split the windows runtest invocation into more granular variables
    windows: skip test-clonebundles-autogen.t in the CI
    ci: adjust port range on windows too
    windows: simply rely on the PATH adjustment to find python.exe in tests
    wheel: assign CIBW_SKIP globally
    wheel: make --hg-wheel works on Windows
    wheel: build Windows wheels too
    wheel: explicitly list built architecture
    wheel: test the built wheel in the windows tests
    ci: shard the tests on windows too
    wheel: enforce that translation being build for windows wheel
    setup: remote a debug statement that slipped through
    setup: factor version computation in a function
    setup: use the same code to compute tag from archive
    wheel: add a platform level to the wheel directories
    wheel: add a job uploading nightly build
    wheels: factor the core of Linux wheel building into a script
    wheels: update the Linux wheels make target
    clone: properly exclude rev-branch-cache from post clone cache warming
    setup: make sure Rust build its extension for the right python
    setup: preserve version part after the "+" on Windows
    wheel: build windows wheel for ARM64 too
    ci: adds a trigger for all pycompat jobs
    ci: let the Windows runner decide how many job they want to run


To generate a diff of this commit:
cvs rdiff -u -r1.101 -r1.102 pkgsrc/devel/py-mercurial/Makefile
cvs rdiff -u -r1.48 -r1.49 pkgsrc/devel/py-mercurial/PLIST
cvs rdiff -u -r1.151 -r1.152 pkgsrc/devel/py-mercurial/distinfo
cvs rdiff -u -r1.63 -r1.64 pkgsrc/devel/py-mercurial/version.mk
cvs rdiff -u -r1.1 -r0 \
    pkgsrc/devel/py-mercurial/patches/patch-hgdemandimport_____init____.py \
    pkgsrc/devel/py-mercurial/patches/patch-mercurial_exchange.py \
    pkgsrc/devel/py-mercurial/patches/patch-mercurial_obsutil.py
cvs rdiff -u -r1.3 -r0 \
    pkgsrc/devel/py-mercurial/patches/patch-mercurial_bundle2.py
cvs rdiff -u -r1.2 -r0 \
    pkgsrc/devel/py-mercurial/patches/patch-mercurial_obsolete.py

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: pkgsrc/devel/py-mercurial/Makefile
diff -u pkgsrc/devel/py-mercurial/Makefile:1.101 pkgsrc/devel/py-mercurial/Makefile:1.102
--- pkgsrc/devel/py-mercurial/Makefile:1.101    Mon Nov 11 07:28:16 2024
+++ pkgsrc/devel/py-mercurial/Makefile  Wed Dec 11 23:27:33 2024
@@ -1,10 +1,9 @@
-# $NetBSD: Makefile,v 1.101 2024/11/11 07:28:16 wiz Exp $
+# $NetBSD: Makefile,v 1.102 2024/12/11 23:27:33 wiz Exp $
 #
 # Changelog sometimes at: https://www.mercurial-scm.org/wiki/WhatsNew
 
 DISTNAME=      mercurial-${VERSION}
 PKGNAME=       ${PYPKGPREFIX}-${DISTNAME}
-PKGREVISION=   1
 CATEGORIES=    devel scm
 MASTER_SITES=  https://www.mercurial-scm.org/release/
 
@@ -23,20 +22,17 @@ LDFLAGS.SunOS+=             -lsocket
 INSTALLATION_DIRS=     bin ${PKGMANDIR}/man1 ${PKGMANDIR}/man5
 INSTALLATION_DIRS+=    share/doc/mercurial
 
-PYTHON_VERSIONS_INCOMPATIBLE=  27
 PYTHON_SELF_CONFLICT=          yes
 
 .include "version.mk"
 
 USE_TOOLS+=            bash:test
-# Test status as of 6.8.1
-# Ran 941 tests, 83 skipped, 3 failed.
-# test-lfs-serve-access.t
-# https://bz.mercurial-scm.org/show_bug.cgi?id=6898
-# test-profile.t
-# https://bz.mercurial-scm.org/show_bug.cgi?id=6846
+# Test status as of 6.9
+# Ran 943 tests, 81 skipped, 2 failed.
 # test-revlog-mmapindex.t
 # https://bz.mercurial-scm.org/show_bug.cgi?id=6899
+# test-locale.t
+# https://bz.mercurial-scm.org/show_bug.cgi?id=6948
 
 TEST_TARGET=           tests
 TEST_MAKE_FLAGS+=      PYTHON=${PYTHONBIN} TESTFLAGS=${_MAKE_JOBS:Q}

Index: pkgsrc/devel/py-mercurial/PLIST
diff -u pkgsrc/devel/py-mercurial/PLIST:1.48 pkgsrc/devel/py-mercurial/PLIST:1.49
--- pkgsrc/devel/py-mercurial/PLIST:1.48        Thu Jun 20 23:55:54 2024
+++ pkgsrc/devel/py-mercurial/PLIST     Wed Dec 11 23:27:33 2024
@@ -1,4 +1,4 @@
-@comment $NetBSD: PLIST,v 1.48 2024/06/20 23:55:54 joerg Exp $
+@comment $NetBSD: PLIST,v 1.49 2024/12/11 23:27:33 wiz Exp $
 bin/chg
 bin/hg
 ${PYSITELIB}/hgdemandimport/__init__.py
@@ -478,6 +478,12 @@ ${PYSITELIB}/mercurial/archival.pyo
 ${PYSITELIB}/mercurial/bookmarks.py
 ${PYSITELIB}/mercurial/bookmarks.pyc
 ${PYSITELIB}/mercurial/bookmarks.pyo
+${PYSITELIB}/mercurial/branching/__init__.py
+${PYSITELIB}/mercurial/branching/__init__.pyc
+${PYSITELIB}/mercurial/branching/__init__.pyo
+${PYSITELIB}/mercurial/branching/rev_cache.py
+${PYSITELIB}/mercurial/branching/rev_cache.pyc
+${PYSITELIB}/mercurial/branching/rev_cache.pyo
 ${PYSITELIB}/mercurial/branchmap.py
 ${PYSITELIB}/mercurial/branchmap.pyc
 ${PYSITELIB}/mercurial/branchmap.pyo
@@ -756,6 +762,9 @@ ${PYSITELIB}/mercurial/interfaces/__init
 ${PYSITELIB}/mercurial/interfaces/dirstate.py
 ${PYSITELIB}/mercurial/interfaces/dirstate.pyc
 ${PYSITELIB}/mercurial/interfaces/dirstate.pyo
+${PYSITELIB}/mercurial/interfaces/modules.py
+${PYSITELIB}/mercurial/interfaces/modules.pyc
+${PYSITELIB}/mercurial/interfaces/modules.pyo
 ${PYSITELIB}/mercurial/interfaces/repository.py
 ${PYSITELIB}/mercurial/interfaces/repository.pyc
 ${PYSITELIB}/mercurial/interfaces/repository.pyo
@@ -1254,6 +1263,9 @@ ${PYSITELIB}/mercurial/templateutil.pyo
 ${PYSITELIB}/mercurial/testing/__init__.py
 ${PYSITELIB}/mercurial/testing/__init__.pyc
 ${PYSITELIB}/mercurial/testing/__init__.pyo
+${PYSITELIB}/mercurial/testing/ps_util.py
+${PYSITELIB}/mercurial/testing/ps_util.pyc
+${PYSITELIB}/mercurial/testing/ps_util.pyo
 ${PYSITELIB}/mercurial/testing/revlog.py
 ${PYSITELIB}/mercurial/testing/revlog.pyc
 ${PYSITELIB}/mercurial/testing/revlog.pyo

Index: pkgsrc/devel/py-mercurial/distinfo
diff -u pkgsrc/devel/py-mercurial/distinfo:1.151 pkgsrc/devel/py-mercurial/distinfo:1.152
--- pkgsrc/devel/py-mercurial/distinfo:1.151    Thu Oct 24 10:41:05 2024
+++ pkgsrc/devel/py-mercurial/distinfo  Wed Dec 11 23:27:33 2024
@@ -1,11 +1,6 @@
-$NetBSD: distinfo,v 1.151 2024/10/24 10:41:05 wiz Exp $
+$NetBSD: distinfo,v 1.152 2024/12/11 23:27:33 wiz Exp $
 
-BLAKE2s (mercurial-6.8.1.tar.gz) = 32f4581344c7ce0a93f76ab4e85ad0d1974fb8059f248d42474d87d2714ebf16
-SHA512 (mercurial-6.8.1.tar.gz) = c638b9c5421320dcae966c7526afcd7743afaa48f72d4202a9b85a68f51ee97755321e75858e128cdb21cc17312701d2481d10a8a8e2f882ec0df189fc1fd194
-Size (mercurial-6.8.1.tar.gz) = 8324749 bytes
-SHA1 (patch-hgdemandimport_____init____.py) = 1d93d06bb71ef07c2b9d866d49bfec7258ac9d56
-SHA1 (patch-mercurial_bundle2.py) = f4612a08effe11fb4b345ea213a148f6fba7118d
-SHA1 (patch-mercurial_exchange.py) = af7ac4719d74d1de731250fe8f5443931e7a15a9
-SHA1 (patch-mercurial_obsolete.py) = 5365f9dab99f68846c4defe1fda8c003248cdcfc
-SHA1 (patch-mercurial_obsutil.py) = 42b29c87b962e5e20d8c7bc7bfd5d3df1c33dab2
+BLAKE2s (mercurial-6.9.tar.gz) = 1d046c1e305ec3525c4146d7e24491c643cea7062bcada9ac4f1a0d5966393e8
+SHA512 (mercurial-6.9.tar.gz) = e3025c9c4352c984dfeb0c8eca740684788e77104287f20b005343054b7135dc1ccd1ef258c749d9a6c9e8127bef0e1c12504b161822899d6359414652432935
+Size (mercurial-6.9.tar.gz) = 8662295 bytes
 SHA1 (patch-setup.py) = 2f5e1f619af50cc0976ce6b229e4ce9cc3492c29

Index: pkgsrc/devel/py-mercurial/version.mk
diff -u pkgsrc/devel/py-mercurial/version.mk:1.63 pkgsrc/devel/py-mercurial/version.mk:1.64
--- pkgsrc/devel/py-mercurial/version.mk:1.63   Thu Aug  8 08:11:10 2024
+++ pkgsrc/devel/py-mercurial/version.mk        Wed Dec 11 23:27:33 2024
@@ -1,3 +1,3 @@
-# $NetBSD: version.mk,v 1.63 2024/08/08 08:11:10 wiz Exp $
+# $NetBSD: version.mk,v 1.64 2024/12/11 23:27:33 wiz Exp $
 
-VERSION=       6.8.1
+VERSION=       6.9



Home | Main Index | Thread Index | Old Index