OpenDNSSEC-signer  1.4.10
schedule.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009 NLNet Labs. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
17  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
19  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
21  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
22  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
23  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  */
26 
32 #ifndef SCHEDULER_SCHEDULE_H
33 #define SCHEDULER_SCHEDULE_H
34 
35 #include "config.h"
36 #include "scheduler/task.h"
37 #include "shared/allocator.h"
38 #include "shared/locks.h"
39 #include "shared/status.h"
40 
41 #include <stdio.h>
42 #include <time.h>
43 
44 #ifdef HAVE_SYS_TYPES_H
45 # include <sys/types.h>
46 #endif
47 #ifdef HAVE_UNISTD_H
48 # include <unistd.h>
49 #endif
50 
51 #include <ldns/ldns.h>
52 
53 
60  ldns_rbtree_t* tasks;
62  int loading; /* to determine backoff */
64 };
65 
73 
80 void schedule_flush(schedule_type* schedule, task_id override);
81 
90 
99 ods_status schedule_task(schedule_type* schedule, task_type* task, int log);
100 
109 
120  task_id what, time_t when);
121 
129 
137 
144 void schedule_print(FILE* out, schedule_type* schedule);
145 
151 void schedule_cleanup(schedule_type* schedule);
152 
153 #endif /* SCHEDULER_SCHEDULE_H */
task_type * schedule_lookup_task(schedule_type *schedule, task_type *task)
Definition: schedule.c:125
task_type * unschedule_task(schedule_type *schedule, task_type *task)
Definition: schedule.c:191
void schedule_print(FILE *out, schedule_type *schedule)
Definition: schedule.c:313
enum ods_enum_status ods_status
Definition: status.h:90
task_type * schedule_pop_task(schedule_type *schedule)
Definition: schedule.c:285
enum task_id_enum task_id
Definition: task.h:48
ods_status schedule_task(schedule_type *schedule, task_type *task, int log)
Definition: schedule.c:146
ods_status reschedule_task(schedule_type *schedule, task_type *task, task_id what, time_t when)
Definition: schedule.c:223
schedule_type * schedule_create(allocator_type *allocator)
Definition: schedule.c:48
int lock_basic_type
Definition: locks.h:91
void schedule_cleanup(schedule_type *schedule)
Definition: schedule.c:357
allocator_type * allocator
Definition: schedule.h:59
void schedule_flush(schedule_type *schedule, task_id override)
Definition: schedule.c:81
ldns_rbtree_t * tasks
Definition: schedule.h:60
lock_basic_type schedule_lock
Definition: schedule.h:63
task_type * schedule_get_first_task(schedule_type *schedule)
Definition: schedule.c:245