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
LogDocMergePolicy.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.Index
21 {
22 
23  /// <summary>This is a <see cref="LogMergePolicy" /> that measures size of a
24  /// segment as the number of documents (not taking deletions
25  /// into account).
26  /// </summary>
27 
29  {
30 
31  /// <seealso cref="MinMergeDocs">
32  /// </seealso>
33  public const int DEFAULT_MIN_MERGE_DOCS = 1000;
34 
35  public LogDocMergePolicy(IndexWriter writer):base(writer)
36  {
37  minMergeSize = DEFAULT_MIN_MERGE_DOCS;
38 
39  // maxMergeSize is never used by LogDocMergePolicy; set
40  // it to Long.MAX_VALUE to disable it
41  maxMergeSize = System.Int64.MaxValue;
42  }
43  protected internal override long Size(SegmentInfo info)
44  {
45  return SizeDocs(info);
46  }
47 
48  protected override void Dispose(bool disposing)
49  {
50  // Do nothing.
51  }
52 
53  /// <summary>Gets or sets the minimum size for the lowest level segments.
54  /// Any segments below this size are considered to be on
55  /// the same level (even if they vary drastically in size)
56  /// and will be merged whenever there are mergeFactor of
57  /// them. This effectively truncates the "long tail" of
58  /// small segments that would otherwise be created into a
59  /// single level. If you set this too large, it could
60  /// greatly increase the merging cost during indexing (if
61  /// you flush many small segments).
62  /// </summary>
63  public virtual int MinMergeDocs
64  {
65  get { return (int) minMergeSize; }
66  set { minMergeSize = value; }
67  }
68  }
69 }