How do you decide what a package name should be and what class should go into what package ?
I’m working on a project where I am constantly adding/removing classes and not really sure if I need a new package, or should add it to an existing one that im not currently aware of.
Do you follow a set of rules when creating a new package ?
How do you know if you are not duplicating package functionality ? Is this just down to familiarity with the project.
Any pointers appreciated.
Classes should do one thing (Single Responsibility Principle).
Classes that do related things should go in the same package. If you find you can more closely relate some of the classes in a package, make them a subpackage!
For example, if I had a project with these classes:
GreetingInputWindowGreetingDatabaseObjectGreetingDatabaseConnectorI might just put them all in the
greetingpackage. If I wanted to, I might putGreetingInputWindowin thegreeting.uipackage, and the other 2 into thegreeting.dbpackage.