Имя пользователя:
Пароль:  
Помощь | Регистрация | Забыли пароль?  

Показать сообщение отдельно

редкий гость


Сообщения: 1696
Благодарности: 44

Профиль | Сайт | Отправить PM | Цитировать


Vlad Drakula
Всё зависит от того, какая конуретно нужна функциональность. Вот псевдокод на Питоне:

Код: Выделить весь код
def get_tasks_for_date(date):
    res = []
    for task in tasks:
        if task.happens_at_date(date):
            res.extend(task.get_times_for_date(date))
            #т.е. просто дописать в конец списка ещё один
    return res

class Task:
    def happens_at_date(date):
        # Здесь идёт проверка.
        # Вычисляется некое выражение.
        # Если ежедневное событие - True всегда
        # Если еженедельное (напр, по понедельникам), то проверяется
        # понедельник ли дата. итд
        # Выражения могут быть весьма сложными (напр, проверять таски в другие дни итп)
        # Хранить их (выражения) можно либо как синтаксическое дерево, либо в виде
        # кода, который потом надо будет проинтерпретировать (благо во всех динамических
        # языках есть eval или его аналоги).

     def get_times_for_date(date):
         # Аналогичным образом определяем список времён, в которые выполняется задание
Это был приведён очень гибкий вариант, который можно по разному кастомизировать, и который в большинстве случаев не нужен

В более простом случае (подозреваю, что таски хранятся в базе), можно завести, например, такие таблички:
Код: Выделить весь код
task:
  id
  title
  -- ещё чё-нить

happens_at:
  id -> FK(task)
  year
  month
  day_of_month
  week
  day_of_week
  time
и сделать примерно такой селект:
Код: Выделить весь код
SELECT DISTINCT id, title, time
FROM task, happens_at
WHERE task.id = happens_at.id
  AND year IN (0, $year)
  AND month IN (0, month)
  AND day_of_month IN (0, $day_of_month)
  AND week IN (0, $week)
  AND day_of_week IN(0, $day_of_week)
Выбираться это будет не быстро, если заданий достаточно много, но можно же закэшировать где-нибудь

Если событие наступает три раза в день, то у нас будет три соответствующих записи, у которых все поля кроме time будут = 0, а time будет указывать время (внутри дня).

Если событие наступает каждый день месяца, то всё = 0 кроме day = 1. Если каждую неделю, то всё = 0, кроме day_of_week = нужному дню. Если два раза в неделю, то просто две разных записи.

Сложнее с отсчётом от конца периода, но этого тоже можно добиться некоторыми извратами (проще всего добавить ещё полей).

Примерно так. Эту структуру тоже можно усложнить. Но нафига? 95% случаев она покроет, я полагаю.

-------
http://ivank.ru


Отправлено: 20:33, 24-05-2006 | #10