[refactor] finished the refactoring for the macos version

This commit is contained in:
Abdellah El Morabit 2025-10-25 15:28:03 +03:00
parent 8ee16bf49e
commit b26fd0a638
4 changed files with 77 additions and 88 deletions

View File

@ -1,4 +1,12 @@
#include "lib.h"
/*
*
* Author: nasr
* Year: 2025-2026
*
*/
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <stddef.h> #include <stddef.h>
@ -7,16 +15,23 @@
#include <unistd.h> #include <unistd.h>
#include <sys/types.h> #include <sys/types.h>
#include "types.h" #include "types.h"
#include "lib.h"
#define MAXC 1024 #define MAXC 1024
#define MAXC_CHAR 256 #define MAXC_CHAR 256
#define CONVERT_BYTES_TO_GIGABYTES 107374182 #define CONVERT_BYTES_TO_GIGABYTES 107374182
#define D 1073741824 #define D 1073741824
void cpu_name(cpu_s cpu); /*
void cpu_threads(cpu_s cpu); * prototype function declarations
void cpu_temperature(cpu_s cpu); * cpu, ram, disk, device
void cpu_frequency(cpu_s cpu); *
*/
void cpu_name();
void cpu_threads();
void cpu_temperature();
void cpu_frequency();
void get_total(); void get_total();
void get_usage(); void get_usage();
@ -29,23 +44,13 @@ void device_os_version();
void device_hostname(); void device_hostname();
void device_model(); void device_model();
void init_device();
#ifdef __gnu_linux__ #ifdef __gnu_linux__
#include <sys/sysinfo.h> #include <sys/sysinfo.h>
void init_device() {
device_s _device; void cpu_name() {
_device.&name = device_model();
_device.&hostname =
}
void cpu_name(){
int buffer_size = 256; int buffer_size = 256;
char cpu_name[buffer_size]; char cpu_name[buffer_size];
@ -70,7 +75,7 @@ void cpu_name(){
} }
} }
_cpu.name = cpu_name; u_cpu->name = cpu_name;
} }
@ -80,7 +85,7 @@ void cpu_frequency() {
FILE *fp = fopen("/proc/cpuinfo", "r"); FILE *fp = fopen("/proc/cpuinfo", "r");
if (!fp) { if (!fp) {
printf("can't open /proc/cpuinfo"); printf("can't open /proc/cpuinfo");
return NULL; return;
} }
while (fgets(buffer, MAXC_CHAR, fp)) { while (fgets(buffer, MAXC_CHAR, fp)) {
@ -95,57 +100,43 @@ void cpu_frequency() {
} }
fclose(fp); fclose(fp);
return buffer; u_cpu->frequency = buffer;
} }
return NULL; return;
} }
unsigned long get_total(){ void mem_size() {
struct sysinfo info; struct sysinfo info;
if (sysinfo(&info) != 0) { if (sysinfo(&info) != 0) {
perror("sysinfo"); perror("sysinfo");
return 1; return;
} }
long total_ram = info.totalram * info.mem_unit; long total_ram = info.totalram * info.mem_unit;
return total_ram; u_ram->total = total_ram;
} }
void mem_size(){
void av_mem_size() {
struct sysinfo info; struct sysinfo info;
if (sysinfo(&info) != 0) { if (sysinfo(&info) != 0) {
perror("sysinfo"); perror("sysinfo");
return 1;
}
long total_ram = info.totalram * info.mem_unit;
return total_ram;
}
void av_mem_size()
{
struct sysinfo info;
if (sysinfo(&info) != 0) {
perror("sysinfo");
return 1;
} }
long total_ram = info.totalram * info.mem_unit; long total_ram = info.totalram * info.mem_unit;
long free_ram = info.freeram * info.mem_unit; long free_ram = info.freeram * info.mem_unit;
return total_ram - free_ram; u_ram->available = free_ram;
} }
void cpu_temperature() void cpu_temperature() {
{
int delay = 0;
while (1) while (1)
{ {
sleep(delay); sleep(delay);
@ -165,31 +156,27 @@ void cpu_temperature()
} }
} }
unsigned long get_usage()
{
struct sysinfo info;
if (sysinfo(&info) != 0) { void device_up_time() {
perror("sysinfo");
return 1;
}
long total_ram = info.totalram * info.mem_unit;
long free_ram = info.freeram * info.mem_unit;
return total_ram - free_ram;
}
unsigned long device_up_time(){
struct sysinfo info; struct sysinfo info;
if (sysinfo(&info) == -1) if (sysinfo(&info) == -1)
perror("sysinfo"); perror("sysinfo");
return info.uptime; u_device->uptime = info.uptime;
}
void device_mdoel() {
return;
} }
#endif #endif
#ifdef __APPLE__ #ifdef __APPLE__
#include <sys/sysctl.h> #include <sys/sysctl.h>
@ -211,7 +198,7 @@ void cpu_name() {
return; return;
} }
_cpu.name = name; u_cpu->name = name;
return; return;
} }
@ -222,7 +209,7 @@ void cpu_threads() {
if (sysctlbyname("machdep.cpu.thread_count", &count, &len, NULL, 0) < 0) if (sysctlbyname("machdep.cpu.thread_count", &count, &len, NULL, 0) < 0)
perror("error in retrieving the cpu threads count\n"); perror("error in retrieving the cpu threads count\n");
_cpu.threads = count; u_cpu->threads = count;
return; return;
} }
@ -237,9 +224,9 @@ void cpu_frequency(){
return; return;
} }
void cpu_temperature(cpu_s cpu) void cpu_temperature()
{ {
cpu.temperature = 0; u_cpu->temperature = 0;
return; return;
} }
@ -249,7 +236,7 @@ void mem_size() {
if (sysctlbyname("hw.memsize", &size, &len, NULL, 0) < 0) if (sysctlbyname("hw.memsize", &size, &len, NULL, 0) < 0)
perror("error in retrieving the memory size"); perror("error in retrieving the memory size");
_ram.total = size / D; u_ram->total = size / D;
} }
void mem_av_size() { void mem_av_size() {
@ -258,7 +245,7 @@ void mem_av_size() {
if (sysctlbyname("hw.memsize_usable", &size, &len, NULL, 0) < 0) if (sysctlbyname("hw.memsize_usable", &size, &len, NULL, 0) < 0)
perror("error in retrieving the available memory size"); perror("error in retrieving the available memory size");
_ram.available = size / D; u_ram->available = size / D;
} }
void device_hostname(){ void device_hostname(){
@ -277,7 +264,7 @@ void device_hostname(){
return ; return ;
} }
_device.name = name; u_device->name = name;
return ; return ;
} }
@ -293,7 +280,7 @@ void device_up_time(){
} }
} }
void device_model(device_s _device){ void device_model(){
char *model_name; char *model_name;
size_t size = 0; size_t size = 0;
@ -309,12 +296,12 @@ void device_model(device_s _device){
return; return;
} }
_device.name = model_name; u_device->name = model_name;
return; return;
} }
void device_os_version(device_s _device) { void device_os_version() {
char *os_version; char *os_version;
size_t size = 0; size_t size = 0;
@ -330,21 +317,10 @@ void device_os_version(device_s _device) {
return ; return ;
} }
_device.os_version = os_version; u_device->os_version = os_version;
return; return;
} }
void init_device() {
device_s _device;
_device.name = device_model(_device);
_device.hostname =
}
#endif #endif

