summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKent Sebastian <ksebasti@redhat.com>2009-04-24 11:26:51 -0400
committerKent Sebastian <ksebasti@redhat.com>2009-04-24 11:26:51 -0400
commit4d0a333004c652a75304c8276e4a45083ca9c122 (patch)
tree93c6f34b85d3a58a90c504c48d1022fade8d2deb
parent9b055ab2163bfa62c70949f4935b1432b6a6921b (diff)
downloadsystemtap-steved-4d0a333004c652a75304c8276e4a45083ca9c122.tar.gz
systemtap-steved-4d0a333004c652a75304c8276e4a45083ca9c122.tar.xz
systemtap-steved-4d0a333004c652a75304c8276e4a45083ca9c122.zip
PR10082: refactor duplicated code
-rw-r--r--main.cxx80
1 files changed, 30 insertions, 50 deletions
diff --git a/main.cxx b/main.cxx
index 1111b316..ab568c23 100644
--- a/main.cxx
+++ b/main.cxx
@@ -324,6 +324,34 @@ setup_signals (sighandler_t handler)
sigaction (SIGTERM, &sa, NULL);
}
+void
+setup_kernel_release (systemtap_session &s, const char* kstr) {
+ if (kstr[0] == '/') // fully specified path
+ {
+ s.kernel_build_tree = kstr;
+ string version_file_name = s.kernel_build_tree + "/include/config/kernel.release";
+ // The file include/config/kernel.release within the
+ // build tree is used to pull out the version information
+ ifstream version_file (version_file_name.c_str());
+ if (version_file.fail ())
+ {
+ cerr << "Missing " << version_file_name << endl;
+ exit(1);
+ }
+ else
+ {
+ char c;
+ s.kernel_release = "";
+ while (version_file.get(c) && c != '\n')
+ s.kernel_release.push_back(c);
+ }
+ }
+ else
+ {
+ s.kernel_release = string (kstr);
+ s.kernel_build_tree = "/lib/modules/" + s.kernel_release + "/build";
+ }
+}
int
main (int argc, char * const argv [])
@@ -426,31 +454,7 @@ main (int argc, char * const argv [])
const char* s_kr = getenv ("SYSTEMTAP_RELEASE");
if (s_kr != NULL) {
- if (s_kr[0] == '/') // fully specified path
- {
- s.kernel_build_tree = s_kr;
- string version_file_name = s.kernel_build_tree + "/include/config/kernel.release";
- // The file include/config/kernel.release within the
- // build tree is used to pull out the version information
- ifstream version_file (version_file_name.c_str());
- if (version_file.fail ())
- {
- cerr << "Missing " << version_file_name << endl;
- exit(1);
- }
- else
- {
- char c;
- s.kernel_release = "";
- while (version_file.get(c) && c != '\n')
- s.kernel_release.push_back(c);
- }
- }
- else
- {
- s.kernel_release = string (s_kr);
- s.kernel_build_tree = "/lib/modules/" + s.kernel_release + "/build";
- }
+ setup_kernel_release(s, s_kr);
}
@@ -588,31 +592,7 @@ main (int argc, char * const argv [])
break;
case 'r':
- if (optarg[0] == '/') // fully specified path
- {
- s.kernel_build_tree = optarg;
- string version_file_name = s.kernel_build_tree + "/include/config/kernel.release";
- // The file include/config/kernel.release within the
- // build tree is used to pull out the version information
- ifstream version_file (version_file_name.c_str());
- if (version_file.fail ())
- {
- cerr << "Missing " << version_file_name << endl;
- usage (s, 1);
- }
- else
- {
- char c;
- s.kernel_release = "";
- while (version_file.get(c) && c != '\n')
- s.kernel_release.push_back(c);
- }
- }
- else
- {
- s.kernel_release = string (optarg);
- s.kernel_build_tree = "/lib/modules/" + s.kernel_release + "/build";
- }
+ setup_kernel_release(s, optarg);
break;
case 'k':