data:image/s3,"s3://crabby-images/bdf6a/bdf6aaf9f4bde8d2dc58c5d374be9d0a4fb65519" alt=""
Read about 3 new Scala code patterns we just added to our platform in our mission Codacy to support multiple coding languages effectively.
1. Avoid using DateTime.now without a timezone (Error Prone)
Using DateTime.now without specifying a timezone can lead to error prone code with regard to dealing with other timezones than those initially considered, as well as with daylight saving time.
For instance, the following example:
val now = DateTime.now
could easily be written as:
val now = DateTime.now(DateTimeZone.UTC)
2. Prefer using .nonEmpty (Code Style)
The collections libraries usually provide a method for determining if the iterable has, at least, one element, with:
val hasElements = SomeSequence.nonEmpty
This is a bit cleaner than verifying explicitly the length or the size:
val hasElements = SomeSequence.length > 0 val hasElementsUsingSize = SomeSequence.size > 0
3. Prevent XML parsing attacks (Security)
XML External Entity (XXE) attacks can occur when an XML parser supports XML entities while processing XML received from an untrusted source.
Vulnerable Code:
SAXParser parser = SAXParserFactory.newInstance().newSAXParser(); parser.parse(inputStream, customHandler);
Solution using “Secure processing” mode:
SAXParserFactory spf = SAXParserFactory.newInstance(); spf.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true); SAXParser parser = spf.newSAXParser(); parser.parse(inputStream, customHandler);
Solution disabling DTD:
SAXParserFactory spf = SAXParserFactory.newInstance(); spf.setFeature("http://apache.org/xml/features/disallow-doctype-decl", true); SAXParser parser = spf.newSAXParser(); parser.parse(inputStream, customHandler);
Enabling patterns with Codacy
When new patterns are added, they’re disabled for already existing projects.
To enable them for a project first head to the project and hit “Code Patterns” on the top right corner. You’ll be able to filter the patterns by language or category:
data:image/s3,"s3://crabby-images/7c521/7c521a3de1a8818b6f0f3f60fdce5e53ba8f951c" alt="selecting language for patterns"
To enable the new patterns simply look for the “New” tag on them and hit their respective checkbox:
data:image/s3,"s3://crabby-images/66bab/66bab5731e961bccc34cb607f4cecb698de3d0b4" alt="enabling patterns"
If you’re interested, there’s also a “Fork pattern” button on the bottom right corner of the details of every Scala pattern.
data:image/s3,"s3://crabby-images/08250/082505e2b1fcbe2f164c49c559824a2acdccb108" alt="fork pattern"
Hitting this button will take you to our Beta Pattern Creator with the current pattern loaded; you can then edit it to create your own:
data:image/s3,"s3://crabby-images/46c75/46c758885f0a9abc54ac1b8432d3ca7e78f56027" alt="pattern creator - beta"
Have fun, code well!
Edit: We just published an ebook: “The Ultimate Guide to Code Review” based on a survey of 680+ developers. Enjoy!
About Codacy
Codacy is used by thousands of developers to analyze billions of lines of code every day!
Getting started is easy – and free! Just use your GitHub, Bitbucket or Google account to sign up.