diff --git a/abacus.cabal b/abacus.cabal index 495053b..b73a745 100644 --- a/abacus.cabal +++ b/abacus.cabal @@ -19,7 +19,8 @@ extra-source-files: library exposed-modules: - Lib + Abacus + Abacus.Internal other-modules: Paths_abacus autogen-modules: diff --git a/src/Abacus.hs b/src/Abacus.hs new file mode 100644 index 0000000..a374afb --- /dev/null +++ b/src/Abacus.hs @@ -0,0 +1,40 @@ +{-| + +Module : Abacus +Description : Core functionality for a simple abacus program +Copyright : (C) Jonathan Lamothe +License : AGPL-3.0-or-later +Maintainer : jonathan@jlamothe.net +Stability : experimental +Portability : POSIX + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU Affero General Public License as +published by the Free Software Foundation, either version 3 of the +License, or (at your option) any later version. + +This program 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 +Affero General Public License for more details. + +You should have received a copy of the GNU Affero General Public +License along with this program. If not, see +. + +-} + +module Abacus (Abacus, newAbacus) where + +import Abacus.Internal + +-- | Constructs the initial state of a new "Abacus" +newAbacus + :: Int + -- ^ The number of beads on each rung + -> Int + -- ^ The number of rungs + -> Maybe Abacus +newAbacus = undefined + +--jl diff --git a/src/Abacus/Internal.hs b/src/Abacus/Internal.hs new file mode 100644 index 0000000..ae40b17 --- /dev/null +++ b/src/Abacus/Internal.hs @@ -0,0 +1,43 @@ +{-| + +Module : Abacus.Internal +Description : Core functionality for a simple abacus program +Copyright : (C) Jonathan Lamothe +License : AGPL-3.0-or-later +Maintainer : jonathan@jlamothe.net +Stability : experimental +Portability : POSIX + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU Affero General Public License as +published by the Free Software Foundation, either version 3 of the +License, or (at your option) any later version. + +This program 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 +Affero General Public License for more details. + +You should have received a copy of the GNU Affero General Public +License along with this program. If not, see +. + +# Important Note + +This module should only be imported directl by the Abacus module and +the testing suite. Anything contained herein should be considered +subject to change without notice. + +-} + +module Abacus.Internal (Abacus (..)) where + +-- | Represents the state of an Abacus +data Abacus = Abacus + { abacusNumBeads :: Int + -- ^ The number of beads per rung of the abacus + , abacusRows :: [Int] + -- ^ The number of beads slid across each rung + } deriving (Eq, Show) + +--jl diff --git a/src/Lib.hs b/src/Lib.hs deleted file mode 100644 index d36ff27..0000000 --- a/src/Lib.hs +++ /dev/null @@ -1,6 +0,0 @@ -module Lib - ( someFunc - ) where - -someFunc :: IO () -someFunc = putStrLn "someFunc"