1
/* Copyright (C) 2009 Sun Microsystems
3
This program is free software; you can redistribute it and/or modify
4
it under the terms of the GNU General Public License as published by
5
the Free Software Foundation; version 2 of the License.
7
This program is distributed in the hope that it will be useful,
8
but WITHOUT ANY WARRANTY; without even the implied warranty of
9
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
GNU General Public License for more details.
12
You should have received a copy of the GNU General Public License
13
along with this program; if not, write to the Free Software
14
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
16
#include "function_map.h"
22
/* Constructor and destructor happen during module dlopen/dlclose. */
23
static GearmanFunctionMap _functionMap;
25
GearmanFunctionMap& GetFunctionMap(void)
30
GearmanFunctionMap::GearmanFunctionMap()
32
(void) pthread_mutex_init(&lock, NULL);
35
GearmanFunctionMap::~GearmanFunctionMap()
37
map<string, gearman_client_st>::iterator x;
39
for (x= functionMap.begin(); x != functionMap.end(); x++)
40
gearman_client_free(&((*x).second));
42
(void) pthread_mutex_destroy(&lock);
45
bool GearmanFunctionMap::add(string function, string servers)
47
map<string, gearman_client_st>::iterator x;
50
pthread_mutex_lock(&lock);
52
x= functionMap.find(function);
53
if (x == functionMap.end())
55
if (gearman_client_create(&(functionMap[function])) == NULL)
57
pthread_mutex_unlock(&lock);
62
gearman_client_remove_servers(&(functionMap[function]));
63
ret= gearman_client_add_servers(&(functionMap[function]), servers.c_str());
64
pthread_mutex_unlock(&lock);
65
if (ret != GEARMAN_SUCCESS)
71
bool GearmanFunctionMap::get(string function, gearman_client_st *client)
73
map<string, gearman_client_st>::iterator x;
75
pthread_mutex_lock(&lock);
77
x= functionMap.find(function);
78
if (x == functionMap.end())
80
x= functionMap.find(string(""));
81
if (x == functionMap.end())
83
pthread_mutex_unlock(&lock);
88
/* Clone the object, the list of host:port pairs get cloned with it. */
89
if (gearman_client_clone(client, &((*x).second)) == NULL)
91
pthread_mutex_unlock(&lock);
95
pthread_mutex_unlock(&lock);