Mercurial > emacs
view src/vmstime.c @ 35362:f6b85f5a5397
(isearch-highlight): Set isearch-overlay priority to
1 here rather than each time through
isearch-lazy-highlight-new-loop.
(isearch-lazy-highlight-max): Variable deleted.
(isearch-lazy-highlight-max-at-a-time): New user variable, like
isearch-lazy-highlight-max but controls a single invocation of
isearch-lazy-highlight-update.
(isearch-lazy-highlight-wrapped): Variable recreated.
(isearch-lazy-highlight-window-start): New variable.
(isearch-lazy-highlight-cleanup): Restored to behavior of
before 2-Jan.
(isearch-lazy-highlight-remove-overlays): Function deleted;
behavior folded into isearch-lazy-highlight-cleanup. "Keep"
behavior removed.
(isearch-lazy-highlight-new-loop): Restore old behavior of calling
isearch-lazy-highlight-update in a loop rather than just once.
Test isearch-invalid-regexp here and decide not to start a new
loop, rather than testing it each time through
isearch-lazy-highlight-update.
(isearch-lazy-highlight-search): Function restored.
(isearch-lazy-highlight-update): Get called in a timer loop again,
but this time highlight more than one match each time through.
Only highlight matches in the visible part of the window. Start
at point, move in the direction of the search, and wrap around at
the edge of the window. Use sit-for to force redisplay and ensure
window-start is credible. "Face suppressing" behavior removed;
overlay priorities should make it unnecessary, right?
(isearch-highlight): Face suppressing behavior removed.
(isearch-dehighlight): Face suppressing behavior removed.
(isearch-set-lazy-highlight-faces-at): Removed.
author | Gerd Moellmann <gerd@gnu.org> |
---|---|
date | Wed, 17 Jan 2001 14:10:25 +0000 |
parents | 2bf083a9ad6a |
children |
line wrap: on
line source
/* Time support for VMS. Copyright (C) 1993 Free Software Foundation. This file is part of GNU Emacs. GNU Emacs 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, or (at your option) any later version. GNU Emacs 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 GNU Emacs; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include <config.h> #include "vmstime.h" long timezone=0; int daylight=0; static char tzname_default[20]=""; static char tzname_dst[20]=""; char *tzname[2] = { tzname_default, tzname_dst }; static long internal_daylight=0; static char daylight_set=0; static long read_time(const char *nptr, const char **endptr, int sign_allowed_p) { int t; *endptr = nptr; /* This routine trusts the user very much, and does no checks! The only exception is this: */ if (!sign_allowed_p && (*nptr == '-' || *nptr == '+')) return 0; t = strtol(*endptr, endptr, 10) * 3600; if (**endptr != ':' || **endptr == '+' || **endptr == '-') return t; (*endptr)++; t = t + strtol(*endptr, endptr, 10) * 60; if (**endptr != ':' || **endptr == '+' || **endptr == '-') return t; (*endptr)++; return t + strtol(*endptr, endptr, 10); } static void read_dst_time(const char *nptr, const char **endptr, int *m, int *n, int *d, int *leap_p) { time_t bintim = time(0); struct tm *lc = localtime(&bintim); *leap_p = 1; *m = 0; /* When m and n are 0, a Julian */ *n = 0; /* date has been inserted in d */ switch(*nptr) { case 'M': { /* This routine counts on the user to have specified "Mm.n.d", where 1 <= n <= 5, 1 <= m <= 12, 0 <= d <= 6 */ *m = strtol(++nptr, endptr, 10); (*endptr)++; /* Skip the dot */ *n = strtol(*endptr, endptr, 10); (*endptr)++; /* Skip the dot */ *d = strtol(*endptr, endptr, 10); return; } case 'J': *leap_p = 0; /* Never count with leap years */ default: /* trust the user to have inserted a number! */ *d = strtol(++nptr, endptr, 10); return; } } struct vms_vectim { short year, month, day, hour, minute, second, centi_second; }; static void find_dst_time(int m, int n, long d, int hour, int minute, int second, int leap_p, long vms_internal_time[2]) { long status = SYS$GETTIM(vms_internal_time); struct vms_vectim vms_vectime; status = SYS$NUMTIM(&vms_vectime, vms_internal_time); if (m == 0 && n == 0) { long tmp_vms_internal_time[2][2]; long day_of_year; long tmp_operation = LIB$K_DAY_OF_YEAR; status = LIB$CVT_FROM_INTERNAL_TIME(&tmp_operation, &day_of_year, vms_internal_time); vms_vectime.month = 2; vms_vectime.day = 29; status = LIB$CVT_VECTIM(&vms_vectime, tmp_vms_internal_time[0]); if (status & 1) /* This is a leap year */ { if (!leap_p && d > 59) d ++; /* If we don't count with 29th Feb, and this is a leap year, count up, to make day 60 really become the 1st March. */ } /* 1st January, at midnight */ vms_vectime.month = 1; vms_vectime.day = 1; vms_vectime.hour = hour; vms_vectime.minute = minute; vms_vectime.second = second; vms_vectime.centi_second = 0; status = LIB$CVT_VECTIM(&vms_vectime, tmp_vms_internal_time[0]); tmp_operation = LIB$K_DELTA_DAYS; status = LIB$CVT_TO_INTERNAL_TIME(&tmp_operation, &d, tmp_vms_internal_time[1]); /* now, tmp_vms_interval_time[0] contains 1st Jan, 00:00:00, and tmp_vms_interval_time[1] contains delta time +d days. Let's just add them together */ status = LIB$ADD_TIMES(tmp_vms_internal_time[0], tmp_vms_internal_time[1], vms_internal_time); } else { long tmp_vms_internal_time[2]; long day_of_week; long tmp_operation = LIB$K_DAY_OF_YEAR; if (d == 0) /* 0 is Sunday, which isn't compatible with VMS, where day_of_week is 1 -- 7, and 1 is Monday */ { d = 7; /* So a simple conversion is required */ } vms_vectime.month = m; vms_vectime.day = 1; vms_vectime.hour = hour; vms_vectime.minute = minute; vms_vectime.second = second; vms_vectime.centi_second = 0; status = LIB$CVT_VECTIM(&vms_vectime, tmp_vms_internal_time); tmp_operation = LIB$K_DAY_OF_WEEK; status = LIB$CVT_FROM_INTERNAL_TIME(&tmp_operation, &day_of_week, tmp_vms_internal_time); d -= day_of_week; if (d < 0) { d += 7; } vms_vectime.day += (n-1)*7 + d; status = LIB$CVT_VECTIM(&vms_vectime, vms_internal_time); if (!(status & 1)) { vms_vectime.day -= 7; /* n was probably 5 */ status = LIB$CVT_VECTIM(&vms_vectime, vms_internal_time); } } } static cmp_vms_internal_times(long vms_internal_time1[2], long vms_internal_time2[2]) { if (vms_internal_time1[1] < vms_internal_time2[1]) return -1; else if (vms_internal_time1[1] > vms_internal_time2[1]) return 1; if (vms_internal_time1[0] < vms_internal_time2[0]) return -1; else if (vms_internal_time1[0] > vms_internal_time2[0]) return 1; return 0; } /* -------------------------- Global routines ------------------------------ */ #ifdef tzset #undef tzset #endif void sys_tzset() { char *TZ; char *p, *q; if (daylight_set) return; daylight = 0; if ((TZ = getenv("TZ")) == 0) return; p = TZ; q = tzname[0]; while(*p != '\0' && (*p <'0' || *p > '9') && *p != '-' && *p != '+' && *p != ',') *q++ = *p++; *q = '\0'; /* This is special for VMS, so I don't care if it doesn't exist anywhere else */ timezone = read_time(p, &p, 1); q = tzname[1]; while(*p != '\0' && (*p <'0' || *p > '9') && *p != '-' && *p != '+' && *p != ',') *q++ = *p++; *q = '\0'; if (*p != '-' && *p != '+' && !(*p >='0' && *p <= '9')) internal_daylight = timezone - 3600; else internal_daylight = read_time(p, &p, 1); if (*p == ',') { int start_m; int start_n; int start_d; int start_leap_p; int start_hour=2, start_minute=0, start_second=0; p++; read_dst_time(p, &p, &start_m, &start_n, &start_d, &start_leap_p); if (*p == '/') { long tmp = read_time (++p, &p, 0); start_hour = tmp / 3600; start_minute = (tmp % 3600) / 60; start_second = tmp % 60; } if (*p == ',') { int end_m; int end_n; int end_d; int end_leap_p; int end_hour=2, end_minute=0, end_second=0; p++; read_dst_time(p, &p, &end_m, &end_n, &end_d, &end_leap_p); if (*p == '/') { long tmp = read_time (++p, &p, 0); end_hour = tmp / 3600; end_minute = (tmp % 3600) / 60; end_second = tmp % 60; } { long vms_internal_time[3][2]; find_dst_time(start_m, start_n, start_d, start_hour, start_minute, start_second, start_leap_p, vms_internal_time[0]); SYS$GETTIM(&vms_internal_time[1]); find_dst_time(end_m, end_n, end_d, end_hour, end_minute, end_second, end_leap_p, vms_internal_time[2]); if (cmp_vms_internal_times(vms_internal_time[0], vms_internal_time[1]) < 0 && cmp_vms_internal_times(vms_internal_time[1], vms_internal_time[2]) < 0) daylight = 1; } } } } #ifdef localtime #undef localtime #endif struct tm *sys_localtime(time_t *clock) { struct tm *tmp = localtime(clock); sys_tzset(); tmp->tm_isdst = daylight; return tmp; } #ifdef gmtime #undef gmtime #endif struct tm *sys_gmtime(time_t *clock) { static struct tm gmt; struct vms_vectim tmp_vectime; long vms_internal_time[3][2]; long tmp_operation = LIB$K_DELTA_SECONDS; long status; long tmp_offset; char tmp_o_sign; sys_tzset(); if (daylight) tmp_offset = internal_daylight; else tmp_offset = timezone; if (tmp_offset < 0) { tmp_o_sign = -1; tmp_offset = -tmp_offset; } else tmp_o_sign = 1; status = LIB$CVT_TO_INTERNAL_TIME(&tmp_operation, &tmp_offset, vms_internal_time[1]); status = SYS$GETTIM(vms_internal_time[0]); if (tmp_o_sign < 0) { status = LIB$SUB_TIMES(vms_internal_time[0], vms_internal_time[1], vms_internal_time[2]); } else { status = LIB$ADD_TIMES(vms_internal_time[0], vms_internal_time[1], vms_internal_time[2]); } status = SYS$NUMTIM(&tmp_vectime, vms_internal_time[2]); gmt.tm_sec = tmp_vectime.second; gmt.tm_min = tmp_vectime.minute; gmt.tm_hour = tmp_vectime.hour; gmt.tm_mday = tmp_vectime.day; gmt.tm_mon = tmp_vectime.month - 1; gmt.tm_year = tmp_vectime.year - 1900; tmp_operation = LIB$K_DAY_OF_WEEK; status = LIB$CVT_FROM_INTERNAL_TIME(&tmp_operation, &gmt.tm_wday, vms_internal_time[2]); if (gmt.tm_wday == 7) gmt.tm_wday = 0; tmp_operation = LIB$K_DAY_OF_YEAR; status = LIB$CVT_FROM_INTERNAL_TIME(&tmp_operation, &gmt.tm_yday, vms_internal_time[2]); gmt.tm_yday--; gmt.tm_isdst = daylight; return &gmt; }