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

core library support #37

Open
25 of 48 tasks
cdepillabout opened this issue Dec 9, 2021 · 3 comments
Open
25 of 48 tasks

core library support #37

cdepillabout opened this issue Dec 9, 2021 · 3 comments
Labels
enhancement New feature or request good first issue Good for newcomers help wanted Extra attention is needed

Comments

@cdepillabout
Copy link
Member

cdepillabout commented Dec 9, 2021

This issue is to track which core libraries have been ported to PureNix.

Done

These are libraries that have already been ported.

Todo

These are libraries that still need to be ported.

Won't Do / Can't Do

These are libraries that either can't be ported to PureNix, or don't make sense to port to PureNix.

  • assert

    Nix does have an assert statement, but I'm not sure it would be able to be used with a similar API to purescript-assert. Creating a purescript-nix-assert library would likely be better.

  • console

    Nix doesn't have any way of writing arbitrary text to the console. There is the builtins.trace Nix function, but that could be wrapped up in it's own library.

  • docs-search

    I'm not sure what this is or how it would be related to PureNix.

  • effect

    Nix doesn't have any way of doing arbitrary effects. In theory, we could have an Effect type for compatibility, but in practice we wouldn't be able to do anything interesting with it.

    edit: There was a little discussion in Add miraculix testing library temp-package-set#1 as to whether or not purescript-effect would make sense for PureNix. There are a couple good points in favor of having purescript-effect.

  • exceptions

    Nix doesn't really have exceptions the same way JavaScript does. Nix does have the builtins.abort, assert, and builtins.tryEval functions, which may be able to be wrapped up in a nice library.

  • gen

    See the problem with random.

  • minibench

    I don't think Nix has any way of getting the current time (or at least to any precision that would be necessary for benchmarking).

  • parallel

    Nix doesn't have any built-in way of running computations in parallel. It is possible we could support this same API in PureNix for compatibility, but it is likely we would only be able to run the computations sequentially.

  • quickcheck

    See the problem with random.

  • random

    As far as I know, Nix doesn't have any sort of random number generator. There is no way to generate random numbers.

    edit: Thinking about this a little more, we could have purescript-random be a pseudorandom number generator (PRNG). All the random functions could just take a seed that has to be passed in. The seed would be the initial seed for the PRNG. This could be useful for people that are willing to pass in a random seed when calling nix-build. This seems like a reasonable way to use libraries like purescript-random, purescript-gen, and purescript-quickcheck.

  • refs

    Nix doesn't have any way of mutating values, so refs are not possible.

  • tailrec

    Nix is lazy, so this sort of trampolining isn't necessary.

@cdepillabout cdepillabout added enhancement New feature or request good first issue Good for newcomers help wanted Extra attention is needed labels Dec 9, 2021
@cdepillabout
Copy link
Member Author

cdepillabout commented Dec 9, 2021

A couple comments:

  • If you'd like to help with this, please leave a message and we can get you setup with a repo for doing the porting.

  • In my experience, the most time-consuming part of this is writing the FFI. For instance, purescript-arrays has a lot of FFI, and that took a long time to port. But packages like purescript-newtype have no FFI, and that basically takes no time to port.

  • It is quite common for libraries to have dependencies on things like purescript-effect (for MonadEffect), or purescript-tailrec (for MonadRec). These type of dependencies and instances can mostly be ignored and deleted from the ported-code, since they aren't used in PureNix.

  • Once you're ported a library, make sure to add it to the temporary package set. (Or possibly whatever we decide to do with create a real package set #36.)

  • I wrote a script for automating some of the manual work when porting a PureScript package (basically cloning the repo, creating a new repo in purenix-org, updating the package set, etc): https://github.com/cdepillabout/port-purescript-package. It is unlikely someone else would be able to use this as-is, but it might help get an idea of what needs to be done.

@martyall
Copy link

martyall commented Aug 5, 2022

I'm interested in giving one of these a shot, whichever you think is in the intersection of most useful and straight-forward. Any suggestions ?

@cdepillabout
Copy link
Member Author

@martyall We recently released a newer version of purenix that is based on PureScript-0.15 (instead of 0.14): #51 and #53.

However, we never went back and updated all the actual PureNix PureScript libraries to be based on the versions that are used for the actual PureScript-0.15 package set. All of our current PureNix libraries are based on PureScript libraries that are used with PureScript-0.14. I'm actually pretty surprised that the Quick Start instructions still work even when you use a 0.15 version of PureNix with the current set of libraries based on PureScript-0.14.

So the most helpful thing would probably be to go through all the PureScript libraries that have already been ported to PureNix, and update their versions to the same versions used in the actual PureScript-0.15 package set. Although that would likely be quite annoying to do unless you automated or semi-automated the process!


Other than that, the most helpful thing might be to try to work on some sort of nix-builtins library as described in #40.

Or, if you're coming from Haskell, one of the most interesting libraries to try to port to PureNix might be purescript-transformers, since that contains all the monad transformers and mtl type-classes. Having them be available in Nix would be neat.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request good first issue Good for newcomers help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants