mirror of
				https://github.com/pelican-eggs/eggs.git
				synced 2025-11-04 10:58:06 +00:00 
			
		
		
		
	Improve wrapper
This commit is contained in:
		
							parent
							
								
									51439f3e5a
								
							
						
					
					
						commit
						bf1217839d
					
				
										
											Binary file not shown.
										
									
								
							@ -8,7 +8,7 @@
 | 
				
			|||||||
#include <time.h>
 | 
					#include <time.h>
 | 
				
			||||||
#include <sys/stat.h>
 | 
					#include <sys/stat.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void print_latest_log(const char* log_directory) {
 | 
					void print_latest_log(const char* log_directory, off_t* last_pos, off_t* last_size) {
 | 
				
			||||||
    DIR *dir;
 | 
					    DIR *dir;
 | 
				
			||||||
    struct dirent *entry;
 | 
					    struct dirent *entry;
 | 
				
			||||||
    time_t latest_time = 0;
 | 
					    time_t latest_time = 0;
 | 
				
			||||||
@ -39,14 +39,20 @@ void print_latest_log(const char* log_directory) {
 | 
				
			|||||||
        return;
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    printf("\nLatest log file: %s\n", latest_file);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    int fd = open(latest_file, O_RDONLY);
 | 
					    int fd = open(latest_file, O_RDONLY);
 | 
				
			||||||
    if (fd < 0) {
 | 
					    if (fd < 0) {
 | 
				
			||||||
        printf("Error opening file %s\n", latest_file);
 | 
					        printf("Error opening file %s\n", latest_file);
 | 
				
			||||||
        return;
 | 
					        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);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        char buffer[4096];
 | 
					        char buffer[4096];
 | 
				
			||||||
        int bytes_read;
 | 
					        int bytes_read;
 | 
				
			||||||
        int last_line_printed = 0; // Flag to check whether we have printed the last line
 | 
					        int last_line_printed = 0; // Flag to check whether we have printed the last line
 | 
				
			||||||
@ -75,9 +81,16 @@ void print_latest_log(const char* log_directory) {
 | 
				
			|||||||
            printf("\n");
 | 
					            printf("\n");
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Remember the last position and size that was read
 | 
				
			||||||
 | 
					        *last_pos = lseek(fd, 0, SEEK_CUR);
 | 
				
			||||||
 | 
					        *last_size = size;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    close(fd);
 | 
					    close(fd);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int main(int argc, char** argv) {
 | 
					int main(int argc, char** argv) {
 | 
				
			||||||
    if (argc < 2) {
 | 
					    if (argc < 2) {
 | 
				
			||||||
        printf("Usage: winewrapper wine_path wine_args exe_path exe_args\n");
 | 
					        printf("Usage: winewrapper wine_path wine_args exe_path exe_args\n");
 | 
				
			||||||
@ -104,12 +117,15 @@ int main(int argc, char** argv) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    sleep(30);
 | 
					    sleep(30);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    off_t last_pos = 0;
 | 
				
			||||||
 | 
					    off_t last_size = 0;
 | 
				
			||||||
    char* log_directory = "/home/container/SNM2020/Saved/Logs";
 | 
					    char* log_directory = "/home/container/SNM2020/Saved/Logs";
 | 
				
			||||||
    print_latest_log(log_directory);
 | 
					    print_latest_log(log_directory, &last_pos, &last_size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    while (1) {
 | 
					    while (1) {
 | 
				
			||||||
        sleep(1);
 | 
					        sleep(1);
 | 
				
			||||||
        print_latest_log(log_directory);
 | 
					        print_latest_log(log_directory, &last_pos, &last_size);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    kill(pid, SIGTERM);
 | 
					    kill(pid, SIGTERM);
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user