From 7c1f9158be7a5d1124a48f42f8d7dcfb6d5df2a6 Mon Sep 17 00:00:00 2001 From: Steven Shaw Date: Sat, 25 Nov 2006 22:04:39 +0000 Subject: QPID-128 Initial import of the C# sources. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@479211 13f79535-47bb-0310-9956-ffa450edef68 --- dotnet/Qpid.Client/Client/Closeable.cs | 71 ++++++++++++++++++++++++++++++++++ 1 file changed, 71 insertions(+) create mode 100644 dotnet/Qpid.Client/Client/Closeable.cs (limited to 'dotnet/Qpid.Client/Client/Closeable.cs') diff --git a/dotnet/Qpid.Client/Client/Closeable.cs b/dotnet/Qpid.Client/Client/Closeable.cs new file mode 100644 index 0000000000..159f71ac08 --- /dev/null +++ b/dotnet/Qpid.Client/Client/Closeable.cs @@ -0,0 +1,71 @@ +/* + * + * 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. + * + */ +using System; + +namespace Qpid.Client +{ + public abstract class Closeable + { + /// + /// Used to ensure orderly closing of the object. The only method that is allowed to be called + /// from another thread of control is close(). + /// + protected readonly object _closingLock = new object(); + + /// + /// All access to this field should be using the Inerlocked class, to make it atomic. + /// Hence it is an int since you cannot use a bool with the Interlocked class. + /// + protected int _closed = NOT_CLOSED; + + protected const int CLOSED = 1; + protected const int NOT_CLOSED = 2; + + /// + /// Checks the not closed. + /// + protected void CheckNotClosed() + { + if (_closed == CLOSED) + { + throw new InvalidOperationException("Object " + ToString() + " has been closed"); + } + } + + /// + /// Gets a value indicating whether this is closed. + /// + /// true if closed; otherwise, false. + public bool Closed + { + get + { + return _closed == CLOSED; + } + } + + /// + /// Close the resource + /// + /// If something goes wrong + public abstract void Close(); + } +} -- cgit v1.2.1