2021-10-27 15:23:28 +05:30
---
type: reference, dev
stage: none
group: Development
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
---
# Ruby style guide
This is a GitLab-specific style guide for Ruby code.
2022-07-23 23:45:48 +05:30
Generally, if a style is not covered by [existing RuboCop rules or style guides ](../contributing/style_guides.md#ruby-rails-rspec ), it shouldn't be a blocker.
2021-10-27 15:23:28 +05:30
Before adding a new cop to enforce a given style, make sure to discuss it with your team.
When the style is approved by a backend EM or by a BE staff eng, add a new section to this page to
document the new rule. For every new guideline, add it in a new section and link the discussion from the section's
2022-07-16 23:28:13 +05:30
[version history note ](../documentation/versions.md#add-a-version-history-item )
2021-10-27 15:23:28 +05:30
to provide context and serve as a reference.
2022-08-27 11:52:29 +05:30
See also [guidelines for reusing abstractions ](../reusing_abstractions.md ).
2022-08-13 15:12:31 +05:30
Everything listed here can be [reopened for discussion ](https://about.gitlab.com/handbook/values/#disagree-commit-and-disagree ).
2021-10-27 15:23:28 +05:30
## Instance variable access using `attr_reader`
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/52351) in GitLab 14.1.
Instance variables can be accessed in a variety of ways in a class:
```ruby
# public
class Foo
attr_reader :my_var
def initialize(my_var)
@my_var = my_var
end
def do_stuff
puts my_var
end
end
# private
class Foo
def initialize(my_var)
@my_var = my_var
end
private
attr_reader :my_var
def do_stuff
puts my_var
end
end
# direct
class Foo
def initialize(my_var)
@my_var = my_var
end
private
def do_stuff
puts @my_var
end
end
```
Public attributes should only be used if they are accessed outside of the class.
There is not a strong opinion on what strategy is used when attributes are only
accessed internally, as long as there is consistency in related code.