fix NPE
[teamcity/dotNetPackagesSupport.git] / nuget-server / src / jetbrains / buildServer / nuget / server / exec / ListPackagesCommandProcessor.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.server.exec;\r
18 \r
19 import com.intellij.openapi.diagnostic.Logger;\r
20 import jetbrains.buildServer.messages.serviceMessages.ServiceMessage;\r
21 import jetbrains.buildServer.messages.serviceMessages.ServiceMessageParserCallback;\r
22 import jetbrains.buildServer.util.StringUtil;\r
23 import org.jetbrains.annotations.NotNull;\r
24 import org.jetbrains.annotations.Nullable;\r
25 \r
26 import java.text.ParseException;\r
27 import java.util.ArrayList;\r
28 import java.util.Collection;\r
29 import java.util.Collections;\r
30 import java.util.List;\r
31 \r
32 /**\r
33 * Created by Eugene Petrenko (eugene.petrenko@gmail.com)\r
34 * Date: 14.07.11 13:23\r
35 */\r
36 public class ListPackagesCommandProcessor implements NuGetOutputProcessor<Collection<PackageInfo>> {\r
37   private static final Logger LOG = Logger.getInstance(ListPackagesCommandProcessor.class.getName());\r
38   private final String mySource;\r
39   private final List<PackageInfo> myPackages = new ArrayList<PackageInfo>();\r
40 \r
41   public ListPackagesCommandProcessor(@Nullable final String source) {\r
42     mySource = source;\r
43   }\r
44 \r
45   public void onStdOutput(String text) {\r
46     if (LOG.isDebugEnabled()) {\r
47       LOG.debug(text);\r
48     }\r
49 \r
50     ServiceMessage.parse(text, new ServiceMessageParserCallback() {\r
51       public void regularText(@NotNull String s) {\r
52       }\r
53 \r
54       public void serviceMessage(@NotNull ServiceMessage serviceMessage) {\r
55         if (!"nuget-package".equals(serviceMessage.getMessageName())) return;\r
56         final String id = serviceMessage.getAttributes().get("Id");\r
57         final String version = serviceMessage.getAttributes().get("Version");\r
58 \r
59         if (StringUtil.isEmptyOrSpaces(id)) return;\r
60         if (StringUtil.isEmptyOrSpaces(version)) return;\r
61 \r
62         myPackages.add(new PackageInfo(mySource, id, version));\r
63 \r
64       }\r
65 \r
66       public void parseException(@NotNull ParseException e, @NotNull String s) {\r
67       }\r
68     });\r
69   }\r
70 \r
71   public void onStdError(String text) {\r
72     if (!StringUtil.isEmptyOrSpaces(text)) {\r
73       LOG.warn(text);\r
74     }\r
75   }\r
76 \r
77   public void onFinished(int exitCode) {\r
78     if (LOG.isDebugEnabled()) {\r
79       LOG.debug("NuGet TeamCity.List command exited with " + exitCode);\r
80     }\r
81     if (exitCode != 0) {\r
82       throw new RuntimeException("Failed to execute TeamCity.List command. Exit code was " + exitCode);\r
83     }\r
84   }\r
85 \r
86   @NotNull\r
87   public Collection<PackageInfo> getResult() {\r
88     return Collections.unmodifiableList(myPackages);\r
89   }\r
90 }\r