Code Monkey home page Code Monkey logo

Comments (6)

ShalokShalom avatar ShalokShalom commented on June 4, 2024 1

Oh sorry. I did mean this more as an informational request for me, rather than a suggestion to change your defaults.

from ruby-style-guide.

pirj avatar pirj commented on June 4, 2024

With git blame I could track it down to:

  1. #553

Do you really prefer foo &. bar?

I must confess, it was a recent revelation to me that the dot should not necessarily be directly adjacent to the receiver and the method name. You want to avoid confusing newbies with your code, don't you?

  1. #44

It's unfortunate that Ruby reserves ^ to bitwise XOR in the first place. I have no strong feelings about e = M * c ** 2 vs e = M * c**2, but the vast majority of participants agree with the exception.

  1. #659

The argument "visual distinction with division" sounds strong enough.

Do you object to some exception in particular, or all of them at once?
What is your suggestion for the style guide change?

from ruby-style-guide.

bbatsov avatar bbatsov commented on June 4, 2024

We can probably add a bit of the rationale to the guidelines. I considered those self-explanatory, but I guess they are not.

from ruby-style-guide.

pirj avatar pirj commented on June 4, 2024

There was even a ticket to handle that, but I gave up on the idea #749

from ruby-style-guide.

ShalokShalom avatar ShalokShalom commented on June 4, 2024

Well, I like consistency.

The third example seems like the language messed up, and the style guide is here to fix this by breaking an already sane style guide, so its fixing a break with another break.

The second is kinda questionable, for the reason you provided.

The first one is a clear yes to the whitespace solution.

from ruby-style-guide.

pirj avatar pirj commented on June 4, 2024

@ShalokShalom

The first one is a clear yes to the whitespace solution.

Please accept my apologies for reductio ad absurdum. If you prefer to use whitespace with the safe navigation operator, wouldn't it make sense for consistency also surround all method calls' dots to be surrounded by whitespace?

cop = cop . cop_name if cop . respond_to?(:cop_name)
return if node . loc . operator . line == rhs . first_line

The style guide is based on the widespread practices.
If we'd adjust some guidelines, there would better be a proof that it is how it's used by Rubyists.

A style guide that reflects real-world usage gets used, while a style guide that holds to an ideal that has been rejected by the people it is supposed to help risks not getting used at all - no matter how good it is.

Would you please harvest https://github.com/eliotsykes/real-world-rails and https://github.com/jeromedalbert/real-world-ruby-apps for me to find a confirmation that at least some percentage of usages of &., ** and /*r have whitespace to them?

from ruby-style-guide.

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.