add --shared
[pylucene.git] / lucene-java-3.4.0 / lucene / contrib / benchmark / src / java / org / apache / lucene / benchmark / byTask / tasks / OptimizeTask.java
1 package org.apache.lucene.benchmark.byTask.tasks;
2
3 /**
4  * Licensed to the Apache Software Foundation (ASF) under one or more
5  * contributor license agreements.  See the NOTICE file distributed with
6  * this work for additional information regarding copyright ownership.
7  * The ASF licenses this file to You under the Apache License, Version 2.0
8  * (the "License"); you may not use this file except in compliance with
9  * the License.  You may obtain a copy of the License at
10  *
11  *     http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  */
19
20 import org.apache.lucene.benchmark.byTask.PerfRunData;
21 import org.apache.lucene.index.IndexWriter;
22
23 /**
24  * Optimize the index.
25  * <br>Other side effects: none.
26  */
27 public class OptimizeTask extends PerfTask {
28
29   public OptimizeTask(PerfRunData runData) {
30     super(runData);
31   }
32
33   int maxNumSegments = 1;
34
35   @Override
36   public int doLogic() throws Exception {
37     IndexWriter iw = getRunData().getIndexWriter();
38     iw.optimize(maxNumSegments);
39     //System.out.println("optimize called");
40     return 1;
41   }
42
43   @Override
44   public void setParams(String params) {
45     super.setParams(params);
46     maxNumSegments = Double.valueOf(params).intValue();
47   }
48
49   @Override
50   public boolean supportsParams() {
51     return true;
52   }
53 }