Prevent committing code with svn if certain obsolete C/C++ functions are used
Is there a way to prevent developers from committing code when certain unsafe or obsolete functions are used? For example:
开发者_如何转开发- scanf
- atoi
- gets
- etc..
A project I've worked uses a simple set of macros in a header that's included in every file (some compilers let you specify such a header on the command line, so you can force it's use in a makefile):
#define strcpy strcpy_is_banned_use_strlcpy
#define strcat strcat_is_banned_use_strlcat
#define strncpy strncpy_is_banned_use_strlcpy
#define strncat strncat_is_banned_use_strlcat
#define sprintf sprintf_is_banned_use_snprintf
With these macros, the build will fail if you try to use a banned function (and the linker will tell you what you should use instead).
So it doesn't get checked on commit, per se, but as long as your team members make sure things build before they check in, the system works. And if they don't, then everyone starts getting build break emails, which tends to quickly correct the behavior.
Simple, but effective.
You could use a Subversion pre-commit hook. Example here: http://wordaligned.org/articles/a-subversion-pre-commit-hook
It shouldn't be too hard to write a few regular expressions to scan your commits for the functions you don't want
You can get part of the way using "svnlook changed" and then "svnlook cat" in a post-commit hook, and grep to check for the functions you're interested in.
That will give you some false positives, for example if the function is mentioned in a string or a comment. Depending on your circumstances (ie how many users you have, and how picky they are ;-), that may or may not be a problem for you. A more complete solution would have to parse the program text to find the functions that are called.
As an alternative, assuming (since you refer to them as obsolete functions) that you're using Visual Studio, you could change the warnings about these functions to errors in your project, so that the code doesn't even build if they are used.
Write a pre-commit hook which performs whatever checks you wish to enforce on the code. Info about pre-commit hooks.
精彩评论