Sometimes I find myself in the situation that I want to modify the configuration of a project that is connected to a revision control system, but don't want to commit those changes. A frequent example is wanting to run a wicket application in debug mode. This is something you don't want to check in, because the project should be kept in a deployment-ready condition inside the repository. On the other hand, I don't want my IDE to remind me constantly of that uncommitted change, since this obscures other changes. While there are RCSs that support this kind of local changes, SVN does not so readily. There is, however, a little method to hide the changes using the IDE, in this case, Eclipse:
Let's assume that the project uses a file called
application.properties, which is found at the root level of the classpath at runtime. This is a fairly common setup. Using Eclipse, you can simply override these settings and hide the changes from svn. To do that, first add a new folder, called
local-config. Inside, add a copy of
application.properties. Edit as necessary.
To have Eclipse use this folder when running the software, insert it into the classpath as a
class folder. Insert it
before the original classpath:
This way, you can easily spot the difference of this folder to a normal source folder:
Using normal Java classpath behavior, the files in
local-config will now be found earlier than the original properties file and be used instead.
To keep SVN from nagging you about checking it in, you can just add
local-config to the
svn:ignore property of the project's root folder. From now on you can change the configuration as you like and not have to check it in, while being able to spot any other changes with a quick glance at the project. Nothing magical, but useful when you don't want to start your software using Maven/Ant and resource filtering. Works for other kinds of resources too. Even for classes, although I wouldn't recommend using that too often - it tends to confuse.