From 732d1963ed83abf4e5f1b06ec451a6943421d716 Mon Sep 17 00:00:00 2001
From: Guo Wenxue <guowenxue@gmail.com>
Date: Thu, 22 Sep 2022 00:36:11 +0800
Subject: [PATCH] update ds18b20.c to snprintf
---
 apue/1.File_IO/ds18b20.c |   13 ++++++-------
 1 files changed, 6 insertions(+), 7 deletions(-)
diff --git a/apue/1.File_IO/ds18b20.c b/apue/1.File_IO/ds18b20.c
index 1ad5192..0ff2a34 100644
--- a/apue/1.File_IO/ds18b20.c
+++ b/apue/1.File_IO/ds18b20.c
@@ -45,14 +45,14 @@
 
 int ds18b20_get_temperature(float *temp)
 {
-    char            w1_path[50] = "/sys/bus/w1/devices/";
+    const char     *w1_path = "/sys/bus/w1/devices/";
+    char            ds_path[50];
     char            chip[20];
     char            buf[128];
     DIR            *dirp;
     struct dirent  *direntp;
     int             fd =-1;
     char           *ptr;
-    float           value;
     int             found = 0;
     int             rv = 0;
 
@@ -89,19 +89,18 @@
     }
 
     /* get DS18B20 sample file full path: /sys/bus/w1/devices/28-xxxx/w1_slave */
-    strncat(w1_path, chip, sizeof(w1_path)-strlen(w1_path));
-    strncat(w1_path, "/w1_slave", sizeof(w1_path)-strlen(w1_path));
+    snprintf(ds_path, sizeof(ds_path), "%s/%s/w1_slave", w1_path, chip);
 
     /* open file /sys/bus/w1/devices/28-xxxx/w1_slave to get temperature */
-    if( (fd=open(w1_path, O_RDONLY)) < 0 )
+    if( (fd=open(ds_path, O_RDONLY)) < 0 )
     {
-        printf("open %s error: %s\n", w1_path, strerror(errno));
+        printf("open %s error: %s\n", ds_path, strerror(errno));
         return -4;
     }
 
     if(read(fd, buf, sizeof(buf)) < 0)
     {
-        printf("read %s error: %s\n", w1_path, strerror(errno));
+        printf("read %s error: %s\n", ds_path, strerror(errno));
         rv = -5;
         goto cleanup;
     }
--
Gitblit v1.9.1