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

refactor Base.GMP.MPZ.import! to be consistent with Base.GMP.MPZ.export! #56903

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

NegaScout
Copy link
Contributor

@NegaScout NegaScout commented Dec 24, 2024

rename Base.GMP.MPZ.export! "dynamic" variable from a to x, since it is more in line with comment on L141 in base/gmp.jl

julia/base/gmp.jl

Lines 141 to 146 in cab11bb

# wrapping of libgmp functions
# - "output parameters" are labeled x, y, z, and are returned when appropriate
# - constant input parameters are labeled a, b, c
# - a method modifying its input has a "!" appended to its name, according to Julia's conventions
# - some convenient methods are added (in addition to the pure MPZ ones), e.g. `add(a, b) = add!(BigInt(), a, b)`
# and `add!(x, a) = add!(x, x, a)`.

add tests, that numbers and vectors can be exported and imported correctly and composed import and export is identity

@giordano giordano added the bignums BigInt and BigFloat label Dec 24, 2024
@LilithHafner
Copy link
Member

Thanks!

AFAICT, import! is an internal function that is neither used nor tested. Perhaps it should be removed? As of 6d71254, this PR makes a breaking change to import! so if we run pkgeval we should be able to tell if anyone depends on this internal function. export! is used once and untested so adding tests for it is very nice.

This invokes pkgeval: @nanosoldier runtests()

@NegaScout
Copy link
Contributor Author

NegaScout commented Dec 24, 2024

Oh, I wanted to run some kind of grep at least, if it is used somewhere, but I forgot. Sorry. However, this functionality is very handy for "interpreting memory as number". I am not sure if there is more use cases. However it would be nice for any serious RSA implementation (and ElGamal at least I think, possibly more cryptographic schemes), which needs to interpret memory as a number to sign it or encrypt/decrypt it.

I would like to see movement in the opposite direction and would like to see more support for this. Otherwise, some iteration based construction for this use case would be needed, unless some Julia native BigInt type is present in Base.

I also think, any big number serialization/deserialization would benefit from this.

However, I can implement any proposed changes or feel free to close this, if it is not desired change

@giordano
Copy link
Contributor

giordano commented Dec 24, 2024

No uses outside of Base according to https://juliahub.com/ui/Search?type=symbols&q=import!

@nanosoldier
Copy link
Collaborator

The package evaluation job you requested has completed - possible new issues were detected.
The full report is available.

@LilithHafner
Copy link
Member

LilithHafner commented Dec 26, 2024

Generally, I lean toward avoiding new public API unless there is a very compelling case. The fact that nobody has used this internal function all this time makes me doubt that it is valuable commonly enough to warrant including in the public API. For those reasons, I prefer deleting insert! rather than publicizing it.

That said, it would be nice to hear other folks' opinions on whether we should keep/publicize/remove Base.GMP.MPZ.import!.

Let's talk about it at the next triage meeting Thursday at 1:15 ET.

@LilithHafner LilithHafner added the triage This should be discussed on a triage call label Dec 26, 2024
@LilithHafner
Copy link
Member

Triage talked about this and considered weather we want to provide a user facing wrapper of MPZ or if we just want to keep these internal and use only what we need to implement BigInts and other Base functions. Making a good user-facing wrapper of MPZ would be fairly large and we don't want to put that in Base. Instead, it makes more sense for a fully featured MPZ wrapper to exist as a package (open invitation to anyone who wants to create that package :) ). Making import! public without also making many more functions public wouldn't really make sense.

For import!, specifically, it makes sense to delete the function from Base because we're not using it and don't want to add it to the public API.

@LilithHafner LilithHafner removed the triage This should be discussed on a triage call label Jan 2, 2025
@NegaScout
Copy link
Contributor Author

NegaScout commented Jan 2, 2025

Ok, fair. It makes sense since there is still much in MPZ that would be cool to have in Julia but does not have bindings. So, lets rebase it and keep only the test and argument rename?

@LilithHafner
Copy link
Member

It would also be good to move the definition of import! from base/ to test/

rename Base.GMP.MPZ.export! "dynamic" variable from `a`	to `x`,	since it is more in line with comment on L141 in base/gmp.jl

add tests, that	numbers and vectors can be exported and imported correctly and composed import and export is identity
@NegaScout
Copy link
Contributor Author

Not sure, if this is how you meant to move the definition from base to tests. However I could not define Base_GMP_MPZ_import as Base.GMP.MPZ.import! in the test, not sure why 🤔

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bignums BigInt and BigFloat
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants