guix-patches
[Top][All Lists]
Advanced

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

[bug#30341] [PATCH 4/4] gnu: Add bpython.


From: Marius Bakke
Subject: [bug#30341] [PATCH 4/4] gnu: Add bpython.
Date: Thu, 15 Feb 2018 13:13:44 +0100
User-agent: Notmuch/0.26 (https://notmuchmail.org) Emacs/25.3.1 (x86_64-pc-linux-gnu)

Hartmut Goebel <address@hidden> writes:

> * gnu/packages/python.scm (bpython, bpython2): New variables.

[...]

> +(define-public bpython
> +  (package
> +    (name "bpython")
> +    (version "0.17")
> +    (source
> +      (origin
> +        (method url-fetch)
> +        (uri (pypi-uri "bpython" version))
> +        (sha256
> +          (base32
> +           "1mbah208jhd7bsfaa17fwpi55f7fvif0ghjwgrjmpmx8w1vqab9l"))
> +        (file-name (string-append name "-" version ".tar.gz"))))

I think (file-name ...) here is unnecessary, no?

> +    (build-system python-build-system)
> +    (arguments
> +     `(#:phases
> +       (modify-phases %standard-phases
> +         (add-after 'unpack 'remove-failing-test ;; FIXME
> +           (lambda _
> +             (delete-file "bpython/test/test_args.py")))

 #t))

Could you add some information about why this is deleted?

> +         (add-after 'wrap 'add-aliases
> +           ;; for symmetry to bpython2, add symlinks bypthon3, bpdb3, etc.
> +           (lambda* (#:key outputs #:allow-other-keys)
> +             (let ((out (assoc-ref outputs "out")))
> +               (for-each
> +                (lambda (old new)
> +                  (symlink old ;; (string-append out "/bin/" old)
                                  ^^^ leftover comment? :)
> +                           (string-append out "/bin/" new)))
> +                '("bpython" "bpython-curses" "bpython-urwid" "bpdb")
> +                '("bpython3" "bpython3-curses" "bpython3-urwid" 
> "bpdb3"))))))))

                  #t)))

> +    (propagated-inputs
> +     `(("python-pygments" ,python-pygments)
> +       ("python-requests", python-requests)
> +       ("python-babel" ,python-babel) ;; optional, for internationalization
> +       ("python-curtsies" ,python-curtsies) ;; >= 0.1.18
> +       ("python-greenlet" ,python-greenlet)
> +       ("python-urwid" ,python-urwid) ;; for bpython-urwid only
                                         ^^^
                                         only one semicolon for inline comments.
> +       ("python-six" ,python-six)))
> +    (native-inputs
> +     `(("python-sphinx" ,python-sphinx)
> +       ("python-mock" ,python-mock)))
> +    (home-page "https://bpython-interpreter.org/";)
> +    (synopsis "Fancy interface to the Python interpreter")
> +    (description "Bpython is a fancy interface to the Python
> +interpreter. bpython's main features are
> +
> address@hidden
> address@hidden in-line syntax highlighting,
> address@hidden readline-like autocomplete with suggestions displayed as you 
> type,
> address@hidden expected parameter list for any Python function,
> address@hidden \"rewind\" function to pop the last line of code from memory 
> and
> +      re-evaluate,
> address@hidden send the code you've entered off to a pastebin,
> address@hidden save the code you've entered to a file, and
> address@hidden auto-indentation.
> address@hidden enumerate")
> +    (license license:expat)))
> +
> +(define-public bpython2
> +  (let ((base (package-with-python2
> +               (strip-python2-variant bpython))))
> +    (package (inherit base)
> +      (name "bpython2")
> +      (arguments
> +       `(#:python ,python-2
> +         #:phases
> +         (modify-phases %standard-phases
> +         (add-after 'unpack 'remove-failing-test ;; FIXME
> +           (lambda _
> +             (delete-file "bpython/test/test_args.py")
> +             (substitute* "bpython/test/test_curtsies_repl.py"
> +               (("^(\\s*def )(test_get_last_word_with_prev_line\\W)" _ a b)
> +                (string-append a "xxx_off_" b))
> +               (("^(\\s*def )(test_complex\\W)" _ a b)
> +                (string-append a "xxx_off_" b)))))

#t))

I'm not sure what's going on here, can you add a comment?

Other than that looks good, thanks!

> +           (add-before 'build 'rename-scripts
> +             ;; rename the scripts to bypthon2, bpdb2, etc.
> +             (lambda _
> +               (substitute* "setup.py"
> +                 (("^(\\s+'bpdb)(\\s+=.*',?)\\s*?$" _ name rest)
> +                  (string-append name "2" rest "\n"))
> +                 (("^(\\s+'bpython)(-\\S+)?(\\s+=.*',?)\\s*?$" _ name sub 
> rest)
> +                  (string-append name "2" (or sub "") rest "\n")))
> +               #t))))))))
> -- 
> 2.13.6

Attachment: signature.asc
Description: PGP signature


reply via email to

[Prev in Thread] Current Thread [Next in Thread]