Method and apparatus for representing recurring events

- Sun Microsystems, Inc.

A method and apparatus for representing and storing the schedules of recurring events is provided. The schedules are represented by recurrence rules generated according to a specific grammar. According to the grammar, each recurrence rule is composed of one or more recurrence commands. Each recurrence command corresponds to a cycle and includes a time interval indicator that specifies the duration of the cycle and a repeat quantity that determines the number of times the cycle is repeated in the schedule. Each recurrence command may also include an occurrence list that specifies at what times during a particular cycle the event occurs. The occurrence list may specify times in absolute or relative terms. Thus, the grammar supports recurrence rules for representing the schedule "first and tenth of every month" as well as the schedule "second Thursday and last Friday of every month". To represent schedules that terminate before the last event in the last cycle is completed, a symbol may be inserted into the occurrence list to distinguish the events that are performed on the last cycle from the events that are not performed on the last cycle. Complex schedules that involve cycles repeated within cycles are represented by multiple-command recurrence rules. The stored recurrence rules may be parsed to determine when events will occur. The grammar may be applied to a variety of applications, including calendar programs, video cassette recorders and home automation devices.

Skip to:  ·  Claims  ·  References Cited  · Patent History  ·  Patent History

Claims

1. A method for representing a schedule of a recurring event in an electronic device, wherein the schedule includes one or more cycles, wherein each of said one or more cycles has a length, the method comprising causing the electronic device to perform the steps of:

a) for each cycle in said schedule, performing the steps of
a1) receiving a first input that specifies a unit of time used to measure the length of said cycle;
a2) receiving a second input that specifies a number of time units;
a3) generating a time-interval indicator representing the length of said cycle;
wherein said step of generating said time-interval indicator includes the steps of
generating a unit-type indicator corresponding to said unit of time;
generating a unit-frequency indicator corresponding to said number of time units;
a4) generating a repeat-quantity indicator representing how many times said cycle is repeated in said schedule;
a5) generating a recurrence command to represent said cycle, said recurrence command including said time-interval indicator and said repeat-quantity indicator; and
b) constructing a recurrence rule to represent said schedule, wherein said recurrence rule includes the recurrence command generated for each cycle of said one or more cycles.

2. The method of claim 1 further comprising the steps of:

invoking an operation at an initial occurrence time;
parsing said recurrence rule to determine subsequent occurrence times; and
invoking said operation at said subsequent occurrence times.

3. The method of claim 1 wherein:

said electronic device is a computer system;
said computer system includes a display device and a storage device;
the method includes the steps of
storing data representing said recurrence rule on said storage device; and
generating on said display device user interface controls for receiving said first input and said second input from a user.

4. The method of claim 3 wherein:

the method further comprises the steps of
executing a client application in said computer system;
executing a server application in said computer system;
said client application performs said step of generating on said display device user interface controls;
said client application performs said step of receiving said first input;
said client application performs said step of receiving said second input;
said client application performs said step of constructing said recurrence rule to represent said schedule;
said client application transmits said recurrence rule to said server application; and
said server application performs said step of storing data representing said recurrence rule on said storage device.

5. The method of claim 1 wherein a given cycle of said one or more cycles includes a plurality of occurrences of said recurring event, wherein said plurality of occurrences do not occur according to a uniform interval, the method further comprising the step of:

receiving a third input indicating when said plurality of occurrences occur during said given cycle; and
wherein said step of generating said recurrence command to represent said given cycle includes generating an occurrence list representing when said plurality of occurrences occur.

6. The method of claim 5 wherein said occurrence list represents when at least one of said plurality of occurrences occurs with an absolute occurrence specifier.

7. The method of claim 6 wherein said occurrence list includes data representing a weekday and data representing a relative occurrence of said weekday within a month.

8. The method of claim 5 wherein said occurrence list represents when at least one of said plurality of occurrences occurs with a relative occurrence specifier.

9. The method of claim 1 wherein said step of constructing said recurrence rule includes placing said recurrence command in an order based on the length of the cycle represented by said recurrence command for each cycle of said one or more cycles.

10. The method of claim 1 wherein the cycle is repeated N times during said schedule, wherein N represents a non-negative integer, wherein said recurring event takes place on a relative occurrence of a certain weekday in a month, the method further comprising the steps of:

generating a repeat-quantity indicator representing the value of N; and
generating a relative occurrence specifier that indicates said relative occurrence of said certain weekday in said month.

11. A method for representing in an electronic device a schedule of a recurring event, wherein the schedule includes a cycle of a certain duration, wherein the cycle is repeated N times during the schedule, wherein N is at least two, wherein during the first N-1 iterations of the cycle said recurring event occurs at a first set of times and a second set of times, wherein during the Nth iteration of said cycle said recurring event occurs at said first set of times but not at said second set of times, the method comprising the steps of:

generating a time-interval indicator representing said certain duration;
generating a repeat-quantity indicator representing the value of N;
generating an occurrence list including data representing said first set of times and said second set of times;
inserting at least one symbol into said occurrence list to distinguish between said first set of times and said second set of times.

12. The method of claim 11 wherein said step of generating said occurrence list includes generating an occurrence list in which data indicating said first set of times precedes data indicating said second set of times, wherein said step of inserting one or more symbols includes inserting one or more symbols between the data indicating said first set of times and the data representing said second set of times.

