Lucene.Net  3.0.3
Lucene.Net is a port of the Lucene search engine library, written in C# and targeted at .NET runtime users.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Properties Pages
LockFactory.cs
Go to the documentation of this file.
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements. See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 
18 using System;
19 
20 namespace Lucene.Net.Store
21 {
22 
23  /// <summary> <p/>Base class for Locking implementation. <see cref="Directory" /> uses
24  /// instances of this class to implement locking.<p/>
25  ///
26  /// <p/>Note that there are some useful tools to verify that
27  /// your LockFactory is working correctly: <see cref="VerifyingLockFactory" />
28  ///, <see cref="LockStressTest" />, <see cref="LockVerifyServer" />
29  ///.<p/>
30  ///
31  /// </summary>
32  /// <seealso cref="LockVerifyServer">
33  /// </seealso>
34  /// <seealso cref="LockStressTest">
35  /// </seealso>
36  /// <seealso cref="VerifyingLockFactory">
37  /// </seealso>
38 
39  public abstract class LockFactory
40  {
41  protected internal System.String internalLockPrefix = null;
42 
43  /// <summary> Gets or sets the prefix in use for all locks created in this
44  /// LockFactory. This is normally called once, when a
45  /// Directory gets this LockFactory instance. However, you
46  /// can also call this (after this instance is assigned to
47  /// a Directory) to override the prefix in use. This
48  /// is helpful if you're running Lucene on machines that
49  /// have different mount points for the same shared
50  /// directory.
51  /// </summary>
52  public virtual string LockPrefix
53  {
54  get { return this.internalLockPrefix; }
55  set { this.internalLockPrefix = value; }
56  }
57 
58  /// <summary> Return a new Lock instance identified by lockName.</summary>
59  /// <param name="lockName">name of the lock to be created.
60  /// </param>
61  public abstract Lock MakeLock(System.String lockName);
62 
63  /// <summary> Attempt to clear (forcefully unlock and remove) the
64  /// specified lock. Only call this at a time when you are
65  /// certain this lock is no longer in use.
66  /// </summary>
67  /// <param name="lockName">name of the lock to be cleared.
68  /// </param>
69  abstract public void ClearLock(System.String lockName);
70  }
71 }