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

Lazy Package is bloated with things that have little or nothing to do with LazyList's... #94

Open
GordonBGood opened this issue Aug 28, 2018 · 0 comments

Comments

@GordonBGood
Copy link

GordonBGood commented Aug 28, 2018

This is a bit of a rant against "do-everything" packages like this:

A/ "dynamic.jl" should be broken out as it's own package "Dynamic" as it's only export @dynamic is not used in Lazy and those who might have a use for it shouldn't need to add all the other features of Lazy.

B/ "tail.jl" should be broken out as its own package "TailCallOptimization", as @rec is only used four places in Lazy: by dorun in "lazy.jl", and by reduce, any, and all in "liblazy.jl"; all of these can easily just use conventional for/while loops, which is what the macro does anyway; the trampolining macro @bounce isn't used at all. Those who might have a use for these, such as for style reasons in wishing to write loops that appear "functionally" as recursive functions using @rec or full (slower) trampolined recursion using @bounce shouldn't need to add all the other features of Lazy.

C/ Although somewhat convenient in particular for the primes example, the use of the @>> macro requires casual users to have to look into what it means in order to understand the example, and the example is just as clear if anonymous functions and the existing pipeline operator |> are used, which is essentially what the macro does. This macro is also used in constantly, repeatedly, last, walk, any, and all in "liblazy.jl", where they can easily be replaced by what they mean with actually less just-as-easily-understood code than using it. The only other macro used is the @with macro in the partition and partitionby functions defined in "liblazy.jl" file, and is one of the few macros created in this package actually tested in "runtest.jl"; these use cases are just as clear if the conventional let/end block is used as the macro expands to. Therefore, I recommend that "macros.jl" be converted into its own package "UtilityMacros" to be more easily accessible by those who have a true need for them and to not clutter this Lazy package.

These simplifications are all the the name of good coding practice in not making packages too "bulky" and also in good coding style in not using macros unless they contribute something to clarity or brevity of code..

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

1 participant