{-
    Copyright 2019 Austin Voecks

    This file is part of ShellCheck.
    https://www.shellcheck.net

    ShellCheck is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    ShellCheck is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <https://www.gnu.org/licenses/>.
-}
module ShellCheck.Formatter.Quiet (format) where

import ShellCheck.Interface
import ShellCheck.Formatter.Format

import Control.Monad
import Data.IORef
import System.Exit

format :: FormatterOptions -> IO Formatter
format :: FormatterOptions -> IO Formatter
format FormatterOptions
options =
    forall (m :: * -> *) a. Monad m => a -> m a
return Formatter {
        header :: IO ()
header = forall (m :: * -> *) a. Monad m => a -> m a
return (),
        footer :: IO ()
footer = forall (m :: * -> *) a. Monad m => a -> m a
return (),
        onFailure :: FilePath -> FilePath -> IO ()
onFailure = \ FilePath
_ FilePath
_ -> forall a. IO a
exitFailure,
        onResult :: CheckResult -> SystemInterface IO -> IO ()
onResult  = \ CheckResult
result SystemInterface IO
_ -> forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (forall (t :: * -> *) a. Foldable t => t a -> Bool
null forall a b. (a -> b) -> a -> b
$ CheckResult -> [PositionedComment]
crComments CheckResult
result) forall a. IO a
exitFailure
    }