EA-64538 (read action)
[idea/community.git] / plugins / properties / properties-psi-impl / src / com / intellij / lang / properties / BundleNameEvaluator.java
1 /*
2  * Copyright 2000-2015 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 package com.intellij.lang.properties;
17
18 import com.intellij.openapi.application.ApplicationManager;
19 import com.intellij.openapi.util.Computable;
20 import com.intellij.psi.PsiDirectory;
21 import com.intellij.psi.PsiFile;
22 import org.jetbrains.annotations.Nullable;
23
24 public interface BundleNameEvaluator {
25   BundleNameEvaluator DEFAULT = new BundleNameEvaluator() {
26     @Nullable
27     public String evaluateBundleName(final PsiFile psiFile) {
28       PsiDirectory directory = ApplicationManager.getApplication().runReadAction(new Computable<PsiDirectory>() {
29         @Override
30         public PsiDirectory compute() {
31           return psiFile.getParent();
32         }
33       });
34       if (directory == null) return null;
35
36       String packageQualifiedName = PropertiesUtil.getPackageQualifiedName(directory);
37       if (packageQualifiedName == null) return null;
38
39       StringBuilder qName = new StringBuilder(packageQualifiedName);
40       if (qName.length() > 0) qName.append(".");
41       qName.append(ResourceBundleManager.getInstance(psiFile.getProject()).getBaseName(psiFile));
42       return qName.toString();
43     }
44   };
45
46   @Nullable
47   String evaluateBundleName(PsiFile psiFile);
48 }