1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
-*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
3
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Definitions required for Configuration Variables plugin
6
* Copyright (C) 2008 Sun Microsystems, Inc.
5
* Definitions required for Configuration Variables plugin
7
* Copyright (C) 2008 Mark Atwood
8
9
* This program is free software; you can redistribute it and/or modify
9
10
* it under the terms of the GNU General Public License as published by
19
20
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22
#ifndef DRIZZLED_PLUGIN_SCHEDULER_H
23
#define DRIZZLED_PLUGIN_SCHEDULER_H
25
#include "drizzled/session.h"
26
#include "drizzled/plugin/plugin.h"
31
#include "drizzled/visibility.h"
42
* This class should be used by scheduler plugins to implement custom session
45
class DRIZZLED_API Scheduler : public Plugin
47
/* Disable default constructors */
49
Scheduler(const Scheduler &);
50
Scheduler& operator=(const Scheduler &);
52
explicit Scheduler(std::string name_arg)
53
: Plugin(name_arg, "Scheduler")
55
virtual ~Scheduler() {}
58
* Add a session to the scheduler. When the scheduler is ready to run the
59
* session, it should call session->run().
61
virtual bool addSession(Session::shared_ptr &session)= 0;
64
* Notify the scheduler that it should be killed gracefully.
66
virtual void killSession(Session *) {}
69
* This is called when a scheduler should kill the session immedaitely.
71
virtual void killSessionNow(Session::shared_ptr&) {}
73
static bool addPlugin(plugin::Scheduler *sced);
74
static void removePlugin(plugin::Scheduler *sced);
75
static bool setPlugin(const std::string& name);
76
static Scheduler *getScheduler();
79
} /* namespace plugin */
80
} /* namespace drizzled */
82
#endif /* DRIZZLED_PLUGIN_SCHEDULER_H */
23
#ifndef DRIZZLED_PLUGIN_SCHEDULING_H
24
#define DRIZZLED_PLUGIN_SCHEDULING_H
26
typedef struct scheduling_st
28
/* todo, define this api */
29
/* this is the API that a scheduling plugin must implement.
30
it should implement each of these function pointers.
31
if a function returns bool true, that means it failed.
32
if a function pointer is NULL, that's ok.
35
bool (*scheduling_func1)(Session *session, void *parm1, void *parm2);
36
bool (*scheduling_func2)(Session *session, void *parm3, void *parm4);
39
#endif /* DRIZZLED_PLUGIN_SCHEDULING_H */