A C# style guide supports the work of developers and the growth of projects. The goal is to have a cleaner, more scalable code base that makes it easier to grow your team and game. This guide provides an overview of the guidelines and examples for developing and maintaining your own style guide.
Note: These recommendations are based on general industry standards for C# and are meant to be inspirational rather than rules set in stone. Adapt anything here to your needs and preferences.
- Names should be descriptive, clear, and unambiguous.
- Avoid using too many prefixes or special encoding.
- Make names easily searchable.
- Variables should be nouns.
- Prefix booleans with a verb (e.g.,
isPlayerSafe
).
- Decide as a team whether to omit access level modifiers or to specify them.
- Local variables and method parameters should be in camelCase.
- Public fields, class, and method names should be in PascalCase.
- Use PascalCase nouns for class names.
- Make class names indicative of their purpose (e.g.,
PetFollowController
).
- Start method names with a verb.
- Use camelCase for method parameters.
- Methods returning a boolean should ask questions (e.g.,
IsStarving
).
- Name events with verb phrases.
- Use present or past participle to indicate events before or after (e.g.,
OpeningDoor
orOpenedDoor
). - Use the
System.Action
delegate for events. - Prefix the event raising method with "on" (e.g.,
OnOpeningDoor
).
- Use PascalCase without symbols or underscores.
- Create sub-namespaces using the dot operator.
- Use expression-bodied syntax for single-line read-only properties.
- Encapsulate data using properties to hide it from unwanted changes.
- Group data in serializable classes or structs to clean up the inspector.
- Use the
SerializeField
attribute for private or protected variables to make them appear in the inspector. - Use the
Range
attribute to set minimum and maximum values.
- Use the Allman style from the Microsoft framework design guidelines.
- Don't omit braces, even for single-line statements.
- Add spaces to decrease code density.
- Use a single space before flow control conditions.
- Add a space before and after comparison operators.
- Classes should be small and focused.
- Follow the single responsibility principle.
- Separate out distinct functionalities into their own classes.
- Use scriptable objects for data.
- Methods should be small with a single responsibility.
- Each method should describe one action or answer one question.
- Follow the DRY (Don't Repeat Yourself) principle.
- Refactor methods to avoid duplicate or repetitious logic.
Clean code should always look like it was written by someone who cares. Caring is not a destination; it's a daily practice.
For a more detailed style sheet and additional resources, refer to the Unity eBook.