summaryrefslogtreecommitdiff
path: root/sql/event_queue.h
diff options
context:
space:
mode:
authorunknown <andrey@lmy004.>2006-07-03 11:20:08 +0200
committerunknown <andrey@lmy004.>2006-07-03 11:20:08 +0200
commit377446fa3497ffbc0f2a17614d848bfb79f52662 (patch)
tree99e7b4fe6e41946b7b36c74b0c7e898e13945244 /sql/event_queue.h
parent8d961c45e2e83f04da92cbfc31d2975a6949743f (diff)
downloadmariadb-git-377446fa3497ffbc0f2a17614d848bfb79f52662.tar.gz
WL#3337 (Event scheduler new architecture)
This is the first cut of separating Event_scheduler in two classes which are more specialized. Inheritance was used to separate methods and member variables. Still Event_scheduler is a child of Event_queue. This dependency will be removed soon. sql/event_data_objects.cc: add comments sql/event_db_repository.cc: coding style sql/event_db_repository.h: add a call, will be implemented later sql/event_queue.cc: Event_queue, still as super-class of Event_scheduler sql/event_queue.h: Event_queue as super-class of Event_scheduler. Trying to separate the two classes sql/event_scheduler.cc: Event_scheduler as child class of Event_queue. Trying to separate both classes. sql/event_scheduler.h: Event_scheduler as child class of Event_queue. Trying to separate both classes. sql/events.cc: Don't allocate on the stack the scheduler but on the heap. The exact way it is done will be changed, that's ok for now.
Diffstat (limited to 'sql/event_queue.h')
-rw-r--r--sql/event_queue.h104
1 files changed, 103 insertions, 1 deletions
diff --git a/sql/event_queue.h b/sql/event_queue.h
index b3aa6133840..8c11d7a2042 100644
--- a/sql/event_queue.h
+++ b/sql/event_queue.h
@@ -16,5 +16,107 @@
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
-
+class sp_name;
+class Event_timed;
+class Event_db_repository;
+
+class THD;
+typedef bool * (*event_timed_identifier_comparator)(Event_timed*, Event_timed*);
+
+class Event_scheduler;
+
+class Event_queue
+{
+public:
+ Event_queue();
+
+ static void
+ init_mutexes();
+
+ static void
+ destroy_mutexes();
+
+ bool
+ init(Event_db_repository *db_repo);
+
+ void
+ deinit();
+
+ /* Methods for queue management follow */
+
+ int
+ create_event(THD *thd, Event_parse_data *et, bool check_existence);
+
+ int
+ update_event(THD *thd, Event_parse_data *et, LEX_STRING *new_schema,
+ LEX_STRING *new_name);
+
+ bool
+ drop_event(THD *thd, sp_name *name);
+
+ int
+ drop_schema_events(THD *thd, LEX_STRING schema);
+
+ int
+ drop_user_events(THD *thd, LEX_STRING *definer)
+ { DBUG_ASSERT(0); return 0;}
+
+ uint
+ events_count();
+
+ uint
+ events_count_no_lock();
+
+ static bool
+ check_system_tables(THD *thd);
+
+ void
+ recalculate_queue(THD *thd);
+
+ void
+ empty_queue();
+
+///////////////protected
+ Event_timed *
+ find_event(LEX_STRING db, LEX_STRING name, bool remove_from_q);
+
+ int
+ load_events_from_db(THD *thd);
+
+ void
+ drop_matching_events(THD *thd, LEX_STRING pattern,
+ bool (*)(Event_timed *,LEX_STRING *));
+
+ /* LOCK_event_queue is the mutex which protects the access to the queue. */
+ pthread_mutex_t LOCK_event_queue;
+
+ Event_db_repository *db_repository;
+
+ /* The MEM_ROOT of the object */
+ MEM_ROOT scheduler_root;
+
+ /* The sorted queue with the Event_timed objects */
+ QUEUE queue;
+
+ uint mutex_last_locked_at_line;
+ uint mutex_last_unlocked_at_line;
+ const char* mutex_last_locked_in_func;
+ const char* mutex_last_unlocked_in_func;
+ bool mutex_queue_data_locked;
+
+ /* helper functions for working with mutexes & conditionals */
+ void
+ lock_data(const char *func, uint line);
+
+ void
+ unlock_data(const char *func, uint line);
+
+ static void
+ on_queue_change();
+protected:
+ /* Singleton instance */
+ static Event_scheduler *singleton;
+
+};
+
#endif /* _EVENT_QUEUE_H_ */