diff options
| author | Kris De Gussem <kris.degussem@gmail.com> | 2012-01-22 08:33:53 +0000 |
|---|---|---|
| committer | Kris <Kris.De.Gussem@hotmail.com> | 2012-01-22 08:33:53 +0000 |
| commit | 88920376ba25bac12f37003c5a810067352e8609 (patch) | |
| tree | 273665b093ce7183ae9dfcc297d55dae7a17da06 /src/version.cpp | |
| parent | memleak / header stuff / unused variable. (diff) | |
| download | inkscape-88920376ba25bac12f37003c5a810067352e8609.tar.gz inkscape-88920376ba25bac12f37003c5a810067352e8609.zip | |
cppcheck tells us: scanf without field width limits can crash with huge input data.
(bzr r10918)
Diffstat (limited to 'src/version.cpp')
| -rw-r--r-- | src/version.cpp | 30 |
1 files changed, 21 insertions, 9 deletions
diff --git a/src/version.cpp b/src/version.cpp index 438e47da9..68729c62e 100644 --- a/src/version.cpp +++ b/src/version.cpp @@ -4,14 +4,16 @@ * Authors: * MenTaLguY <mental@rydia.net> * Jon A. Cruz <jon@joncruz.org> + * Kris De Gussem <Kris.DeGussem@gmail.com> * * Copyright (C) 2003 MenTaLguY + * Copyright (C) 2012 Kris De Gussem * * Released under GNU GPL, read the file 'COPYING' for more information */ -#include <stdio.h> -#include <glib.h> +#include <sstream> + #include "version.h" gboolean sp_version_from_string(const gchar *string, Inkscape::Version *version) @@ -19,13 +21,23 @@ gboolean sp_version_from_string(const gchar *string, Inkscape::Version *version) if (!string) { return FALSE; } - - version->_major = 0; - version->_minor = 0; - - return sscanf((const char *)string, "%u.%u", - &version->_major, &version->_minor) || - sscanf((const char *)string, "%u", &version->_major); + + try + { + std::stringstream ss; + ss << string; + ss >> version->_major; + char tmp=0; + ss >> tmp; + ss >>version->_minor; + return true; + } + catch(...) + { + version->_major = 0; + version->_minor = 0; + return false; + } } gchar *sp_version_to_string(Inkscape::Version version) |
