check open file before close()
This commit is contained in:
parent
e0d7d7ede1
commit
46661f64e7
1 changed files with 5 additions and 4 deletions
|
@ -666,10 +666,11 @@ void get_info()
|
||||||
#else
|
#else
|
||||||
FILE *cpuinfo = popen("sysctl -a | egrep -i 'hw.model'", "r");
|
FILE *cpuinfo = popen("sysctl -a | egrep -i 'hw.model'", "r");
|
||||||
#endif
|
#endif
|
||||||
FILE *host_model_info = fopen("/sys/devices/virtual/dmi/id/board_name", "r");
|
FILE *host_model_info = fopen("/sys/devices/virtual/dmi/id/board_name", "r"); // first try open the file
|
||||||
if (!host_model_info)
|
if (!host_model_info) // if failed
|
||||||
if ((host_model_info = fopen("/sys/devices/virtual/dmi/id/product_name", "r")) != NULL)
|
host_model_info = fopen("/sys/devices/virtual/dmi/id/product_name", "r"); // try open another file
|
||||||
fclose(host_model_info);
|
if(host_model_info) // if one of the file could be open then close it
|
||||||
|
fclose(host_model_info);
|
||||||
#ifdef __WINDOWS__
|
#ifdef __WINDOWS__
|
||||||
host_model_info = popen("wmic computersystem get model", "r");
|
host_model_info = popen("wmic computersystem get model", "r");
|
||||||
while (fgets(line, sizeof(line), host_model_info))
|
while (fgets(line, sizeof(line), host_model_info))
|
||||||
|
|
Loading…
Reference in a new issue