/* * get_data.c - Part of AFD, an automatic file distribution program. * Copyright (c) 1997 - 2014 Holger Kiehl * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "afddefs.h" DESCR__S_M3 /* ** NAME ** get_data - searches input log files for data ** ** SYNOPSIS ** void get_data(void) ** ** DESCRIPTION ** This function searches for the selected data in the input ** log file of the AFD. The following things can be selected: ** start & end time, file name, file length, directory and ** recipient. Only selected data will be shown in the list ** widget. ** ** RETURN VALUES ** None. ** ** AUTHOR ** H.Kiehl ** ** HISTORY ** 27.05.1997 H.Kiehl Created ** 15.02.1999 H.Kiehl Multiple recipients. ** 13.04.2002 Separator definable via SEPARATOR_CHAR. ** */ DESCR__E_M3 #include /* sprintf() */ #include /* strerror(), strcmp() */ #include /* malloc(), realloc(), free(), strtod() */ #include /* time() */ #ifdef TM_IN_SYS_TIME # include #endif #include /* close() */ #include #include #include #ifdef HAVE_MMAP # include /* mmap(), munmap() */ # ifndef MAP_FILE /* Required for BSD */ # define MAP_FILE 0 /* All others do not need it */ # endif #endif #include #include #include #include #include #include "logdefs.h" #include "mafd_ctrl.h" #include "show_ilog.h" #define QUICK_SEARCH 50000 #define SLOW_SEARCH 400 /* External global variables. */ extern Display *display; extern Window main_window; extern XtAppContext app; extern Widget appshell, /* CHECK_INTERRUPT() */ listbox_w, scrollbar_w, statusbox_w, special_button_w, summarybox_w; extern int continues_toggle_set, gt_lt_sign, log_date_length, max_input_log_files, no_of_search_dirs, no_of_search_dirids, no_of_search_hosts, *search_dir_length, special_button_flag, file_name_length, no_of_log_files; extern unsigned int all_list_items, *search_dirid; extern size_t search_file_size; extern time_t start_time_val, end_time_val; extern char *p_work_dir, search_file_name[], **search_dir, *search_dir_filter, **search_recipient, **search_user, summary_str[], total_summary_str[]; extern struct item_list *il; extern struct info_data id; extern struct sol_perm perm; /* Local global variables. */ static unsigned int total_no_files, unprintable_chars; static int interval_id_set = NO, last_file_no, log_fd = -1; static time_t local_start_time, local_end_time, first_date_found, start; static off_t log_offset; static ino_t log_inode; static double file_size; static char *p_file_name, *p_file_size, log_file[MAX_PATH_LENGTH], *p_log_file, line[MAX_OUTPUT_LINE_LENGTH + SHOW_LONG_FORMAT + 1]; static XmStringTable str_list; static XtIntervalId interval_id_log; /* Local function prototypes. */ static char *search_time(char *, time_t, time_t, time_t, size_t); static void check_log_updates(Widget), display_data(int, time_t, time_t), end_log_updates(void), extract_data(char *, int, int), no_criteria(register char *, char *, int, char *, off_t), file_name_only(register char *, char *, int, char *, off_t), file_size_only(register char *, char *, int, char *, off_t), file_name_and_size(register char *, char *, int, char *, off_t), recipient_only(register char *, char *, int, char *, off_t), file_name_and_recipient(register char *, char *, int, char *, off_t), file_size_and_recipient(register char *, char *, int, char *, off_t), file_name_size_recipient(register char *, char *, int, char *, off_t); #define REALLOC_OFFSET_BUFFER() \ { \ if ((item_counter == 0) || (item_counter > prev_item_counter)) \ { \ int new_int_size, \ new_char_size, \ new_off_t_size; \ \ new_char_size = item_counter + LINES_BUFFERED + 1; \ new_int_size = new_char_size * sizeof(int); \ new_off_t_size = new_char_size * sizeof(off_t); \ prev_item_counter = item_counter; \ \ if (((il[file_no].offset = realloc(il[file_no].offset, new_int_size)) == NULL) || \ ((il[file_no].line_offset = realloc(il[file_no].line_offset, new_off_t_size)) == NULL))\ { \ (void)xrec(FATAL_DIALOG, "realloc() error : %s (%s %d)",\ strerror(errno), __FILE__, __LINE__);\ return; \ } \ } \ } #define IGNORE_ENTRY() \ { \ while (*ptr != '\n')\ ptr++; \ ptr++; i--; line_counter++;\ continue; \ } #define INSERT_TIME() \ { \ (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length);\ time_when_transmitted = (time_t)str2timet(ptr_start_line, NULL, 16);\ if (first_date_found == -1) \ { \ first_date_found = time_when_transmitted; \ } \ p_ts = localtime(&time_when_transmitted); \ CONVERT_TIME(); \ } #define COMMON_BLOCK() \ { \ ptr++; \ il[file_no].offset[item_counter] = (int)(ptr - p_start_log_file + offset);\ \ if ((no_of_search_dirs > 0) || (no_of_search_dirids > 0)) \ { \ int count = 0, \ gotcha = NO, \ kk; \ char dir_id_str[15 + 1]; \ \ while ((*ptr != SEPARATOR_CHAR) && (*ptr != '\n') && (count < 15))\ { \ dir_id_str[count] = *ptr; \ count++; ptr++; \ } \ dir_id_str[count] = '\0'; \ id.dir_id = (unsigned int)strtoul(dir_id_str, NULL, 16); \ id.dir[0] = '\0'; \ if (no_of_search_dirs > 0) \ { \ get_info(GOT_JOB_ID_DIR_ONLY); \ count = strlen((char *)id.dir); \ id.dir[count] = SEPARATOR_CHAR; \ id.dir[count + 1] = '\0'; \ } \ \ for (kk = 0; kk < no_of_search_dirids; kk++) \ { \ if (search_dirid[kk] == id.dir_id) \ { \ gotcha = YES; \ break; \ } \ } \ if (gotcha == NO) \ { \ for (kk = 0; kk < no_of_search_dirs; kk++) \ { \ if (search_dir_filter[kk] == YES) \ { \ if (sfilter(search_dir[kk], (char *)id.dir, SEPARATOR_CHAR) == 0)\ { \ gotcha = YES; \ break; \ } \ } \ else \ { \ if (search_dir_length[kk] == count) \ { \ if (strncmp(search_dir[kk], (char *)id.dir, count) == 0)\ { \ gotcha = YES; \ break; \ } \ } \ } \ } \ } \ if (gotcha == NO) \ { \ IGNORE_ENTRY(); \ } \ } \ while ((*ptr != '\n') && (*ptr != '\0')) \ { \ ptr++; \ } \ line_counter++; \ item_counter++; \ str_list[i] = XmStringCreateLocalized(line); \ ptr++; \ } #define CHECK_LIST_LIMIT() \ { \ if ((perm.list_limit > 0) && (item_counter > perm.list_limit)) \ { \ char msg_buffer[40]; \ \ (void)sprintf(msg_buffer, "List limit (%d) reached!", \ perm.list_limit); \ show_message(statusbox_w, msg_buffer); \ break; \ } \ } #define MACRO_DEBUG /*############################### get_data() ############################*/ void get_data(void) { int i, j, start_file_no = -1, end_file_no = -1; time_t end; char status_message[MAX_MESSAGE_LENGTH]; struct stat stat_buf; XmString xstr; /* At start always reset these values. */ if (interval_id_set == YES) { XtRemoveTimeOut(interval_id_log); interval_id_set = NO; } if (log_fd != -1) { if (close(log_fd) == -1) { (void)xrec(FATAL_DIALOG, "close() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); return; } else { log_fd = -1; } } /* Prepare log file name. */ p_log_file = log_file; no_of_log_files = max_input_log_files; p_log_file += sprintf(log_file, "%s%s/%s", p_work_dir, LOG_DIR, INPUT_BUFFER_FILE); local_start_time = start_time_val; local_end_time = end_time_val; for (i = 0; i < no_of_log_files; i++) { (void)sprintf(p_log_file, "%d", i); if (stat(log_file, &stat_buf) == 0) { if (((stat_buf.st_mtime + SWITCH_FILE_TIME) >= local_start_time) || (start_file_no == -1)) { start_file_no = i; } if (local_end_time == -1) { if (end_file_no == -1) { end_file_no = i; } } else if ((stat_buf.st_mtime >= local_end_time) || (end_file_no == -1)) { end_file_no = i; } } } no_of_log_files = start_file_no - end_file_no + 1; if ((str_list = (XmStringTable)XtMalloc(LINES_BUFFERED * sizeof(XmString))) == NULL) { (void)xrec(FATAL_DIALOG, "XtMalloc() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); return; } /* Allocate memory for item list. */ if (il == NULL) { if ((il = malloc(max_input_log_files * sizeof(struct item_list))) == NULL) { (void)xrec(FATAL_DIALOG, "malloc() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); return; } for (i = 0; i < max_input_log_files; i++) { il[i].fp = NULL; il[i].no_of_items = 0; il[i].offset = NULL; il[i].line_offset = NULL; } } else { for (i = 0; i < max_input_log_files; i++) { if (il[i].fp != NULL) { if (fclose(il[i].fp) == EOF) { (void)fprintf(stderr, "fclose() error : %s (%s %d)\n", strerror(errno), __FILE__, __LINE__); } il[i].fp = NULL; } il[i].no_of_items = 0; if (il[i].line_offset != NULL) { free(il[i].line_offset); il[i].line_offset = NULL; } if (il[i].offset != NULL) { free(il[i].offset); il[i].offset = NULL; } } } /* Initialise all pointer in line. */ p_file_name = line + 16; p_file_size = p_file_name + file_name_length + 1; *(line + MAX_OUTPUT_LINE_LENGTH + file_name_length) = '\0'; special_button_flag = STOP_BUTTON; xstr = XmStringCreateLtoR("Stop", XmFONTLIST_DEFAULT_TAG); XtVaSetValues(special_button_w, XmNlabelString, xstr, NULL); XmStringFree(xstr); summary_str[0] = ' '; summary_str[1] = '\0'; SHOW_SUMMARY_DATA(); (void)strcpy(status_message, "Searching -"); SHOW_MESSAGE(); CHECK_INTERRUPT(); start = time(NULL); file_size = 0.0; total_no_files = 0; first_date_found = -1; unprintable_chars = 0; j = 0; for (i = start_file_no; ((i >= end_file_no) && (special_button_flag != STOP_BUTTON_PRESSED)); i--, j++) { (void)sprintf(p_log_file, "%d", i); (void)extract_data(log_file, j, i); if ((perm.list_limit > 0) && (total_no_files >= perm.list_limit)) { break; } } end = time(NULL); if ((continues_toggle_set == NO) || (log_fd == -1) || ((end > end_time_val) && (end_time_val != -1))) { set_sensitive(); if ((perm.list_limit == 0) || (total_no_files < perm.list_limit)) { if (total_no_files == 0) { i = sprintf(status_message, "No data found. "); } else { i = 0; } #if SIZEOF_TIME_T == 4 i += sprintf(status_message + i, "Search time: %lds", #else i += sprintf(status_message + i, "Search time: %llds", #endif (pri_time_t)(end - start)); if (unprintable_chars > 0) { (void)sprintf(status_message + i, " (%u unprintable chars!)", unprintable_chars); } SHOW_MESSAGE(); } special_button_flag = SEARCH_BUTTON; xstr = XmStringCreateLtoR("Search", XmFONTLIST_DEFAULT_TAG); XtVaSetValues(special_button_w, XmNlabelString, xstr, NULL); XmStringFree(xstr); XtFree((char *)str_list); } else { interval_id_set = YES; interval_id_log = XtAppAddTimeOut(app, LOG_CHECK_INTERVAL, (XtTimerCallbackProc)check_log_updates, listbox_w); } return; } /*+++++++++++++++++++++++++++++ extract_data() ++++++++++++++++++++++++++*/ static void extract_data(char *current_log_file, int file_no, int log_no) { int fd; time_t earliest_entry, latest_entry; register char *ptr, *ptr_start; char *src, *tmp_ptr, *ptr_end; struct stat stat_buf; /* Check if file is there and get its size. */ if (stat(current_log_file, &stat_buf) < 0) { if (errno == ENOENT) { /* For some reason the file is not there. So lets */ /* assume we have found nothing. */ return; } else { (void)xrec(WARN_DIALOG, "Failed to stat() %s : %s (%s %d)", current_log_file, strerror(errno), __FILE__, __LINE__); return; } } /* Make sure there is data in the log file. */ if (stat_buf.st_size == 0) { return; } if ((fd = open(current_log_file, O_RDONLY)) == -1) { (void)xrec(FATAL_DIALOG, "Failed to open() %s : %s (%s %d)", current_log_file, strerror(errno), __FILE__, __LINE__); return; } if ((il[file_no].fp = fdopen(fd, "r")) == NULL) { (void)xrec(FATAL_DIALOG, "fdopen() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); return; } #ifdef HAVE_MMAP if ((src = mmap(NULL, stat_buf.st_size, PROT_READ, (MAP_FILE | MAP_SHARED), fd, 0)) == (caddr_t) -1) { (void)xrec(FATAL_DIALOG, "Failed to mmap() %s : %s (%s %d)", current_log_file, strerror(errno), __FILE__, __LINE__); (void)close(fd); return; } #else if ((src = malloc(stat_buf.st_size)) == NULL) { (void)xrec(FATAL_DIALOG, "malloc() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); (void)close(fd); return; } if (read(fd, src, stat_buf.st_size) != stat_buf.st_size) { (void)xrec(FATAL_DIALOG, "Failed to read() from %s : %s (%s %d)", current_log_file, strerror(errno), __FILE__, __LINE__); free(src); (void)close(fd); return; } #endif /* * Now we have the source data in the buffer 'src'. Lets * search for the stuff the user wants to see. First * collect this data in the buffer 'dst' and only after * we have found all data will 'dst' be displayed. The * destination buffer 'dst' will be realloced in sizes * 10 * MAX_OUTPUT_LINE_LENGTH characters. Hope this will reduce * memory usage a little bit. */ /* Get latest entry. */ tmp_ptr = src + stat_buf.st_size - 2; do { while ((*tmp_ptr != '\n') && (src != tmp_ptr)) { tmp_ptr--; } if (*tmp_ptr == '\n') { ptr = tmp_ptr + 1; if (*ptr == '#') { tmp_ptr -= 1; } } else { if (*tmp_ptr == '#') { /* Free all memory we have allocated. */ #ifdef HAVE_MMAP if (munmap(src, stat_buf.st_size) < 0) { (void)xrec(ERROR_DIALOG, "munmap() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); } #else free(src); #endif return; } ptr = tmp_ptr; } } while ((*ptr == '#') && (src != tmp_ptr)); if (*ptr == '#') { /* Free all memory we have allocated. */ #ifdef HAVE_MMAP if (munmap(src, stat_buf.st_size) < 0) { (void)xrec(ERROR_DIALOG, "munmap() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); } #else free(src); #endif return; } latest_entry = (time_t)str2timet(ptr, NULL, 16); /* Get earliest entry. */ ptr = src; while (*ptr == '#') { while (*ptr != '\n') { if (ptr == (src + stat_buf.st_size)) { /* Free all memory we have allocated. */ #ifdef HAVE_MMAP if (munmap(src, stat_buf.st_size) < 0) { (void)xrec(ERROR_DIALOG, "munmap() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); } #else free(src); #endif return; } ptr++; } ptr++; } earliest_entry = (time_t)str2timet(ptr, NULL, 16); if (local_start_time == -1) { ptr_start = src; ptr_end = search_time(src, local_end_time, earliest_entry, latest_entry, stat_buf.st_size); } else { /* * Search for the first entry of 'local_start_time'. Get the very * first time entry and see if this is not already higher than * 'local_start_time', ie this is our first entry. */ if (earliest_entry >= local_start_time) { ptr_start = src; } else { ptr_start = search_time(src, local_start_time, earliest_entry, latest_entry, stat_buf.st_size); } ptr_end = search_time(src, local_end_time, earliest_entry, latest_entry, stat_buf.st_size); } if (ptr_start == ptr_end) { /* Free all memory we have allocated. */ #ifdef HAVE_MMAP if (munmap(src, stat_buf.st_size) < 0) { (void)xrec(ERROR_DIALOG, "munmap() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); } #else free(src); #endif return; } if ((log_no == 0) && ((end_time_val == -1) || (time(NULL) < end_time_val))) { /* * NOTE: We need to have this opened twice so that the function * called with XtAppAddTimeOut() has its own file descriptor * position within this file. */ if ((log_fd = open(current_log_file, O_RDONLY)) == -1) { (void)xrec(FATAL_DIALOG, "Failed to open() %s : %s (%s %d)", current_log_file, strerror(errno), __FILE__, __LINE__); return; } if (lseek(log_fd, stat_buf.st_size, SEEK_SET) == (off_t)-1) { (void)xrec(FATAL_DIALOG, "Failed to lssek() in %s : %s (%s %d)", current_log_file, strerror(errno), __FILE__, __LINE__); return; } log_offset = stat_buf.st_size; log_inode = stat_buf.st_ino; last_file_no = file_no; } /* * So, start and end are found. Now lets do the real search, * ie search for specific file names, recipient, etc. */ ptr = ptr_start; if ((search_file_name[0] == '\0') && (search_file_size == -1) && (no_of_search_hosts == 0)) { no_criteria(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] != '\0') && (search_file_size == -1) && (no_of_search_hosts == 0)) { file_name_only(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] == '\0') && (search_file_size != -1) && (no_of_search_hosts == 0)) { file_size_only(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] != '\0') && (search_file_size != -1) && (no_of_search_hosts == 0)) { file_name_and_size(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] == '\0') && (search_file_size == -1) && (no_of_search_hosts != 0)) { recipient_only(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] != '\0') && (search_file_size == -1) && (no_of_search_hosts != 0)) { file_name_and_recipient(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] == '\0') && (search_file_size != -1) && (no_of_search_hosts != 0)) { file_size_and_recipient(ptr_start, ptr_end, file_no, src, 0); } else if ((search_file_name[0] != '\0') && (search_file_size != -1) && (no_of_search_hosts != 0)) { file_name_size_recipient(ptr_start, ptr_end, file_no, src, 0); } else { (void)xrec(FATAL_DIALOG, "What's this!? Impossible! (%s %d)", __FILE__, __LINE__); return; } /* Free all memory we have allocated. */ get_info_free(); #ifdef HAVE_MMAP if (munmap(src, stat_buf.st_size) < 0) { (void)xrec(ERROR_DIALOG, "munmap() error : %s (%s %d)", strerror(errno), __FILE__, __LINE__); } #else free(src); #endif return; } /*++++++++++++++++++++++++++ check_log_updates() ++++++++++++++++++++++++*/ static void check_log_updates(Widget w) { static int rotate; interval_id_set = NO; if (special_button_flag == STOP_BUTTON_PRESSED) { end_log_updates(); return; } if ((end_time_val == -1) || (time(NULL) < end_time_val)) { struct stat stat_buf; if (fstat(log_fd, &stat_buf) == -1) { (void)xrec(FATAL_DIALOG, "fstat() error: %s (%s %d)\n", strerror(errno), __FILE__, __LINE__); } if (log_inode != stat_buf.st_ino) { /* * This seems from the point of programming the simplest. It * is not efficient, but since the logs are rotated daily once * seems an acceptable solution. */ XmListDeleteAllItems(listbox_w); get_data(); XmListSetBottomPos(listbox_w, 0); return; } if (stat_buf.st_size > log_offset) { off_t diff_size; char *ptr_start, *ptr_end; diff_size = stat_buf.st_size - log_offset; if ((ptr_start = malloc(diff_size)) == NULL) { #if SIZEOF_OFF_T == 4 (void)xrec(FATAL_DIALOG, "malloc() error [%ld bytes] : %s (%s %d)", #else (void)xrec(FATAL_DIALOG, "malloc() error [%lld bytes] : %s (%s %d)", #endif (pri_off_t)diff_size, strerror(errno), __FILE__, __LINE__); } if (read(log_fd, ptr_start, diff_size) != diff_size) { (void)xrec(FATAL_DIALOG, "read() error: %s (%s %d)\n", strerror(errno), __FILE__, __LINE__); } ptr_end = ptr_start + diff_size; if ((search_file_name[0] == '\0') && (search_file_size == -1) && (no_of_search_hosts == 0)) { no_criteria(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] != '\0') && (search_file_size == -1) && (no_of_search_hosts == 0)) { file_name_only(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] == '\0') && (search_file_size != -1) && (no_of_search_hosts == 0)) { file_size_only(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] != '\0') && (search_file_size != -1) && (no_of_search_hosts == 0)) { file_name_and_size(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] == '\0') && (search_file_size == -1) && (no_of_search_hosts != 0)) { recipient_only(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] != '\0') && (search_file_size == -1) && (no_of_search_hosts != 0)) { file_name_and_recipient(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] == '\0') && (search_file_size != -1) && (no_of_search_hosts != 0)) { file_size_and_recipient(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else if ((search_file_name[0] != '\0') && (search_file_size != -1) && (no_of_search_hosts != 0)) { file_name_size_recipient(ptr_start, ptr_end, last_file_no, ptr_start, log_offset); } else { (void)xrec(FATAL_DIALOG, "What's this!? Impossible! (%s %d)", __FILE__, __LINE__); } get_info_free(); free(ptr_start); log_offset = stat_buf.st_size; XmListSetBottomPos(listbox_w, 0); } else { char status_message[13]; (void)memset(status_message, ' ', 12); status_message[12] = '\0'; status_message[rotate] = '.'; rotate++; if (rotate == 12) { rotate = 0; } SHOW_MESSAGE(); } interval_id_set = YES; interval_id_log = XtAppAddTimeOut(app, LOG_CHECK_INTERVAL, (XtTimerCallbackProc)check_log_updates, listbox_w); } else { end_log_updates(); } return; } /*-------------------------- end_log_updates() --------------------------*/ static void end_log_updates(void) { time_t diff_time; char *ptr, status_message[MAX_MESSAGE_LENGTH]; XmString xstr; if (total_no_files != 0) { ptr = status_message + sprintf(status_message, "Search+Wait time: "); } else { ptr = status_message + sprintf(status_message, "No data found. Search+Wait time: "); } diff_time = time(NULL) - start; if (diff_time > 3600) { int hours, left, min; hours = diff_time / 3600; left = diff_time % 3600; min = left / 60; left = left % 60; (void)sprintf(ptr, "%dh %dm %ds", hours, min, left); } else if (diff_time > 60) { int left, min; min = diff_time / 60; left = diff_time % 60; (void)sprintf(ptr, "%dm %ds", min, left); } else { #if SIZEOF_TIME_T == 4 (void)sprintf(ptr, "%lds", (pri_time_t)diff_time); #else (void)sprintf(ptr, "%llds", (pri_time_t)diff_time); #endif } SHOW_MESSAGE(); special_button_flag = SEARCH_BUTTON; xstr = XmStringCreateLtoR("Search", XmFONTLIST_DEFAULT_TAG); XtVaSetValues(special_button_w, XmNlabelString, xstr, NULL); XmStringFree(xstr); XtFree((char *)str_list); return; } /*------------------------------ search_time() --------------------------*/ static char * search_time(char *src, time_t search_time_val, time_t earliest_entry, time_t latest_entry, size_t size) { char *ptr, *bs_ptr; time_t time_val; if ((search_time_val == -1) || (latest_entry < search_time_val)) { return(src + size); } else { /* * YUCK! Now we have to search for it! We know the * time of the very first entry and the last entry. So * lets see if 'search_time_val' is closer to the beginning * or end in our buffer. Thats where we will start our * search. */ if (abs(search_time_val - earliest_entry) > abs(latest_entry - search_time_val)) { /* Start search from end. */ bs_ptr = src + size - 2; do { ptr = bs_ptr; ptr -= log_date_length + 1 + 1; while ((ptr >= src) && (*ptr != '\n')) { ptr--; } bs_ptr = ptr - 1; ptr++; if (*ptr == '#') { time_val = search_time_val; } else { time_val = (time_t)str2timet(ptr, NULL, 16); } } while ((time_val >= search_time_val) && (ptr > src)); while (*ptr != '\n') { ptr++; } } else /* Start search from beginning. */ { ptr = src; do { ptr += log_date_length + 1 + 1; while (*ptr != '\n') { ptr++; } ptr++; if (*ptr == '#') { time_val = search_time_val - 1; } else { time_val = (time_t)str2timet(ptr, NULL, 16); } } while ((time_val < search_time_val) && (ptr < (src + size))); while (*ptr != '\n') { ptr--; } } return(ptr + 1); } } /*------------------------------ no_criteria() --------------------------*/ /* ------------- */ /* Description: Reads everyting from ptr to ptr_end. It only checks if */ /* the transfer type is the correct one. */ /*-----------------------------------------------------------------------*/ static void no_criteria(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line; struct tm *p_ts; /* The easiest case! */ #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % QUICK_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; j = 0; il[file_no].line_offset[item_counter] = (off_t)(ptr - p_start_log_file + offset); ptr += log_date_length + 1; INSERT_TIME(); while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } ptr++; j++; } /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Write file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif print_file_size(p_file_size, (off_t)tmp_file_size); /* Write transfer duration, job ID and archive directory. */ /* Also check if we have to check for directory name. */ #ifndef MACRO_DEBUG COMMON_BLOCK(); #else ptr++; il[file_no].offset[item_counter] = (int)(ptr - p_start_log_file + offset); if ((no_of_search_dirs > 0) || (no_of_search_dirids > 0)) { int count = 0, gotcha = NO, kk; char dir_id_str[15 + 1]; while ((*ptr != SEPARATOR_CHAR) && (*ptr != '\n') && (count < 15)) { dir_id_str[count] = *ptr; count++; ptr++; } dir_id_str[count] = '\0'; id.dir_id = (unsigned int)strtoul(dir_id_str, NULL, 16); id.dir[0] = '\0'; if (no_of_search_dirs > 0) { get_info(GOT_JOB_ID_DIR_ONLY); count = strlen((char *)id.dir); id.dir[count] = SEPARATOR_CHAR; id.dir[count + 1] = '\0'; } for (kk = 0; kk < no_of_search_dirids; kk++) { if (search_dirid[kk] == id.dir_id) { gotcha = YES; break; } } if (gotcha == NO) { for (kk = 0; kk < no_of_search_dirs; kk++) { if (search_dir_filter[kk] == YES) { if (sfilter(search_dir[kk], (char *)id.dir, SEPARATOR_CHAR) == 0) { gotcha = YES; break; } } else { if (search_dir_length[kk] == count) { if (strncmp(search_dir[kk], (char *)id.dir, count) == 0) { gotcha = YES; break; } } } } } if (gotcha == NO) { IGNORE_ENTRY(); } } while ((*ptr != '\n') && (*ptr != '\0')) { ptr++; } line_counter++; item_counter++; str_list[i] = XmStringCreateLocalized(line); ptr++; #endif file_size += tmp_file_size; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*---------------------------- file_name_only() -------------------------*/ /* ---------------- */ /* Description: Reads everyting from ptr to ptr_end and search for the */ /* file name search_file_name. It also checks if the */ /* transfer type is the correct one. */ /*-----------------------------------------------------------------------*/ static void file_name_only(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % QUICK_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; ptr += log_date_length + 1; if (sfilter(search_file_name, ptr, SEPARATOR_CHAR) == 0) { il[file_no].line_offset[item_counter] = (off_t)(ptr - (log_date_length + 1) - p_start_log_file + offset); INSERT_TIME(); j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } ptr++; j++; } } else { IGNORE_ENTRY(); } /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Write file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif print_file_size(p_file_size, (off_t)tmp_file_size); /* Write transfer duration, job ID and archive directory. */ /* Also check if we have to check for directory name. */ COMMON_BLOCK(); file_size += tmp_file_size; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*---------------------------- file_size_only() -------------------------*/ /* ---------------- */ /* Description: Reads everyting from ptr to ptr_end and search for any */ /* file that is <, >, or = search_file_size. It also checks */ /* if the transfer type is the correct one. */ /*-----------------------------------------------------------------------*/ static void file_size_only(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % QUICK_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; ptr += log_date_length + 1; /* Away with the file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Get file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif if ((gt_lt_sign == EQUAL_SIGN) && (tmp_file_size == search_file_size)) { (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length); /* Write file size. */ print_file_size(p_file_size, (off_t)tmp_file_size); } else if ((gt_lt_sign == LESS_THEN_SIGN) && (tmp_file_size < search_file_size)) { (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length); /* Write file size. */ print_file_size(p_file_size, (off_t)tmp_file_size); } else if ((gt_lt_sign == GREATER_THEN_SIGN) && (tmp_file_size > search_file_size)) { (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length); /* Write file size. */ print_file_size(p_file_size, (off_t)tmp_file_size); } else { IGNORE_ENTRY(); } il[file_no].line_offset[item_counter] = (off_t)(ptr_start_line - p_start_log_file + offset); ptr = ptr_start_line + log_date_length + 1; time_when_transmitted = (time_t)str2timet(ptr_start_line, NULL, 16); if (first_date_found == -1) { first_date_found = time_when_transmitted; } p_ts = localtime(&time_when_transmitted); CONVERT_TIME(); j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } ptr++; j++; } /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* File size is already stored. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } /* Write transfer duration, job ID and archive directory. */ /* Also check if we have to check for directory name. */ COMMON_BLOCK(); file_size += tmp_file_size; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*-------------------------- file_name_and_size() -----------------------*/ /* -------------------- */ /* Description: Reads everyting from ptr to ptr_end and search for the */ /* file name search_file_name that is <, >, or = */ /* search_file_size. It also checks if the transfer type is */ /* the correct one. */ /*-----------------------------------------------------------------------*/ static void file_name_and_size(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % QUICK_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; ptr += log_date_length + 1; if (sfilter(search_file_name, ptr, SEPARATOR_CHAR) != 0) { IGNORE_ENTRY(); } il[file_no].line_offset[item_counter] = (off_t)(ptr_start_line - p_start_log_file + offset); /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Get file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif if ((gt_lt_sign == EQUAL_SIGN) && (tmp_file_size != search_file_size)) { IGNORE_ENTRY(); } else if ((gt_lt_sign == LESS_THEN_SIGN) && (tmp_file_size >= search_file_size)) { IGNORE_ENTRY(); } else if ((gt_lt_sign == GREATER_THEN_SIGN) && (tmp_file_size <= search_file_size)) { IGNORE_ENTRY(); } ptr = ptr_start_line + log_date_length + 1; INSERT_TIME(); j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } ptr++; j++; } while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Write file size. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } print_file_size(p_file_size, (off_t)tmp_file_size); /* Write transfer duration, job ID and archive directory. */ /* Also check if we have to check for directory name. */ COMMON_BLOCK(); file_size += tmp_file_size; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*--------------------------- recipient_only() --------------------------*/ /* ---------------- */ /* Description: Reads everyting from ptr to ptr_end and search for the */ /* recipient 'search_recipient. It also checks if the */ /* transfer type is the correct one. */ /*-----------------------------------------------------------------------*/ static void recipient_only(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int gotcha, count, ii, item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line, dir_id_str[15 + 1]; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % SLOW_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; INSERT_TIME(); j = 0; il[file_no].line_offset[item_counter] = (off_t)(ptr - p_start_log_file + offset); ptr += log_date_length + 1; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } id.file_name[j] = *(p_file_name + j); ptr++; j++; } id.file_name[j] = ' '; id.file_name[j + 1] = '\0'; /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Write file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif print_file_size(p_file_size, (off_t)tmp_file_size); ptr++; count = 0; while ((*ptr != SEPARATOR_CHAR) && (*ptr != '\n') && (count < 15)) { dir_id_str[count] = *ptr; count++; ptr++; } dir_id_str[count] = '\0'; id.dir_id = (unsigned int)strtoul(dir_id_str, NULL, 16); id.dir[0] = '\0'; get_info(GOT_JOB_ID_DIR_AND_RECIPIENT); gotcha = NO; if (id.count > 0) { for (ii = 0; ii < no_of_search_hosts; ii++) { for (j = 0; j < id.count; j++) { if (sfilter(search_recipient[ii], id.dbe[j].recipient, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].user, ' ') == 0) { gotcha = YES; break; } } } if ((gotcha == NO) && (id.dbe[j].dir_url_hostname[0] != '\0')) { if (sfilter(search_recipient[ii], id.dbe[j].dir_url_hostname, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].dir_url_user, ' ') == 0) { gotcha = YES; break; } } } } } if (gotcha == YES) { break; } } free(id.dbe); id.dbe = NULL; id.count = 0; } if (gotcha == NO) { IGNORE_ENTRY(); } il[file_no].offset[item_counter] = (int)(ptr - p_start_log_file); if ((no_of_search_dirs > 0) || (no_of_search_dirids > 0)) { int kk; gotcha = NO; for (kk = 0; kk < no_of_search_dirids; kk++) { if (search_dirid[kk] == id.dir_id) { gotcha = YES; break; } } if ((gotcha == NO) && (no_of_search_dirs > 0)) { count = strlen((char *)id.dir); id.dir[count] = SEPARATOR_CHAR; id.dir[count + 1] = '\0'; for (kk = 0; kk < no_of_search_dirs; kk++) { if (search_dir_filter[kk] == YES) { if (sfilter(search_dir[kk], (char *)id.dir, SEPARATOR_CHAR) == 0) { gotcha = YES; break; } } else { if (search_dir_length[kk] == count) { if (strncmp(search_dir[kk], (char *)id.dir, count) == 0) { gotcha = YES; break; } } } } } if (gotcha == NO) { IGNORE_ENTRY(); } } while ((*ptr != '\n') && (*ptr != '\0')) { ptr++; } line_counter++; item_counter++; file_size += tmp_file_size; str_list[i] = XmStringCreateLocalized(line); ptr++; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*----------------------- file_name_and_recipient() ---------------------*/ static void file_name_and_recipient(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int gotcha, count, ii, item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line, dir_id_str[15 + 1]; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % SLOW_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; ptr += log_date_length + 1; if (sfilter(search_file_name, ptr, SEPARATOR_CHAR) == 0) { il[file_no].line_offset[item_counter] = (off_t)(ptr_start_line - p_start_log_file + offset); INSERT_TIME(); j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } id.file_name[j] = *(p_file_name + j); ptr++; j++; } id.file_name[j] = ' '; id.file_name[j + 1] = '\0'; } else { IGNORE_ENTRY(); } /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Write file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif print_file_size(p_file_size, (off_t)tmp_file_size); ptr++; count = 0; while ((*ptr != SEPARATOR_CHAR) && (*ptr != '\n') && (count < 15)) { dir_id_str[count] = *ptr; count++; ptr++; } dir_id_str[count] = '\0'; id.dir_id = (unsigned int)strtoul(dir_id_str, NULL, 16); id.dir[0] = '\0'; get_info(GOT_JOB_ID_DIR_AND_RECIPIENT); gotcha = NO; if (id.count > 0) { for (ii = 0; ii < no_of_search_hosts; ii++) { for (j = 0; j < id.count; j++) { if (sfilter(search_recipient[ii], id.dbe[j].recipient, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].user, ' ') == 0) { gotcha = YES; break; } } } if ((gotcha == NO) && (id.dbe[j].dir_url_hostname[0] != '\0')) { if (sfilter(search_recipient[ii], id.dbe[j].dir_url_hostname, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].dir_url_user, ' ') == 0) { gotcha = YES; break; } } } } } if (gotcha == YES) { break; } } free(id.dbe); id.dbe = NULL; id.count = 0; } if (gotcha == NO) { IGNORE_ENTRY(); } il[file_no].offset[item_counter] = (int)(ptr - p_start_log_file); if ((no_of_search_dirs > 0) || (no_of_search_dirids > 0)) { int kk; gotcha = NO; for (kk = 0; kk < no_of_search_dirids; kk++) { if (search_dirid[kk] == id.dir_id) { gotcha = YES; break; } } if ((gotcha == NO) || (no_of_search_dirs > 0)) { count = strlen((char *)id.dir); id.dir[count] = SEPARATOR_CHAR; id.dir[count + 1] = '\0'; for (kk = 0; kk < no_of_search_dirs; kk++) { if (search_dir_filter[kk] == YES) { if (sfilter(search_dir[kk], (char *)id.dir, SEPARATOR_CHAR) == 0) { gotcha = YES; break; } } else { if (search_dir_length[kk] == count) { if (strncmp(search_dir[kk], (char *)id.dir, count) == 0) { gotcha = YES; break; } } } } } if (gotcha == NO) { IGNORE_ENTRY(); } } while ((*ptr != '\n') && (*ptr != '\0')) { ptr++; } line_counter++; item_counter++; file_size += tmp_file_size; str_list[i] = XmStringCreateLocalized(line); ptr++; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*----------------------- file_size_and_recipient() ---------------------*/ static void file_size_and_recipient(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int gotcha, count, ii, item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line, dir_id_str[15 + 1]; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % SLOW_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; ptr += log_date_length + 1; j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { id.file_name[j] = *ptr; ptr++; j++; } id.file_name[j] = ' '; id.file_name[j + 1] = '\0'; /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Get file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif if ((gt_lt_sign == EQUAL_SIGN) && (tmp_file_size == search_file_size)) { (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length); /* Write file size. */ print_file_size(p_file_size, (off_t)tmp_file_size); } else if ((gt_lt_sign == LESS_THEN_SIGN) && (tmp_file_size < search_file_size)) { (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length); /* Write file size. */ print_file_size(p_file_size, (off_t)tmp_file_size); } else if ((gt_lt_sign == GREATER_THEN_SIGN) && (tmp_file_size > search_file_size)) { (void)memset(line, ' ', MAX_OUTPUT_LINE_LENGTH + file_name_length); /* Write file size. */ print_file_size(p_file_size, (off_t)tmp_file_size); } else { IGNORE_ENTRY(); } il[file_no].line_offset[item_counter] = (off_t)(ptr_start_line - p_start_log_file + offset); ptr = ptr_start_line + log_date_length + 1; time_when_transmitted = (time_t)str2timet(ptr_start_line, NULL, 16); if (first_date_found == -1) { first_date_found = time_when_transmitted; } p_ts = localtime(&time_when_transmitted); CONVERT_TIME(); j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } ptr++; j++; } /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* File size is already stored. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; count = 0; while ((*ptr != SEPARATOR_CHAR) && (*ptr != '\n') && (count < 15)) { dir_id_str[count] = *ptr; count++; ptr++; } dir_id_str[count] = '\0'; id.dir_id = (unsigned int)strtoul(dir_id_str, NULL, 16); id.dir[0] = '\0'; get_info(GOT_JOB_ID_DIR_AND_RECIPIENT); gotcha = NO; if (id.count > 0) { for (ii = 0; ii < no_of_search_hosts; ii++) { for (j = 0; j < id.count; j++) { if (sfilter(search_recipient[ii], id.dbe[j].recipient, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].user, ' ') == 0) { gotcha = YES; break; } } } if ((gotcha == NO) && (id.dbe[j].dir_url_hostname[0] != '\0')) { if (sfilter(search_recipient[ii], id.dbe[j].dir_url_hostname, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].dir_url_user, ' ') == 0) { gotcha = YES; break; } } } } } if (gotcha == YES) { break; } } free(id.dbe); id.dbe = NULL; id.count = 0; } if (gotcha == NO) { IGNORE_ENTRY(); } il[file_no].offset[item_counter] = (int)(ptr - p_start_log_file); if ((no_of_search_dirs > 0) || (no_of_search_dirids > 0)) { int kk; gotcha = NO; for (kk = 0; kk < no_of_search_dirids; kk++) { if (search_dirid[kk] == id.dir_id) { gotcha = YES; break; } } if ((gotcha == NO) && (no_of_search_dirs > 0)) { count = strlen((char *)id.dir); id.dir[count] = SEPARATOR_CHAR; id.dir[count + 1] = '\0'; for (kk = 0; kk < no_of_search_dirs; kk++) { if (search_dir_filter[kk] == YES) { if (sfilter(search_dir[kk], (char *)id.dir, SEPARATOR_CHAR) == 0) { gotcha = YES; break; } } else { if (search_dir_length[kk] == count) { if (strncmp(search_dir[kk], (char *)id.dir, count) == 0) { gotcha = YES; break; } } } } } if (gotcha == NO) { IGNORE_ENTRY(); } } while ((*ptr != '\n') && (*ptr != '\0')) { ptr++; } line_counter++; item_counter++; file_size += tmp_file_size; str_list[i] = XmStringCreateLocalized(line); ptr++; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*---------------------- file_name_size_recipient() ---------------------*/ static void file_name_size_recipient(register char *ptr, char *ptr_end, int file_no, char *p_start_log_file, off_t offset) { register int i, j; int gotcha, count, ii, item_counter = il[file_no].no_of_items, prev_item_counter = il[file_no].no_of_items, line_counter = 0, #ifndef LESSTIF_WORKAROUND unmanaged, #endif loops = 0; time_t now, prev_time_val = 0L, time_when_transmitted = 0L; double tmp_file_size; char *ptr_start_line, dir_id_str[15 + 1]; struct tm *p_ts; #ifndef LESSTIF_WORKAROUND if (item_counter == 0) { XtUnmanageChild(listbox_w); unmanaged = YES; } else { unmanaged = NO; } #endif do { for (i = 0; ((i < LINES_BUFFERED) && (ptr < ptr_end)); i++) { /* Allocate memory for offset to job ID. */ REALLOC_OFFSET_BUFFER(); if ((line_counter != 0) && ((line_counter % SLOW_SEARCH) == 0)) { display_data(-1, 0L, 0L); CHECK_INTERRUPT(); if (special_button_flag != STOP_BUTTON) { loops--; break; } } if (*ptr == '#') { if ((*(ptr + 1) == '!') && (*(ptr + 2) == '#')) { get_log_type_data(ptr + 3); } IGNORE_ENTRY(); } ptr_start_line = ptr; ptr += log_date_length + 1; j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { id.file_name[j] = '?'; } else { id.file_name[j] = *ptr; } ptr++; j++; } id.file_name[j] = ' '; id.file_name[j + 1] = '\0'; if (sfilter(search_file_name, (char *)id.file_name, ' ') != 0) { IGNORE_ENTRY(); } il[file_no].line_offset[item_counter] = (off_t)(ptr_start_line - p_start_log_file + offset); /* If necessary, ignore rest of file name. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Get file size. */ j = 0; while (*ptr != SEPARATOR_CHAR) { ptr++; j++; } #ifdef HAVE_STRTOULL if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { tmp_file_size = (double)strtoull(ptr - j, NULL, 16); } #else if (j < 9) { tmp_file_size = (double)strtoul(ptr - j, NULL, 16); } else { # ifdef LINUX if (j > 15) { tmp_file_size = strtod("INF", NULL); } else { char tmp_buf[23]; tmp_buf[0] = '0'; tmp_buf[1] = 'x'; (void)memcpy(&tmp_buf[2], ptr - j, j); tmp_buf[2 + j] = '\0'; tmp_file_size = strtod(tmp_buf, NULL); } # else tmp_file_size = strtod("INF", NULL); # endif } #endif if ((gt_lt_sign == EQUAL_SIGN) && (tmp_file_size != search_file_size)) { IGNORE_ENTRY(); } else if ((gt_lt_sign == LESS_THEN_SIGN) && (tmp_file_size >= search_file_size)) { IGNORE_ENTRY(); } else if ((gt_lt_sign == GREATER_THEN_SIGN) && (tmp_file_size <= search_file_size)) { IGNORE_ENTRY(); } ptr = ptr_start_line + log_date_length + 1; INSERT_TIME(); j = 0; while ((*ptr != SEPARATOR_CHAR) && (j < file_name_length)) { if ((unsigned char)(*ptr) < ' ') { *(p_file_name + j) = '?'; unprintable_chars++; } else { *(p_file_name + j) = *ptr; } ptr++; j++; } while (*ptr != SEPARATOR_CHAR) { ptr++; } ptr++; /* Write file size. */ while (*ptr != SEPARATOR_CHAR) { ptr++; } print_file_size(p_file_size, (off_t)tmp_file_size); ptr++; count = 0; while ((*ptr != SEPARATOR_CHAR) && (*ptr != '\n') && (count < 15)) { dir_id_str[count] = *ptr; count++; ptr++; } dir_id_str[count] = '\0'; id.dir_id = (unsigned int)strtoul(dir_id_str, NULL, 16); id.dir[0] = '\0'; get_info(GOT_JOB_ID_DIR_AND_RECIPIENT); gotcha = NO; if (id.count > 0) { for (ii = 0; ii < no_of_search_hosts; ii++) { for (j = 0; j < id.count; j++) { if (sfilter(search_recipient[ii], id.dbe[j].recipient, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].user, ' ') == 0) { gotcha = YES; break; } } } if ((gotcha == NO) && (id.dbe[j].dir_url_hostname[0] != '\0')) { if (sfilter(search_recipient[ii], id.dbe[j].dir_url_hostname, ' ') == 0) { if (search_user[ii][0] == '\0') { gotcha = YES; break; } else { if (sfilter(search_user[ii], id.dbe[j].dir_url_user, ' ') == 0) { gotcha = YES; break; } } } } } if (gotcha == YES) { break; } } free(id.dbe); id.dbe = NULL; id.count = 0; } if (gotcha == NO) { IGNORE_ENTRY(); } il[file_no].offset[item_counter] = (int)(ptr - p_start_log_file); if ((no_of_search_dirs > 0) || (no_of_search_dirids > 0)) { int kk; gotcha = NO; for (kk = 0; kk < no_of_search_dirids; kk++) { if (search_dirid[kk] == id.dir_id) { gotcha = YES; break; } } if ((gotcha == NO) && (no_of_search_dirs > 0)) { count = strlen((char *)id.dir); id.dir[count] = SEPARATOR_CHAR; id.dir[count + 1] = '\0'; for (kk = 0; kk < no_of_search_dirs; kk++) { if (search_dir_filter[kk] == YES) { if (sfilter(search_dir[kk], (char *)id.dir, SEPARATOR_CHAR) == 0) { gotcha = YES; break; } } else { if (search_dir_length[kk] == count) { if (strncmp(search_dir[kk], (char *)id.dir, count) == 0) { gotcha = YES; break; } } } } } if (gotcha == NO) { IGNORE_ENTRY(); } } while ((*ptr != '\n') && (*ptr != '\0')) { ptr++; } line_counter++; item_counter++; file_size += tmp_file_size; str_list[i] = XmStringCreateLocalized(line); ptr++; } loops++; /* Display what we have in buffer. */ display_data(i, first_date_found, time_when_transmitted); /* Check if user has done anything. */ if ((time(&now) - prev_time_val) > CHECK_TIME_INTERVAL) { prev_time_val = now; CHECK_INTERRUPT(); } CHECK_LIST_LIMIT(); } while ((ptr < ptr_end) && (special_button_flag == STOP_BUTTON)); #ifndef LESSTIF_WORKAROUND if (unmanaged == YES) { XtManageChild(listbox_w); } #endif il[file_no].no_of_items = item_counter; return; } /*--------------------------- display_data() ----------------------------*/ static void display_data(int i, time_t first_date_found, time_t time_when_transmitted) { static int rotate; char status_message[MAX_MESSAGE_LENGTH]; XmString xstr; if (i != -1) { register int j; XExposeEvent xeev; Dimension w, h; XmListAddItemsUnselected(listbox_w, str_list, i, 0); for (j = 0; j < i; j++) { XmStringFree(str_list[j]); } total_no_files += i; calculate_summary(summary_str, first_date_found, time_when_transmitted, total_no_files, file_size); (void)strcpy(total_summary_str, summary_str); xeev.type = Expose; xeev.display = display; xeev.window = main_window; xeev.x = 0; xeev.y = 0; XtVaGetValues(summarybox_w, XmNwidth, &w, XmNheight, &h, NULL); xeev.width = w; xeev.height = h; xstr = XmStringCreateLtoR(summary_str, XmFONTLIST_DEFAULT_TAG); XtVaSetValues(summarybox_w, XmNlabelString, xstr, NULL); (XtClass(summarybox_w))->core_class.expose(summarybox_w, (XEvent *)&xeev, NULL); XmStringFree(xstr); } rotate++; if (rotate == 0) { (void)strcpy(status_message, "Searching -"); } else if (rotate == 1) { (void)strcpy(status_message, "Searching \\"); } else if (rotate == 2) { (void)strcpy(status_message, "Searching |"); } else { (void)strcpy(status_message, "Searching /"); rotate = -1; } xstr = XmStringCreateLtoR(status_message, XmFONTLIST_DEFAULT_TAG); XtVaSetValues(statusbox_w, XmNlabelString, xstr, NULL); XmStringFree(xstr); all_list_items = total_no_files; return; }