13. An apparatus for storing a representation of a schedule of a recurring event, the apparatus comprising:

an input device for receiving input representing said schedule;
a processor coupled to said input device, said processor receiving said input from said input device and generating a recurrence rule based on a grammar, wherein said recurrence rule represents said schedule of said recurring event; and
a storage device coupled to said processor, said processor storing data representing said recurrence rule on said storage device;
wherein said recurrence rule includes one or more recurrence commands, wherein each recurrence command of said recurrence rule represents a repeating cycle in said schedule;
wherein said grammar includes rules for constructing time-interval indicators for representing cycles that repeat every N.sub.1 minutes, every N.sub.2 days, every N.sub.3 weeks, every N.sub.4 months on a relative day and week, every N.sub.5 months on an absolute day, every N.sub.6 years on one or more specific months, and every N.sub.7 years on one or more specific days of the year, where N.sub.1 -N.sub.7 are each any natural number.

14. The apparatus of claim 13 wherein said grammar includes rules for constructing repeat-quantity indicators for representing how many times a cycle repeats in said schedule.

15. The apparatus of claim 14 wherein said repeat-quantity indicators comprise a repeat-quantity symbol and a number.

16. The apparatus of claim 13 wherein said grammar includes rules for constructing occurrence lists, wherein said occurrence lists indicate times that said recurring event occurs during said repeating cycle.

17. The apparatus of claim 16 wherein said grammar includes rules for constructing occurrence lists that represent specific hours in a day, specific weekdays in a week, specific days in a month, specific months in a year and specific days in a year.

18. The apparatus of claim 16 wherein said grammar includes rules for constructing occurrence lists that represent relative occurrences of weekdays in a month.

19. The apparatus of claim 13 wherein said grammar includes rules for specifying any number of occurrences of said recurring event within a repeating cycle in said schedule.

20. The apparatus of claim 13 wherein said grammar includes a first rule for specifying an absolute end time and a second rule for determining an end time by specifying a number of repetitions of each repeating cycle in said schedule.

21. A method for representing a schedule of a recurring event in an electronic device, wherein the schedule includes a plurality of cycles, wherein each of said plurality of cycles has a length, the method comprising causing the electronic device to perform the steps of:

a) for each cycle in said schedule, performing the steps of
a1) generating a time-interval indicator representing the length of said cycle;
a2) generating a recurrence command to represent said cycle, said recurrence command including said time-interval indicator; and
b) constructing a recurrence rule to represent said schedule, wherein said recurrence rule includes the recurrence command generated for each cycle of said plurality of cycles.

22. The method of claim 21 wherein:

said schedule includes a first cycle and a second cycle;
said schedule includes repeating one of said first cycle and said second cycle within the other of said first cycle and said second cycle;
said first cycle has a duration that does not vary;
said second cycle has a duration that varies based on a selected relative occurrence;
said step of a1) generating a time-interval indicator includes the steps of
generating a first time-interval representing the length of said first cycle; and
generating a second time-interval indicator representing the length of said second cycle;
wherein said step of a2) generating a recurrence command includes
generating a first recurrence command to represent said first cycle; and
generating a second recurrence command to represent said second cycle;
wherein said step of b) constructing a recurrence rule includes constructing a recurrence rule that includes said first recurrence command and said second recurrence command.

23. The method of claim 22 wherein said selected relative occurrence is a relative occurrence of a weekday in a month.

Referenced Cited
U.S. Patent Documents
5260868 November 9, 1993 Gupta et al.
5416473 May 16, 1995 Dulaney, III et al.
5491626 February 13, 1996 Williams et al.
Other references
  • Fresko-Weiss; "Microsoft Adds Scheduling to its E-mail System"; PC Magazine; v11 n19; p56(1); Nov. 10, 1992; Dialog: File 148, Acc# 06140060. "Introduction to Schedule+"; The Professional Development Group, Inc.; pp. 14-41; Copyright May, 1993. Taylor; "Now Up-to-Date, Now Contact Need to Improve Integration"; InfoWorld; v15 n52-1; p81(1); Dec. 27, 1993; Dialog: File 148, Acc# 06783739. Printout from Schedule+ Help File from Microsoft Windows for Workgroups Version 3.11; Copyright 1985-1993; Microsoft Corporation. Gilliland; "Keeping Track of Your Time"; Computer Shopper; v14 n1; p486(2); Jan., 1994; Dialog: File 275, Acc# 01664633. Warner; "Controlling Appointments"; CPA Journal; v64 n11; p40(4); Nov., 1994; Dialog. File 148, Acc# 07584594.
Patent History
Patent number: 5749074
Type: Grant
Filed: Feb 27, 1995
Date of Patent: May 5, 1998
Assignees: Sun Microsystems, Inc. (Mountainview, CA), International Business Machines Corporation (Armonk, NY)
Inventors: Chris S. Kasso (Sunnyvale, CA), Martin Arthur Knutson (Cupertino, CA), Yvonne Yuen-Yee Tso (Milpitas, CA), Frank R. Dawson (Keller, TX)
Primary Examiner: Robert A. Weinhardt
Assistant Examiner: Stephen R. Tkacs
Law Firm: Blakely Sokoloff Taylor & Zafman
Application Number: 8/395,458
Classifications
Current U.S. Class: 705/8; 705/9; 364/70507; 364/70508
International Classification: G06F 1760; G06G 752;