mirror of
https://github.com/parkervcp/eggs.git
synced 2024-11-29 10:22:58 +08:00
wrapper use time and not size
This commit is contained in:
parent
bf1217839d
commit
9c08f3fd5e
Binary file not shown.
@ -8,7 +8,7 @@
|
||||
#include <time.h>
|
||||
#include <sys/stat.h>
|
||||
|
||||
void print_latest_log(const char* log_directory, off_t* last_pos, off_t* last_size) {
|
||||
void print_latest_log(const char* log_directory, off_t* last_pos, time_t* last_time) {
|
||||
DIR *dir;
|
||||
struct dirent *entry;
|
||||
time_t latest_time = 0;
|
||||
@ -39,19 +39,18 @@ void print_latest_log(const char* log_directory, off_t* last_pos, off_t* last_si
|
||||
return;
|
||||
}
|
||||
|
||||
if (latest_time <= *last_time) {
|
||||
return;
|
||||
}
|
||||
|
||||
int fd = open(latest_file, O_RDONLY);
|
||||
if (fd < 0) {
|
||||
printf("Error opening file %s\n", latest_file);
|
||||
return;
|
||||
}
|
||||
|
||||
// Get the size of the file
|
||||
off_t size = lseek(fd, 0, SEEK_END);
|
||||
|
||||
// Check if the file size has increased since the last read
|
||||
if (size > *last_size) {
|
||||
// Move the file pointer to the beginning of the file
|
||||
lseek(fd, 0, SEEK_SET);
|
||||
// Move the file pointer to the last printed position
|
||||
lseek(fd, *last_pos, SEEK_SET);
|
||||
|
||||
char buffer[4096];
|
||||
int bytes_read;
|
||||
@ -81,16 +80,16 @@ void print_latest_log(const char* log_directory, off_t* last_pos, off_t* last_si
|
||||
printf("\n");
|
||||
}
|
||||
|
||||
// Remember the last position and size that was read
|
||||
// Remember the last position and time that was read
|
||||
*last_pos = lseek(fd, 0, SEEK_CUR);
|
||||
*last_size = size;
|
||||
}
|
||||
close(fd);
|
||||
*last_time = latest_time;
|
||||
|
||||
close(fd);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
int main(int argc, char** argv) {
|
||||
if (argc < 2) {
|
||||
printf("Usage: winewrapper wine_path wine_args exe_path exe_args\n");
|
||||
|
Loading…
Reference in New Issue
Block a user