farewell green items in completion
[idea/community.git] / platform / lang-impl / src / com / intellij / internal / DumpLookupElementWeights.java
1 /*
2  * Copyright 2000-2009 JetBrains s.r.o.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 package com.intellij.internal;
18
19 import com.intellij.codeInsight.lookup.LookupElement;
20 import com.intellij.codeInsight.lookup.LookupManager;
21 import com.intellij.codeInsight.lookup.impl.LookupImpl;
22 import com.intellij.openapi.actionSystem.AnAction;
23 import com.intellij.openapi.actionSystem.AnActionEvent;
24 import com.intellij.openapi.actionSystem.PlatformDataKeys;
25 import com.intellij.openapi.actionSystem.Presentation;
26 import com.intellij.openapi.diagnostic.Logger;
27 import com.intellij.openapi.editor.Editor;
28 import com.intellij.openapi.project.DumbAware;
29 import com.intellij.openapi.util.text.StringUtil;
30
31 import java.util.ArrayList;
32 import java.util.LinkedHashMap;
33 import java.util.List;
34
35 /**
36  * @author peter
37  */
38 public class DumpLookupElementWeights extends AnAction implements DumbAware {
39   private static final Logger LOG = Logger.getInstance("#com.intellij.internal.DumpLookupElementWeights");
40
41   @Override
42   public void actionPerformed(final AnActionEvent e) {
43     final Editor editor = e.getData(PlatformDataKeys.EDITOR);
44     dumpLookupElementWeights((LookupImpl)LookupManager.getActiveLookup(editor));
45   }
46
47   @Override
48   public void update(final AnActionEvent e) {
49     final Presentation presentation = e.getPresentation();
50     final Editor editor = e.getData(PlatformDataKeys.EDITOR);
51     presentation.setEnabled(editor != null && LookupManager.getActiveLookup(editor) != null);
52   }
53
54   public static void dumpLookupElementWeights(final LookupImpl lookup) {
55     String sb = StringUtil.join(getLookupElementWeights(lookup), "\n");
56     System.out.println(sb);
57     LOG.info(sb);
58   }
59
60   public static List<String> getLookupElementWeights(LookupImpl lookup) {
61     final LinkedHashMap<LookupElement,StringBuilder> strings = lookup.getRelevanceStrings();
62     List<String> sb = new ArrayList<String>();
63     for (LookupElement item : lookup.getItems()) {
64       String weight = strings.get(item).toString();
65       final String s = item.getLookupString() + (lookup.isFrozen(item) ? "\t_first_\t" : "\t") + weight;
66       sb.add(s);
67     }
68     return sb;
69   }
70 }