e01d67e9f6d90045da11a135f1f04e000644c70c
[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.NuGetPackagesConfigParser;\r
25 import jetbrains.buildServer.nuget.agent.install.PackageUsages;\r
26 import jetbrains.buildServer.nuget.agent.util.BuildProcessBase;\r
27 import org.jetbrains.annotations.NotNull;\r
28 \r
29 import java.io.File;\r
30 import java.io.IOException;\r
31 \r
32 /**\r
33  * Created by Eugene Petrenko (eugene.petrenko@gmail.com)\r
34  * Date: 18.07.11 23:17\r
35  */\r
36 public class PackageUsagesImpl implements PackageUsages {\r
37   private static final Logger LOG = Logger.getInstance(PackageUsagesImpl.class.getName());\r
38 \r
39   private final NuGetPackagesCollector myCollector;\r
40   private final NuGetPackagesConfigParser myParser;\r
41 \r
42   public PackageUsagesImpl(@NotNull final NuGetPackagesCollector collector,\r
43                            @NotNull final NuGetPackagesConfigParser parser) {\r
44     myCollector = collector;\r
45     myParser = parser;\r
46   }\r
47 \r
48   @NotNull\r
49   public BuildProcess createReport(@NotNull final File packagesConfig) {\r
50     return new BuildProcessBase() {\r
51       @NotNull\r
52       @Override\r
53       protected BuildFinishedStatus waitForImpl() throws RunBuildException {\r
54         if (!packagesConfig.exists()) {\r
55           LOG.debug("Packages file: " + packagesConfig + " does not exit");\r
56           return BuildFinishedStatus.FINISHED_SUCCESS;\r
57         }\r
58 \r
59         try {\r
60           myParser.parseNuGetPackages(packagesConfig, myCollector);\r
61         } catch (IOException e) {\r
62           LOG.warn("Failed to parse " + packagesConfig + ". " + e.getMessage(), e);\r
63         }\r
64 \r
65         return BuildFinishedStatus.FINISHED_SUCCESS;\r
66       }\r
67     };\r
68   }\r
69 }\r