summaryrefslogtreecommitdiff
path: root/qpid/cpp/src/sys/ProducerConsumer.cpp
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2007-04-13 20:58:27 +0000
committerAlan Conway <aconway@apache.org>2007-04-13 20:58:27 +0000
commit26a723475dc6926bde883c8c7f983ee44d8deb01 (patch)
treed3be63007fb9799549310ee31cfd1aae589bfd96 /qpid/cpp/src/sys/ProducerConsumer.cpp
parent52a1b1fbcaf2935874f8ab7b85a06d09eed4a94c (diff)
downloadqpid-python-26a723475dc6926bde883c8c7f983ee44d8deb01.tar.gz
Moved src/ source code to src/qpid directory:
- allows rhm package to build consistently against checked-out or installed qpid. - consistent correspondence between source paths and C++ namespaces. - consistent use of #include <qpid/foo> in source and by users. - allows header files to split over multiple directories, e.g. separating generated code, separating public API from private files. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@528668 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src/sys/ProducerConsumer.cpp')
-rw-r--r--qpid/cpp/src/sys/ProducerConsumer.cpp141
1 files changed, 0 insertions, 141 deletions
diff --git a/qpid/cpp/src/sys/ProducerConsumer.cpp b/qpid/cpp/src/sys/ProducerConsumer.cpp
deleted file mode 100644
index 1cf2a79784..0000000000
--- a/qpid/cpp/src/sys/ProducerConsumer.cpp
+++ /dev/null
@@ -1,141 +0,0 @@
-/*
- *
- * Copyright (c) 2006 The Apache Software Foundation
- *
- * Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *
- */
-
-
-#include "../QpidError.h"
-#include "ScopedIncrement.h"
-#include "ProducerConsumer.h"
-
-namespace qpid {
-namespace sys {
-
-// // ================ ProducerConsumer
-
-ProducerConsumer::ProducerConsumer(size_t init_items)
- : items(init_items), waiters(0), shutdownFlag(false)
-{}
-
-void ProducerConsumer::shutdown() {
- Mutex::ScopedLock l(monitor);
- shutdownFlag = true;
- monitor.notifyAll();
- // Wait for waiting consumers to wake up.
- while (waiters > 0)
- monitor.wait();
-}
-
-size_t ProducerConsumer::available() const {
- Mutex::ScopedLock l(monitor);
- return items;
-}
-
-size_t ProducerConsumer::consumers() const {
- Mutex::ScopedLock l(monitor);
- return waiters;
-}
-
-// ================ Lock
-
-ProducerConsumer::Lock::Lock(ProducerConsumer& p)
- : pc(p), lock(p.monitor), status(INCOMPLETE) {}
-
-bool ProducerConsumer::Lock::isOk() const {
- return !pc.isShutdown() && status==INCOMPLETE;
-}
-
-void ProducerConsumer::Lock::checkOk() const {
- assert(!pc.isShutdown());
- assert(status == INCOMPLETE);
-}
-
-ProducerConsumer::Lock::~Lock() {
- assert(status != INCOMPLETE || pc.isShutdown());
-}
-
-void ProducerConsumer::Lock::confirm() {
- checkOk();
- status = CONFIRMED;
-}
-
-void ProducerConsumer::Lock::cancel() {
- checkOk();
- status = CANCELLED;
-}
-
-// ================ ProducerLock
-
-ProducerConsumer::ProducerLock::ProducerLock(ProducerConsumer& p) : Lock(p)
-{}
-
-
-ProducerConsumer::ProducerLock::~ProducerLock() {
- if (status == CONFIRMED) {
- pc.items++;
- pc.monitor.notify(); // Notify a consumer.
- }
-}
-
-// ================ ConsumerLock
-
-ProducerConsumer::ConsumerLock::ConsumerLock(ProducerConsumer& p) : Lock(p)
-{
- if (isOk()) {
- ScopedIncrement<size_t> inc(pc.waiters);
- while (pc.items == 0 && !pc.shutdownFlag) {
- pc.monitor.wait();
- }
- }
-}
-
-ProducerConsumer::ConsumerLock::ConsumerLock(
- ProducerConsumer& p, const Time& timeout) : Lock(p)
-{
- if (isOk()) {
- // Don't wait if timeout==0
- if (timeout == 0) {
- if (pc.items == 0)
- status = TIMEOUT;
- return;
- }
- else {
- Time deadline = now() + timeout;
- ScopedIncrement<size_t> inc(pc.waiters);
- while (pc.items == 0 && !pc.shutdownFlag) {
- if (!pc.monitor.wait(deadline)) {
- status = TIMEOUT;
- return;
- }
- }
- }
- }
-}
-
-ProducerConsumer::ConsumerLock::~ConsumerLock() {
- if (pc.isShutdown()) {
- if (pc.waiters == 0)
- pc.monitor.notifyAll(); // Notify shutdown thread(s)
- }
- else if (status==CONFIRMED) {
- pc.items--;
- if (pc.items > 0)
- pc.monitor.notify(); // Notify another consumer.
- }
-}
-
-
-}} // namespace qpid::sys