move to .impl package
[teamcity/dotNetPackagesSupport.git] / nuget-agent / src / jetbrains / buildServer / nuget / agent / install / impl / PackageUsagesImpl.java
1 /*\r
2  * Copyright 2000-2011 JetBrains s.r.o.\r
3  *\r
4  * Licensed under the Apache License, Version 2.0 (the "License");\r
5  * you may not use this file except in compliance with the License.\r
6  * You may obtain a copy of the License at\r
7  *\r
8  * http://www.apache.org/licenses/LICENSE-2.0\r
9  *\r
10  * Unless required by applicable law or agreed to in writing, software\r
11  * distributed under the License is distributed on an "AS IS" BASIS,\r
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
13  * See the License for the specific language governing permissions and\r
14  * limitations under the License.\r
15  */\r
16 \r
17 package jetbrains.buildServer.nuget.agent.install.impl;\r
18 \r
19 import com.intellij.openapi.diagnostic.Logger;\r
20 import jetbrains.buildServer.RunBuildException;\r
21 import jetbrains.buildServer.agent.BuildFinishedStatus;\r
22 import jetbrains.buildServer.agent.BuildProcess;\r
23 import jetbrains.buildServer.nuget.agent.install.NuGetPackagesCollector;\r
24 import jetbrains.buildServer.nuget.agent.install.PackageUsages;\r
25 import jetbrains.buildServer.nuget.agent.util.BuildProcessBase;\r
26 import org.jetbrains.annotations.NotNull;\r
27 \r
28 import java.io.File;\r
29 import java.io.IOException;\r
30 \r
31 /**\r
32  * Created by Eugene Petrenko (eugene.petrenko@gmail.com)\r
33  * Date: 18.07.11 23:17\r
34  */\r
35 public class PackageUsagesImpl implements PackageUsages {\r
36   private static final Logger LOG = Logger.getInstance(PackageUsagesImpl.class.getName());\r
37 \r
38   private final NuGetPackagesCollector myCollector;\r
39   private final NuGetPackagesConfigParser myParser;\r
40 \r
41   public PackageUsagesImpl(@NotNull final NuGetPackagesCollector collector,\r
42                            @NotNull final NuGetPackagesConfigParser parser) {\r
43     myCollector = collector;\r
44     myParser = parser;\r
45   }\r
46 \r
47   @NotNull\r
48   public BuildProcess createReport(@NotNull final File packagesConfig) {\r
49     return new BuildProcessBase() {\r
50       @NotNull\r
51       @Override\r
52       protected BuildFinishedStatus waitForImpl() throws RunBuildException {\r
53         if (!packagesConfig.exists()) {\r
54           LOG.debug("Packages file: " + packagesConfig + " does not exit");\r
55           return BuildFinishedStatus.FINISHED_SUCCESS;\r
56         }\r
57 \r
58         try {\r
59           myParser.parseNuGetPackages(packagesConfig, myCollector);\r
60         } catch (IOException e) {\r
61           LOG.warn("Failed to parse " + packagesConfig + ". " + e.getMessage(), e);\r
62         }\r
63 \r
64         return BuildFinishedStatus.FINISHED_SUCCESS;\r
65       }\r
66     };\r
67   }\r
68 }\r