Chapter 18. Globals
Write shy code—modules that don’t reveal anything unnecessary to other modules and that don’t rely on other modules’ implementations.
David Thomas and Andrew Hunt, The Pragmatic Programmer: Your Journey to Mastery
18.0 Introduction
Most modern languages support global functions, classes, and attributes. There’s a hidden cost when you use any of these artifacts. Even when you are creating an object using new()
, you will introduce a tight coupling to a global class unless you apply some of the following recipes.
18.1 Reifying Global Functions
Problem
You have global functions that you can call from anywhere.
Solution
Global functions bring a lot of coupling. Narrow their scope.
Discussion
Discouraged by object-oriented programming, many mixed languages support global functions. They create coupling and hurt readability since they are difficult to trace. As coupling grows, maintainability and testability become more problematic. You can start by wrapping the function in a context object. For example, you can find external resource access, database access, singletons (see Recipe 17.2, “Replacing Singletons”), global classes, time, and operating system resources.
This example calls a method from a global database:
class
Employee
{
function
taxesPayedUntilToday
()
{
return
database
()
->
select
(
"SELECT TAXES FROM EMPLOYEE"
.
" WHERE ID = "
.
$this
->
id
()
.
" AND DATE < "
.
currentDate
());
}
}
By making persistence contextual, you can decouple the database ...
Get Clean Code Cookbook now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.