Giter Site home page Giter Site logo

Highlight self about python-syntax HOT 4 CLOSED

hdima avatar hdima commented on July 28, 2024
Highlight self

from python-syntax.

Comments (4)

lonetwin avatar lonetwin commented on July 28, 2024

Strictly speaking self is not really a keyword but yeah it would be good to highlight it (and the other strong conventional keyword cls as well)

from python-syntax.

hdima avatar hdima commented on July 28, 2024

Well, it was discussed a little bit before in #10.

I don't want to add highlighting for self for a number of reasons:

  • I actually tried it and I don't really like how it looks. It adds too many colors to the code to the point that it's getting harder to follow.
  • As @lonetwin already mentioned, self is actually just a conventional name for the first argument of a method. And if somebody uses for example just s instead it won't be highlighted and just will be confusing.
  • As it just an argument of a method it also can raise a question "why the other arguments not highlighted?" and also can add to the confusion.

from python-syntax.

Olivia5k avatar Olivia5k commented on July 28, 2024

It is a conventional name, but it is used in literally 99.99% of all OO Python code. I have worked with Python almost exclusively for the better part of a decade, and I have never seen anyone use anything but self. So, if someone averts themselves from this de facto standard, I don't think they will be confused if their tooling would not follow suit 100%. Even if they are, I would argue that the other 99.99% of all users would be happy to have all their keywords highlighted.

For your first and second points, they can be tweaked. self highlight could be a default-on option so that it can be disabled, and adding highlights for other arguments is actually something that can be done. I have already implemented a light way (highlighting *args and **kwargs and the value part of key=value) into this project, but I was holding off on making PRs until this was resolved. Guess I won't be adding them.

I'll respect your decision, but I'll also express some general concern about the Open Source way of disregarding useful ideas and changes because they might be troublesome for a single hypothetical power user. The lack of colored prompts and tab completion in default Debian and Ubuntu shells come to mind; the argument was that people still using print terminals or really slow computers would have a slightly worse time.

from python-syntax.

hdima avatar hdima commented on July 28, 2024

Probably not so good example but there's a class which uses s instead of self: https://hg.python.org/cpython/file/3.4/Lib/sched.py#l45

I'll respect your decision, but I'll also express some general concern about the Open Source way of disregarding useful ideas and changes because they might be troublesome for a single hypothetical power user.

I think the main point of Open Source is that you can create your own version of a project if you think that your changes are useful and they can't be incorporated to the mainline version for some reason. It's actually one of the reasons why this project exists.

from python-syntax.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.