Skip to main content

Command Palette

Search for a command to run...

Code Smell 274 - Cascaded Returns

Stop the Return Rollercoaster

Updated
3 min read
Code Smell 274 - Cascaded Returns
M

I’m a senior software engineer loving clean code, and declarative designs. S.O.L.I.D. and agile methodologies fan.

TL;DR: Prevent chaining return statements for better code readability and flow.

Problems

  • Confusing flow
  • Hard to debug
  • Buried logic
  • Low readability
  • Risk of errors
  • Abuse of IF Sentences

Solutions

  1. Early returns
  2. Clear conditions 3 Use guard clauses 4 Repace IFs with Polymorphism

Refactorings

Context

When you chain multiple return statements within a function, you create a confusing flow.

This leads to spaghetti code where understanding the exit points becomes hard.

Cascaded returns can hide important logic deep within the function, making it harder to follow and debug.

You read through multiple branches to determine when and where the function ends.

Sample Code

Wrong

function discount(price, isMember) {
  if (price < 20) {
    if (isMember) {
      return 5;
    } else {
      return 2;
    }
  } else {
    if (isMember) {
      return 10;
    } else {
      return 0;
    }
  }
}

Right

class Member {
  discount(price) {
    return price < 20 ? 5 : 10;
    // This ternary is an essential IF
    // And you should NOT remove it
  }
}

class NonMember {
  discount(price) {
    return price < 20 ? 2 : 0;
    // This ternary is an essential IF
    // And you should NOT remove it
  }
}

function discount(price, status) {
  return status.discount(price);
}

const member = new Member();
const nonMember = new NonMember();

Detection

[X] Automatic

You can spot cascaded returns by looking for multiple nested return statements.

If you see deep indentation or many layers of conditions, that's a sign of this code smell.

Tags

  • IF

Level

[X ] Beginner

AI Generation

AI generators might create this smell when tasked with solving complex problems quickly.

Cascaded returns often happen when the generator handles multiple conditions without optimizing the flow.

AI Detection

With clear instructions, AI tools can avoid cascaded returns.

You can ask the AI to use guard clauses, polymorphism and simplify returns for a cleaner solution.

Try Them!

Remember: AI Assistants make lots of mistakes

Without Proper InstructionsWith Specific Instructions
ChatGPTChatGPT
ClaudeClaude
PerplexityPerplexity
CopilotCopilot
GeminiGemini

Conclusion

Avoid cascaded returns to make your code more readable, maintainable, and easier to debug.

Stick to early returns and guard clauses to prevent unnecessary complexity.

Relations

More Info

Disclaimer

Code Smells are my opinion.

Credits

Photo by Mike Lewis HeadSmart Media on Unsplash


Even when a module is old and stable, bad code may be a time bomb and we might defuse it by isolating that code in its own library

Adam Tornhill


This article is part of the CodeSmell Series.

Code Smells

Part 44 of 50

In this series, we will see several symptoms and situations that make us doubt the quality of our developments. We will present possible solutions. Most are just clues. They are no hard rules.

Up next

Code Smell 273 - Overengineering

Keep It Simple, Stupid