| // Copyright 2017 The Bazel Authors. All rights reserved. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| package com.google.devtools.build.lib.buildeventstream; |
| |
| import com.google.common.collect.ImmutableList; |
| import com.google.devtools.build.lib.buildeventstream.BuildEvent.LocalFile.LocalFileType; |
| import com.google.devtools.build.lib.util.Pair; |
| import com.google.devtools.build.lib.vfs.Path; |
| import com.google.protobuf.ByteString; |
| import java.util.Collection; |
| |
| /** Event reporting on statistics about the build. */ |
| public class BuildToolLogs implements BuildEventWithOrderConstraint { |
| /** These values are posted as byte strings to the BEP. */ |
| private final Collection<Pair<String, ByteString>> directValues; |
| /** |
| * These values are posted as URIs to the BEP; if these reference files, those are not uploaded. |
| */ |
| private final Collection<Pair<String, String>> directUris; |
| /** |
| * These values are local files that are uploaded if required, and turned into URIs as part of the |
| * process. |
| */ |
| private final Collection<Pair<String, Path>> logFiles; |
| |
| public BuildToolLogs( |
| Collection<Pair<String, ByteString>> directValues, |
| Collection<Pair<String, String>> directUris, |
| Collection<Pair<String, Path>> logFiles) { |
| this.directValues = directValues; |
| this.directUris = directUris; |
| this.logFiles = logFiles; |
| } |
| |
| @Override |
| public BuildEventId getEventId() { |
| return BuildEventId.buildToolLogs(); |
| } |
| |
| @Override |
| public Collection<BuildEventId> getChildrenEvents() { |
| return ImmutableList.of(); |
| } |
| |
| @Override |
| public Collection<LocalFile> referencedLocalFiles() { |
| ImmutableList.Builder<LocalFile> localFiles = ImmutableList.builder(); |
| for (Pair<String, Path> logFile : logFiles) { |
| localFiles.add(new LocalFile(logFile.getSecond(), LocalFileType.LOG)); |
| } |
| return localFiles.build(); |
| } |
| |
| @Override |
| public BuildEventStreamProtos.BuildEvent asStreamProto(BuildEventContext converters) { |
| BuildEventStreamProtos.BuildToolLogs.Builder toolLogs = |
| BuildEventStreamProtos.BuildToolLogs.newBuilder(); |
| for (Pair<String, ByteString> direct : directValues) { |
| toolLogs.addLog( |
| BuildEventStreamProtos.File.newBuilder() |
| .setName(direct.getFirst()) |
| .setContents(direct.getSecond()) |
| .build()); |
| } |
| for (Pair<String, String> direct : directUris) { |
| toolLogs.addLog( |
| BuildEventStreamProtos.File.newBuilder() |
| .setName(direct.getFirst()) |
| .setUri(direct.getSecond()) |
| .build()); |
| } |
| for (Pair<String, Path> logFile : logFiles) { |
| String uri = converters.pathConverter().apply(logFile.getSecond()); |
| if (uri != null) { |
| toolLogs.addLog( |
| BuildEventStreamProtos.File.newBuilder() |
| .setName(logFile.getFirst()) |
| .setUri(uri) |
| .build()); |
| } |
| } |
| return GenericBuildEvent.protoChaining(this).setBuildToolLogs(toolLogs.build()).build(); |
| } |
| |
| @Override |
| public Collection<BuildEventId> postedAfter() { |
| return ImmutableList.of(BuildEventId.buildFinished()); |
| } |
| } |