From 665e1b5cb16d058f478867d0e8a4f8632e2cb02e Mon Sep 17 00:00:00 2001
From: GuoWenxue <“guowenxue@gmail.com”>
Date: Fri, 29 Apr 2022 10:29:19 +0800
Subject: [PATCH] upate packet time to struct tm

---
 apue/project_socket/src/packet.c |   92 +++++++++++++++++++++++++--------------------
 1 files changed, 51 insertions(+), 41 deletions(-)

diff --git a/apue/project_socket/src/packet.c b/apue/project_socket/src/packet.c
index a904596..9bb680f 100644
--- a/apue/project_socket/src/packet.c
+++ b/apue/project_socket/src/packet.c
@@ -21,66 +21,76 @@
 
 int get_devid(char *devid, int size, int sn)
 {
-	if( !devid || size<DEVID_LEN )
-	{
-		log_error("Invalid input arugments\n");
-		return -1;
-	}
+    if( !devid || size<DEVID_LEN )
+    {
+        log_error("Invalid input arugments\n");
+        return -1;
+    }
 
-	memset(devid, 0, size);
-	snprintf(devid, size, "rpi#%04d", sn);
-	return 0;
+    memset(devid, 0, size);
+    snprintf(devid, size, "rpi#%04d", sn);
+    return 0;
 }
 
-int get_time(char *strtime, int size)
+int get_time(struct tm *ptm)
 {
+    if( !ptm )
+    {
+        log_error("Invalid input arugments\n");
+        return -1;
+    }
+
+
     time_t now = time(NULL);
-    struct tm *tnow = localtime(&now);
+    localtime_r(&now, ptm);
 
-	if( !strtime || size<TIME_LEN )
-	{
-		log_error("Invalid input arugments\n");
-		return -1;
-	}
-
-	snprintf(strtime, size, "%04d-%02d-%2d %02d:%02d:%02d",
-			tnow->tm_year+1900, tnow->tm_mon+1, tnow->tm_mday,
-			tnow->tm_hour, tnow->tm_min, tnow->tm_sec);
-
-	return 0;
+    return 0;
 }
 
 int packet_segmented_pack(pack_info_t *pack_info, char *pack_buf, int size)
 {
-	if( !pack_info || !pack_buf || size<=0 )
-	{
-		log_error("Invalid input arguments\n");
-		return -1;
-	}
+    char              strtime[TIME_LEN] = {'\0'};
+    struct tm        *ptm;
+
+    if( !pack_info || !pack_buf || size<=0 )
+    {
+        log_error("Invalid input arguments\n");
+        return -1;
+    }
+
+    ptm = &pack_info->sample_time;
+    snprintf(strtime, sizeof(strtime), "%04d-%02d-%2d %02d:%02d:%02d",
+            ptm->tm_year+1900, ptm->tm_mon+1, ptm->tm_mday,
+            ptm->tm_hour, ptm->tm_min, ptm->tm_sec);
+
 
     memset(pack_buf, 0, size);
+    snprintf(pack_buf, size, "%s|%s|%d.%d", pack_info->devid, strtime,
+            temper_integer(pack_info->temper), temper_fract(pack_info->temper));
 
-	snprintf(pack_buf, size, "%s|%s|%d.%d", pack_info->devid, pack_info->strtime,
-			temper_integer(pack_info->temper), temper_fract(pack_info->temper));
-
-	return strlen(pack_buf);
+    return strlen(pack_buf);
 }
 
 int packet_json_pack(pack_info_t *pack_info, char *pack_buf, int size)
 {
-	if( !pack_info || !pack_buf || size<=0 )
-	{
-		log_error("Invalid input arguments\n");
-		return -1;
-	}
+    char              strtime[TIME_LEN] = {'\0'};
+    struct tm        *ptm;
+
+    if( !pack_info || !pack_buf || size<=0 )
+    {
+        log_error("Invalid input arguments\n");
+        return -1;
+    }
+
+    ptm = &pack_info->sample_time;
+    snprintf(strtime, sizeof(strtime), "%04d-%02d-%2d %02d:%02d:%02d",
+            ptm->tm_year+1900, ptm->tm_mon+1, ptm->tm_mday,
+            ptm->tm_hour, ptm->tm_min, ptm->tm_sec);
 
     memset(pack_buf, 0, size);
+    snprintf(pack_buf, size, "{\"devid\":\"%s\", \"time\":\"%s\",\"temperature\":\"%d.%d\"}",
+            pack_info->devid, strtime, temper_integer(pack_info->temper), temper_fract(pack_info->temper));
 
-	snprintf(pack_buf, size, "{\"devid\":\"%s\", \"time\":\"%s\",\"temperature\":\"%d.%d\"}",
-            pack_info->devid, pack_info->strtime,
-            temper_integer(pack_info->temper), temper_fract(pack_info->temper));
-
-	return strlen(pack_buf);
+    return strlen(pack_buf);
 }
-
 

--
Gitblit v1.9.1