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}