From 2542f1ea5c71decb2147121fc31ed4518acb7087 Mon Sep 17 00:00:00 2001 From: "Seth Daily [SSW]" <130118701+sethdaily@users.noreply.github.com> Date: Thu, 28 Nov 2024 16:04:44 +1100 Subject: [PATCH] rule updates for CTF (#9612) Update rule.md --- rules/avoid-generic-names/rule.md | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/rules/avoid-generic-names/rule.md b/rules/avoid-generic-names/rule.md index 8816f024c8e..3250952151a 100644 --- a/rules/avoid-generic-names/rule.md +++ b/rules/avoid-generic-names/rule.md @@ -31,7 +31,7 @@ Generic names like “manager”, "helper", “processor”, “data”, and “ ## Why generic names are problematic -Words like "manager" and "processor" imply something that handles various tasks, which can make it tempting to pile unrelated responsibilities into one class. "Helper" makes this worse as it becomes a catch-all for a collection of disorganized functionality.Names like "data" or "info" are similarly ambiguous, as they could apply to nearly anything, from a database connection to a simple string. Specific names are always preferable, as they make the code easier to understand and prevent code bloat from accumulating unrelated functionality. +Words like "manager" and "processor" imply something that handles various tasks, which can make it tempting to pile unrelated responsibilities into one class. "Helper" makes this worse as it becomes a catch-all for a collection of disorganized functionality. Names like "data" or "info" are similarly ambiguous, as they could apply to nearly anything, from a database connection to a simple string. Specific names are always preferable, as they make the code easier to understand and prevent code bloat from accumulating unrelated functionality. :::greybox `OrderManager` - a class to handle orders in an e-commerce system @@ -41,12 +41,14 @@ Bad example - while this name suggests that it might have something to do with o ::: :::greybox -`OrderCreator` - specifically creating orders +`OrderCreator` - specifically creating orders + `ShippingOrderHandler` or `OrderShipmentService` - specifically handles only one aspect - sending orders for shipment ::: :::good Good example - This name directly reflects its purpose, making it immediately clear what the class is responsible for -::: +::: + :::greybox `UserData` - tracking the data for each user account