8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-31 14:43:04 +01:00
firebird-mirror/src/common/classes/fb_pair.h
alexpeshkoff 7007d6f2a4 1. introduced Jrd and Ods namespaces
2. cleanup of blk* request conversions
3. fixed memory allocation in Execute Statement
2004-03-20 14:57:40 +00:00

136 lines
3.7 KiB
C++

/*
* PROGRAM: Common class definition
* MODULE: fb_pair.h
* DESCRIPTION: Provides almost that same functionality,
* that STL::pair does, but behaves
* MemoryPools friendly.
*
* The contents of this file are subject to the Initial
* Developer's Public License Version 1.0 (the "License");
* you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
* http://www.ibphoenix.com/main.nfs?a=ibphoenix&page=ibp_idpl.
*
* Software distributed under the License is distributed AS IS,
* WITHOUT WARRANTY OF ANY KIND, either express or implied.
* See the License for the specific language governing rights
* and limitations under the License.
*
* The Original Code was created by Alexander Peshkoff
* for the Firebird Open Source RDBMS project.
*
* Copyright (c) 2004 Alexander Peshkoff <peshkoff@mail.ru>
* and all contributors signed below.
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*/
#ifndef CLASSES_FB_PAIR_H
#define CLASSES_FB_PAIR_H
#include "../common/classes/alloc.h"
namespace Firebird
{
// Left pair - left object in such pair has MemoryPool'ed constructor,
// right one - doesn't (typically POD or builtin type)
template<typename parLeft, typename parRight>
struct Left {
typedef parLeft first_type;
typedef parRight second_type;
explicit Left(MemoryPool& p) : first(p), second() { }
explicit Left(MemoryPool& p, const parLeft& v1, const parRight& v2)
: first(p, v1), second(v2) { }
explicit Left(MemoryPool& p, const Left& lp)
: first(p, lp.first), second(lp.second) { }
parLeft first;
parRight second;
};
// Full pair - both objects in such pair have MemoryPool'ed constructors.
template<typename parLeft, typename parRight>
struct Full {
typedef parLeft first_type;
typedef parRight second_type;
explicit Full(MemoryPool& p) : first(p), second(p) { }
explicit Full(MemoryPool& p, const parLeft& v1, const parRight& v2)
: first(p, v1), second(p, v2) { }
explicit Full(MemoryPool& p, const Full& lp)
: first(p, lp.first), second(p, lp.second) { }
parLeft first;
parRight second;
};
// Pair - template providing full bool op-s set
template<typename BasePair>
struct Pair : public BasePair {
typedef typename Pair::first_type Pair_first_type;
typedef typename Pair::second_type Pair_second_type;
explicit Pair(MemoryPool& p) : BasePair(p) { }
explicit Pair(MemoryPool& p, const Pair_first_type& v1,
const Pair_second_type& v2) : BasePair(p, v1, v2) { }
explicit Pair(MemoryPool& p, const Pair& lp)
: BasePair(p, lp) { }
Pair() : BasePair(AutoStorage::getAutoMemoryPool()) { }
Pair(const Pair_first_type& v1, const Pair_second_type& v2)
: BasePair(AutoStorage::getAutoMemoryPool(), v1, v2) { }
Pair(const Pair& lp)
: BasePair(AutoStorage::getAutoMemoryPool(), lp) { }
bool operator==(const Pair& v)
{
return first == v.first && second == v.second;
}
bool operator<(const Pair& v)
{
return first < v.first || (!(first < v.first) && second < v.second);
}
bool operator!=(const Pair& v)
{
return ! (*this == v);
}
bool operator>(const Pair& v)
{
return v < *this;
}
bool operator<=(const Pair& v)
{
return ! (v < *this);
}
bool operator>=(const Pair& v)
{
return ! (*this < v);
}
};
template <typename P>
class FirstKey
{
public:
typedef typename P::first_type Pair_first_type;
static const Pair_first_type&
generate(void* sender, const P& Item)
{
return Item.first;
}
};
template <typename P>
class FirstObjectKey
{
public:
typedef typename P::first_type Pair_first_type;
static const Pair_first_type&
generate(void* sender, const P* Item)
{
return Item->first;
}
};
};
#endif // CLASSES_FB_PAIR_H