Skip to content

Commit

Permalink
ogma-cli: Make new fprime command available via the CLI. Refs #77.
Browse files Browse the repository at this point in the history
Expose the new FPrime backend via the command-line interface.
  • Loading branch information
ivanperez-keera committed Mar 21, 2023
1 parent d66d97e commit bc4ede9
Show file tree
Hide file tree
Showing 3 changed files with 163 additions and 0 deletions.
1 change: 1 addition & 0 deletions ogma-cli/ogma-cli.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,7 @@ executable ogma
CLI.CommandCFSApp
CLI.CommandCStructs2Copilot
CLI.CommandCStructs2MsgHandlers
CLI.CommandFPrimeApp
CLI.CommandFretComponentSpec2Copilot
CLI.CommandFretReqsDB2Copilot
CLI.CommandROSApp
Expand Down
148 changes: 148 additions & 0 deletions ogma-cli/src/CLI/CommandFPrimeApp.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1,148 @@
-- Copyright 2022 United States Government as represented by the Administrator
-- of the National Aeronautics and Space Administration. All Rights Reserved.
--
-- Disclaimers
--
-- No Warranty: THE SUBJECT SOFTWARE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY
-- OF ANY KIND, EITHER EXPRESSED, IMPLIED, OR STATUTORY, INCLUDING, BUT NOT
-- LIMITED TO, ANY WARRANTY THAT THE SUBJECT SOFTWARE WILL CONFORM TO
-- SPECIFICATIONS, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
-- PARTICULAR PURPOSE, OR FREEDOM FROM INFRINGEMENT, ANY WARRANTY THAT THE
-- SUBJECT SOFTWARE WILL BE ERROR FREE, OR ANY WARRANTY THAT DOCUMENTATION, IF
-- PROVIDED, WILL CONFORM TO THE SUBJECT SOFTWARE. THIS AGREEMENT DOES NOT, IN
-- ANY MANNER, CONSTITUTE AN ENDORSEMENT BY GOVERNMENT AGENCY OR ANY PRIOR
-- RECIPIENT OF ANY RESULTS, RESULTING DESIGNS, HARDWARE, SOFTWARE PRODUCTS OR
-- ANY OTHER APPLICATIONS RESULTING FROM USE OF THE SUBJECT SOFTWARE. FURTHER,
-- GOVERNMENT AGENCY DISCLAIMS ALL WARRANTIES AND LIABILITIES REGARDING
-- THIRD-PARTY SOFTWARE, IF PRESENT IN THE ORIGINAL SOFTWARE, AND DISTRIBUTES
-- IT "AS IS."
--
-- Waiver and Indemnity: RECIPIENT AGREES TO WAIVE ANY AND ALL CLAIMS AGAINST
-- THE UNITED STATES GOVERNMENT, ITS CONTRACTORS AND SUBCONTRACTORS, AS WELL AS
-- ANY PRIOR RECIPIENT. IF RECIPIENT'S USE OF THE SUBJECT SOFTWARE RESULTS IN
-- ANY LIABILITIES, DEMANDS, DAMAGES, EXPENSES OR LOSSES ARISING FROM SUCH USE,
-- INCLUDING ANY DAMAGES FROM PRODUCTS BASED ON, OR RESULTING FROM, RECIPIENT'S
-- USE OF THE SUBJECT SOFTWARE, RECIPIENT SHALL INDEMNIFY AND HOLD HARMLESS THE
-- UNITED STATES GOVERNMENT, ITS CONTRACTORS AND SUBCONTRACTORS, AS WELL AS ANY
-- PRIOR RECIPIENT, TO THE EXTENT PERMITTED BY LAW. RECIPIENT'S SOLE REMEDY
-- FOR ANY SUCH MATTER SHALL BE THE IMMEDIATE, UNILATERAL TERMINATION OF THIS
-- AGREEMENT.
--
-- | CLI interface to the FPrimeApp subcommand.
module CLI.CommandFPrimeApp
(
-- * Direct command access
command
, CommandOpts
, ErrorCode

-- * CLI
, commandDesc
, commandOptsParser
)
where

-- External imports
import Options.Applicative ( Parser, help, long, metavar, optional, showDefault,
strOption, value )

-- External imports: command results
import Command.Result ( Result )

-- External imports: actions or commands supported
import Command.FPrimeApp ( ErrorCode, fprimeApp )

-- * Command

-- | Options needed to generate the FPrime component.
data CommandOpts = CommandOpts
{ fprimeAppTarget :: String
, fprimeAppFRETFile :: Maybe String
, fprimeAppVarNames :: Maybe String
, fprimeAppVarDB :: Maybe String
, fprimeAppHandlers :: Maybe String
}

-- | Create <https://github.com/nasa/fprime FPrime> component that subscribe
-- to obtain necessary data from the bus and call Copilot when new data
-- arrives.
--
-- This is just an uncurried version of "Command.fprimeApp".
command :: CommandOpts -> IO (Result ErrorCode)
command c =
fprimeApp
(fprimeAppTarget c)
(fprimeAppFRETFile c)
(fprimeAppVarNames c)
(fprimeAppVarDB c)
(fprimeAppHandlers c)

