~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/message/catalog.h

  • Committer: Evan Jones
  • Date: 2011-01-02 18:30:08 UTC
  • mto: (2055.1.2 build)
  • mto: This revision was merged to the branch mainline in revision 2056.
  • Revision ID: evanj@mit.edu-20110102183008-ytvoaig5zxdck3d5
libdrizzle: drizzle_state_read: only call recv() if data is available.

This uses the "read ready" flag that already exists to avoid excess system calls. Without this patch, in non-blocking mode after sending a command, libdrizzle immediately calls recv(), which almost always returns EAGAIN. This patch avoids that, instead returning IO_WAIT. This causes the caller to wait for data on the connection using poll() or epoll() before calling recv().

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2010 Brian Aker
5
 
 *
6
 
 *  This program is free software; you can redistribute it and/or modify
7
 
 *  it under the terms of the GNU General Public License as published by
8
 
 *  the Free Software Foundation; either version 2 of the License, or
9
 
 *  (at your option) any later version.
10
 
 *
11
 
 *  This program is distributed in the hope that it will be useful,
12
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 
 *  GNU General Public License for more details.
15
 
 *
16
 
 *  You should have received a copy of the GNU General Public License
17
 
 *  along with this program; if not, write to the Free Software
18
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
 
 */
20
 
 
21
 
#ifndef DRIZZLED_MESSAGE_CATALOG_H
22
 
#define DRIZZLED_MESSAGE_CATALOG_H
23
 
 
24
 
#include <boost/shared_ptr.hpp>
25
 
#include <drizzled/message/catalog.pb.h>
26
 
 
27
 
namespace drizzled {
28
 
 
29
 
namespace identifier {
30
 
class Catalog;
31
 
} /* namespace identifier */
32
 
 
33
 
namespace message {
34
 
namespace catalog {
35
 
 
36
 
typedef boost::shared_ptr<message::Catalog> shared_ptr;
37
 
typedef std::vector< shared_ptr > vector;
38
 
typedef message::Catalog value_type;
39
 
 
40
 
shared_ptr make_shared(const drizzled::identifier::Catalog &identifier);
41
 
 
42
 
} /* namespace catalog */
43
 
} /* namespace message */
44
 
} /* namespace drizzled */
45
 
 
46
 
#endif /* DRIZZLED_MESSAGE_CATALOG_H */