View File

@ -1,10 +1,12 @@
#ifndef LIB_H #ifndef LIB_L
#define LIB_H #ifndef LIB_O
#define LIB_L
#define LIB_O
#include "types.h" #include "types.h"
#ifdef __APPLE__
void cpu_name(cpu_s cpu); void cpu_name();
void cpu_threads(); void cpu_threads();
void cpu_temperature(); void cpu_temperature();
void cpu_frequency(); void cpu_frequency();
@ -18,8 +20,11 @@ void ram_info();
void mem_size(); void mem_size();
void mem_av_size(); void mem_av_size();
void get_device_info(); void device_os_version();
void get_os_version(); void device_model();
void device_up_time();
void device_model();
#endif #endif
#endif #endif

View File

@ -1,9 +1,10 @@
#include <pthread.h> #include <pthread.h>
#include <curl/curl.h> #include <curl/curl.h>
#include <cjson/cJSON.h> #include <cjson/cJSON.h>
#include "lib.h"
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#include "lib.h"
void *gather_cpu_information(); void *gather_cpu_information();
void *gather_ram_information(); void *gather_ram_information();

View File

@ -4,7 +4,7 @@
typedef struct { typedef struct {
char* name; char* name;
int frequency; char* frequency;
int temperature; int temperature;
int threads; int threads;
@ -34,4 +34,11 @@ typedef struct {
} device_s; } device_s;
extern cpu_s *u_cpu ;
extern ram_s *u_ram ;
extern disk_s *u_disk ;
extern device_s *u_device ;
#endif #endif