Files
linux-packaging-mono/mcs/class/RabbitMQ.Client/src/util/Semaphore.cs
Jo Shields a575963da9 Imported Upstream version 3.6.0
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
2014-08-13 10:39:27 +01:00

139 lines
4.9 KiB
C#

// This source code is dual-licensed under the Apache License, version
// 2.0, and the Mozilla Public License, version 1.1.
//
// The APL v2.0:
//
//---------------------------------------------------------------------------
// Copyright (C) 2007-2009 LShift Ltd., Cohesive Financial
// Technologies LLC., and Rabbit Technologies Ltd.
//
// 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.
//---------------------------------------------------------------------------
//
// The MPL v1.1:
//
//---------------------------------------------------------------------------
// The contents of this file are subject to the Mozilla Public License
// Version 1.1 (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.rabbitmq.com/mpl.html
//
// Software distributed under the License is distributed on an "AS IS"
// basis, 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 is The RabbitMQ .NET Client.
//
// The Initial Developers of the Original Code are LShift Ltd,
// Cohesive Financial Technologies LLC, and Rabbit Technologies Ltd.
//
// Portions created before 22-Nov-2008 00:00:00 GMT by LShift Ltd,
// Cohesive Financial Technologies LLC, or Rabbit Technologies Ltd
// are Copyright (C) 2007-2008 LShift Ltd, Cohesive Financial
// Technologies LLC, and Rabbit Technologies Ltd.
//
// Portions created by LShift Ltd are Copyright (C) 2007-2009 LShift
// Ltd. Portions created by Cohesive Financial Technologies LLC are
// Copyright (C) 2007-2009 Cohesive Financial Technologies
// LLC. Portions created by Rabbit Technologies Ltd are Copyright
// (C) 2007-2009 Rabbit Technologies Ltd.
//
// All Rights Reserved.
//
// Contributor(s): ______________________________________.
//
//---------------------------------------------------------------------------
using System;
using System.Collections;
using System.Threading;
namespace RabbitMQ.Util {
///<summary>A classic counting semaphore.</summary>
///<remarks>
/// The .NET framework does not introduce a counting semaphore
/// until framework release 2.0. Consequently, we implement one
/// here, for the benefit of .NET 1.1.
///</remarks>
public class Semaphore {
private int m_count;
///<summary>Create a Semaphore, with its counter initialized
///to 1.</summary>
public Semaphore()
: this(1)
{}
///<summary>Create a Semaphore, with its counter initialized
///to the value passed in.</summary>
public Semaphore(int initialCount)
{
m_count = initialCount;
}
///<summary>Acquire a single resource, decrementing the count by one.</summary>
///<remarks>
/// Not interruptable - will retry forever until a resource comes available.
///</remarks>
public void Wait() {
lock (this) {
while (true) {
if (m_count > 0) {
m_count--;
return;
} else {
Monitor.Wait(this);
}
}
}
}
///<summary>Acquire a single resource, decrementing the count
///by one and returning true, if a resource is available;
///otherwise, return false immediately.</summary>
public bool TryWait() {
lock (this) {
if (m_count > 0) {
m_count--;
return true;
} else {
return false;
}
}
}
///<summary>Release a single resource, incrementing the count
///by one.</summary>
public void Release() {
lock (this) {
m_count++;
Monitor.Pulse(this);
}
}
///<summary>Retrieve the current semaphore value.</summary>
///<remarks>
/// Consider carefully whether this property is actually what
/// you want - usually, using this property is wrong, and
/// either Wait() or TryWait() is the correct choice.
///</remarks>
public int Value {
get {
lock (this) {
return m_count;
}
}
}
}
}