]> git.ipfire.org Git - thirdparty/git.git/commitdiff
version: refactor get_uname_info()
authorUsman Akinyemi <usmanakinyemi202@gmail.com>
Sat, 15 Feb 2025 15:50:49 +0000 (21:20 +0530)
committerJunio C Hamano <gitster@pobox.com>
Tue, 18 Feb 2025 17:05:12 +0000 (09:05 -0800)
Some code from "builtin/bugreport.c" uses uname(2) to get system
information.

Let's refactor this code into a new get_uname_info() function, so
that we can reuse it in a following commit.

Mentored-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Usman Akinyemi <usmanakinyemi202@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/bugreport.c
version.c
version.h

index 7c2df035c9cff06f649c2b35394ea3db3d39f469..5e13d532a8565d93158bebadcc95cecb7554c77d 100644 (file)
 #include "diagnose.h"
 #include "object-file.h"
 #include "setup.h"
+#include "version.h"
 
 static void get_system_info(struct strbuf *sys_info)
 {
-       struct utsname uname_info;
        char *shell = NULL;
 
        /* get git version from native cmd */
@@ -24,16 +24,7 @@ static void get_system_info(struct strbuf *sys_info)
 
        /* system call for other version info */
        strbuf_addstr(sys_info, "uname: ");
-       if (uname(&uname_info))
-               strbuf_addf(sys_info, _("uname() failed with error '%s' (%d)\n"),
-                           strerror(errno),
-                           errno);
-       else
-               strbuf_addf(sys_info, "%s %s %s %s\n",
-                           uname_info.sysname,
-                           uname_info.release,
-                           uname_info.version,
-                           uname_info.machine);
+       get_uname_info(sys_info);
 
        strbuf_addstr(sys_info, _("compiler info: "));
        get_compiler_info(sys_info);
index 60df71fd0ebc28779072236ced0d55dd5b143ed9..3ec8b8243d6cae258e4abb4c03773eef9e8cfb52 100644 (file)
--- a/version.c
+++ b/version.c
@@ -3,6 +3,7 @@
 #include "version-def.h"
 #include "strbuf.h"
 #include "sane-ctype.h"
+#include "gettext.h"
 
 const char git_version_string[] = GIT_VERSION;
 const char git_built_from_commit_string[] = GIT_BUILT_FROM_COMMIT;
@@ -47,3 +48,22 @@ const char *git_user_agent_sanitized(void)
 
        return agent;
 }
+
+int get_uname_info(struct strbuf *buf)
+{
+       struct utsname uname_info;
+
+       if (uname(&uname_info)) {
+               strbuf_addf(buf, _("uname() failed with error '%s' (%d)\n"),
+                           strerror(errno),
+                           errno);
+               return -1;
+       }
+
+       strbuf_addf(buf, "%s %s %s %s\n",
+                   uname_info.sysname,
+                   uname_info.release,
+                   uname_info.version,
+                   uname_info.machine);
+       return 0;
+}
index 7c62e80577154d79bec050424945eb500d262a0f..afe3dbbab74ae76420359c81db5439aeaea82a2b 100644 (file)
--- a/version.h
+++ b/version.h
@@ -7,4 +7,11 @@ extern const char git_built_from_commit_string[];
 const char *git_user_agent(void);
 const char *git_user_agent_sanitized(void);
 
+/*
+  Try to get information about the system using uname(2).
+  Return -1 and put an error message into 'buf' in case of uname()
+  error. Return 0 and put uname info into 'buf' otherwise.
+*/
+int get_uname_info(struct strbuf *buf);
+
 #endif /* VERSION_H */