001/* 002 * SPDX-License-Identifier: Apache-2.0 003 * 004 * Copyright 2025-2026 The Enola <https://enola.dev> Authors 005 * 006 * Licensed under the Apache License, Version 2.0 (the "License"); 007 * you may not use this file except in compliance with the License. 008 * You may obtain a copy of the License at 009 * 010 * https://www.apache.org/licenses/LICENSE-2.0 011 * 012 * Unless required by applicable law or agreed to in writing, software 013 * distributed under the License is distributed on an "AS IS" BASIS, 014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 015 * See the License for the specific language governing permissions and 016 * limitations under the License. 017 */ 018package dev.enola.common.exec; 019 020import org.slf4j.Logger; 021import org.slf4j.LoggerFactory; 022 023import java.util.function.BiConsumer; 024 025public class LoggingExitConsumer implements BiConsumer<Integer, Throwable> { 026 027 private static final Logger LOG = LoggerFactory.getLogger(LoggingExitConsumer.class); 028 029 private final String details; 030 031 public LoggingExitConsumer(String details) { 032 this.details = details; 033 } 034 035 @Override 036 public void accept(Integer integer, Throwable throwable) { 037 if (throwable == null) LOG.info("Process {} exited with code {}", details, integer); 038 else 039 LOG.warn( 040 "Process {} exited with exception {}", 041 details, 042 throwable.getMessage(), 043 throwable); 044 } 045}