Skip to content

Commit

Permalink
Create STYLE_GUIDE.md
Browse files Browse the repository at this point in the history
  • Loading branch information
htrgouvea authored Dec 25, 2024
1 parent d81ef59 commit 3a5cd29
Showing 1 changed file with 157 additions and 0 deletions.
157 changes: 157 additions & 0 deletions STYLE_GUIDE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
<p align="center">
<h3 align="center">Perl Style Guide</h3>
<p align="center">A starting point for Perl development teams to provide consistency through good practices</p>
</p>

---

#### Summary

This paper is summarized in some good practice guidelines for Perl coding using "post-modern" practices. This work is in progress and any suggestions/contributions are welcome.

This project is just one of several other coding style guides, there is no intention of setting a pattern from it. Please do not take this as absolute truth. The most important thing here is that you and your team feel comfortable with a certain guideline and make use of it.

This paper is a fork of the paper written by [Eric Lorenzana](https://github.com/chusqui/perl-style-guide), with only a few changes in the sense of organization of the material and some adjustments to current market practices.

---

#### Code layout

- Avoid using comments: your code must be self explanatory, using comments proves that it is a confusing code.

- Make use of the "strict" and "warnings" modules in all your codes, they provided you:
1. strict: It forces you to code properly to make your program less error-prone. For example: It forces you to declare variables before you use them. You can declare variable using “my” keyword. “my” keyword restricts the scope of the variable to local. It makes the code more readable and less error prone. If you don’t declare variable using my keyword then the created variable would be global, which you should avoid, reducing the scope of the variable to the place where it is needed is a good programming practice.

2. warnings: It helps you find typing mistakes, it warns you whenever it sees something wrong with your program. It would help you find mistakes in your program faster.


- Try to limit your code to 72-78 column lines...
- But don't stress over it. Real world code often has very long sentences, and trying to force them to be below 78 columns leads to tight, but ugly code. In a nutshell: <= 72 is perfect, <= 78 is great, > 78 is not as bad as some folks might try to make you believe.

- Use four spaces per indentation level. The main advantage being that it provides a consistent and readable format, making it easier to maintain code quality. This level of indentation also helps in keeping lines within a reasonable length, promoting better readability.

- Do not use tabs. It makes code difficult to browse in some hosts (where 8 spaces per tab is the standard) and only works when indenting by blocks.

---

#### Good practices

```perl
# Don't do this:
my $string =
"Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor aliqua.";

# Do this instead:
my $string = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor aliqua."

my $fn = sub {$_[0] + 1}; # Bad
my $fn = sub { $_[0] + 1 }; # Good
```

* Don't cuddle an else.

```perl
# Good
if (condition) {
...
}

else {
...
}

# Bad
if (condition) {
...
} else {
...
}
```

```perl
# Good
sub function {
if (test) {
...
}
}

# Bad
sub function
{
if (test)
{
...
}
}
```

- Always unpack the stack first.
- Do not, ever, modify the stack. Unless necessary.

```perl
# Bad
sub my_method {
my $self = shift;
my %params = @_;
...
}

# Good
sub my_method {
my ($self, %params) = @_;
...
}
```

- Do not put spaces between spaces, braces and brackets. That is, arrays, hashes, array and hash references, string and command line delimiters.

```perl
my ( $self, $who, @params ) = @_; # Bad
my ($self, $who, @params) = @_; # Good

my $self = { name => "Eric", age => 26 }; # Bad
my $self = {name => "Eric", age => 26}; # Good

my @files = qx| ls $str |; # Bad
my @files = qx|ls $str|; # Good
```

- Please keep in mind that this does not apply to operators.

```perl
my $fn = sub {$_[0] + 1}; # Bad
my $fn = sub { $_[0] + 1 }; # Good

my @items = map {do_something_to $_} @_; # Bad
my @items = map { do_something_to $_ } @_; # Good
```

- Use whitespace between operators.

```perl
# Good
my $area = $pi * ($radius ^ 2);

# Bad
my $area = $pi*($radius^2);
```

- Associate hash key and values by using fat comma.

```perl

# Correct, but bad style
my %hash = (key1, 'val1',
key2, 'val2',
key3, 'val3');

# Good
my %hash = (
key1 => 'val1',
key2 => 'val2',
key3 => 'val3'
);
```

---

0 comments on commit 3a5cd29

Please sign in to comment.