-- * CLI

-- | FPrime command description
commandDesc :: String
commandDesc = "Generate a complete F' monitoring component"

-- | Subparser for the @fprime@ command, used to generate an FPrime component
-- connected to Copilot monitors.
commandOptsParser :: Parser CommandOpts
commandOptsParser = CommandOpts
<$> strOption
( long "app-target-dir"
<> metavar "DIR"
<> showDefault
<> value "fprime"
<> help strFPrimeAppDirArgDesc
)
<*> optional
( strOption
( long "fret-file-name"
<> metavar "FILENAME"
<> help strFPrimeAppFRETFileNameArgDesc
)
)
<*> optional
( strOption
( long "variable-file"
<> metavar "FILENAME"
<> help strFPrimeAppVarListArgDesc
)
)
<*> optional
( strOption
( long "variable-db"
<> metavar "FILENAME"
<> help strFPrimeAppVarDBArgDesc
)
)
<*> optional
( strOption
( long "handlers-file"
<> metavar "FILENAME"
<> help strFPrimeAppHandlerListArgDesc
)
)

-- | Argument target directory to FPrime component generation command
strFPrimeAppDirArgDesc :: String
strFPrimeAppDirArgDesc = "Target directory"

-- | Argument FRET CS to FPrime component generation command
strFPrimeAppFRETFileNameArgDesc :: String
strFPrimeAppFRETFileNameArgDesc =
"File containing FRET Component Specification"

-- | Argument variable list to FPrime component generation command
strFPrimeAppVarListArgDesc :: String
strFPrimeAppVarListArgDesc =
"File containing list of F' variables to make accessible"

-- | Argument variable database to FPrime component generation command
strFPrimeAppVarDBArgDesc :: String
strFPrimeAppVarDBArgDesc =
"File containing a DB of known F' variables"

-- | Argument handler list to FPrime component generation command
strFPrimeAppHandlerListArgDesc :: String
strFPrimeAppHandlerListArgDesc =
"File containing list of Copilot handlers used in the specification"
14 changes: 14 additions & 0 deletions ogma-cli/src/CLI/CommandTop.hs
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ import Command.Result ( Result )
import qualified CLI.CommandCFSApp
import qualified CLI.CommandCStructs2Copilot
import qualified CLI.CommandCStructs2MsgHandlers
import qualified CLI.CommandFPrimeApp
import qualified CLI.CommandFretComponentSpec2Copilot
import qualified CLI.CommandFretReqsDB2Copilot
import qualified CLI.CommandROSApp
Expand All @@ -104,6 +105,7 @@ data CommandOpts =
CommandOptsCFSApp CLI.CommandCFSApp.CommandOpts
| CommandOptsCStructs2Copilot CLI.CommandCStructs2Copilot.CommandOpts
| CommandOptsCStructs2MsgHandlers CLI.CommandCStructs2MsgHandlers.CommandOpts
| CommandOptsFPrimeApp CLI.CommandFPrimeApp.CommandOpts
| CommandOptsFretComponentSpec2Copilot CLI.CommandFretComponentSpec2Copilot.CommandOpts
| CommandOptsFretReqsDB2Copilot CLI.CommandFretReqsDB2Copilot.CommandOpts
| CommandOptsROSApp CLI.CommandROSApp.CommandOpts
Expand All @@ -121,6 +123,7 @@ commandOptsParser = subparser
( subcommandCStructs
<> subcommandMsgHandlers
<> subcommandCFSApp
<> subcommandFPrimeApp
<> subcommandFretComponentSpec
<> subcommandFretReqs
<> subcommandROSApp
Expand Down Expand Up @@ -187,6 +190,15 @@ subcommandROSApp =
(CommandOptsROSApp <$> CLI.CommandROSApp.commandOptsParser)
CLI.CommandROSApp.commandDesc

-- | Modifier for the FPrime app expansion subcommand, linking the subcommand
-- options and description to the command @fprime@ at top level.
subcommandFPrimeApp :: Mod CommandFields CommandOpts
subcommandFPrimeApp =
subcommand
"fprime"
(CommandOptsFPrimeApp <$> CLI.CommandFPrimeApp.commandOptsParser)
CLI.CommandFPrimeApp.commandDesc

-- * Command dispatcher

-- | Command dispatcher that obtains the parameters from the command line and
Expand Down Expand Up @@ -215,6 +227,8 @@ command (CommandOptsCStructs2Copilot c) =
id <$> CLI.CommandCStructs2Copilot.command c
command (CommandOptsCStructs2MsgHandlers c) =
id <$> CLI.CommandCStructs2MsgHandlers.command c
command (CommandOptsFPrimeApp c) =
id <$> CLI.CommandFPrimeApp.command c
command (CommandOptsFretComponentSpec2Copilot c) =
id <$> CLI.CommandFretComponentSpec2Copilot.command c
command (CommandOptsFretReqsDB2Copilot c) =
Expand Down

0 comments on commit bc4ede9

Please sign in to comment.