On Tue, Nov 19, 2019 at 5:26 AM Random832 <random...@fastmail.com> wrote:
>
> On Mon, Nov 18, 2019, at 13:00, Andrew Barnert via Python-ideas wrote:
> >     def f(a, b): return a**(b+1)
> >     g = partial(f, b==2)
> >     h = lambda x: f(x, 2)
> >
> > Python can’t tell the difference between f, g, and h; they’re all
> > variables. An IDE could keep track of the fact that f was bound by a
> > def statement, and g and h by assignment. But I’m not sure why you’d
> > want it to. After all, they’re all variables with callable values. Why
> > should f(2,3) be colored differently from g(4)?
>
> I think, more or less, "a function" can be regarded as "a *constant* whose 
> value is callable and is not type-like" [where type-like includes types, 
> abstract base classes, and type hint objects], regardless of how it was 
> obtained.
>

If by "constant" you mean that they are immutable, then maybe; there
aren't very many mutable callables (by comparison to the huge number
of functions). But you can't assume that a function is as constant as
a string literal. Closures are more akin to lists than to literals -
every time you run the 'def' command, it creates you a brand new
function with whichever context it was given.

> Opinions may differ on whether "real variables" [either locals, or globals 
> whose values actually do vary] and/or parameters of callable types (or 
> type-like types) should or should not be highlighted the same way as a 
> typical non-callable variable.
>
> Highlighting these would in any case require an editor with a deep 
> understanding of the language (far beyond the typical regex-based syntax 
> highlighters) and probably type annotated code, but that doesn't mean it 
> wouldn't be useful.
>

verbose = print
if args.quiet:
    def verbose(*a, **kw): pass

...
verbose("blah blah blah")


Is 'verbose' now a variable, a function, a constant, a global, or
what? How should it be highlighted?

ChrisA
_______________________________________________
Python-ideas mailing list -- python-ideas@python.org
To unsubscribe send an email to python-ideas-le...@python.org
https://mail.python.org/mailman3/lists/python-ideas.python.org/
Message archived at 
https://mail.python.org/archives/list/python-ideas@python.org/message/SFAB2TURTNTUU5AKVOHSU4COG7CNEIAW/
Code of Conduct: http://python.org/psf/codeofconduct/

Reply via email to