diff options
author | Gordon Sim <gsim@apache.org> | 2007-11-29 11:54:17 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2007-11-29 11:54:17 +0000 |
commit | 6b179639ac573be8f5c7d84bfd480c71a6815265 (patch) | |
tree | 29d56665e8258c923f256fbed3942148dede48e0 /cpp/src/qpid/sys/AggregateOutput.cpp | |
parent | d1f32f54b73807b778eb6027bb048f9e7b0e808f (diff) | |
download | qpid-python-6b179639ac573be8f5c7d84bfd480c71a6815265.tar.gz |
Changes to threading: queues serialiser removed, io threads used to drive dispatch to consumers
Fix to PersistableMessage: use correct lock when accessing synclist, don't hold enqueue lock when notifying queues
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@599395 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/sys/AggregateOutput.cpp')
-rw-r--r-- | cpp/src/qpid/sys/AggregateOutput.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/cpp/src/qpid/sys/AggregateOutput.cpp b/cpp/src/qpid/sys/AggregateOutput.cpp new file mode 100644 index 0000000000..74eea5ed08 --- /dev/null +++ b/cpp/src/qpid/sys/AggregateOutput.cpp @@ -0,0 +1,61 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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 "qpid/sys/AggregateOutput.h" +#include "qpid/log/Statement.h" + +namespace qpid { +namespace sys { + +void AggregateOutput::activateOutput() +{ + control.activateOutput(); +} + +bool AggregateOutput::doOutput() +{ + bool result = false; + if (!tasks.empty()) { + if (next >= tasks.size()) next = next % tasks.size(); + + size_t start = next; + //loop until a task generated some output + while (!result) { + result = tasks[next++]->doOutput(); + if (next >= tasks.size()) next = next % tasks.size(); + if (start == next) break; + } + } + return result; +} + +void AggregateOutput::addOutputTask(OutputTask* t) +{ + tasks.push_back(t); +} + +void AggregateOutput::removeOutputTask(OutputTask* t) +{ + TaskList::iterator i = find(tasks.begin(), tasks.end(), t); + if (i != tasks.end()) tasks.erase(i); +} + +}} // namespace qpid::sys |