diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 000000000..6599f8191 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,5 @@ +# Change Log for neuron + +## 0.2.0.0 + +- Initial public release diff --git a/default.nix b/default.nix index 12726a553..1f243f04a 100644 --- a/default.nix +++ b/default.nix @@ -2,7 +2,7 @@ let # To upgrade rib, go to https://github.com/srid/rib/commits/master, select the # revision you would like to upgrade to and set it here. Consult rib's # ChangeLog.md to check any notes on API migration. - ribRevision = "a5171e7"; + ribRevision = "19b1022442a0cde2a0b1d9373b0397030472721e"; projectRoot = ./.; in { # Rib library source to use diff --git a/neuron.cabal b/neuron.cabal index cf76a1387..bcac19528 100644 --- a/neuron.cabal +++ b/neuron.cabal @@ -1,11 +1,25 @@ cabal-version: 2.4 name: neuron -- This version must be in sync with what's in Default.dhall -version: 0.1.0.0 +version: 0.2.0.0 license: BSD-3-Clause +copyright: 2020 Sridhar Ratnakumar maintainer: srid@srid.ca author: Sridhar Ratnakumar category: Web +homepage: https://neuron.srid.ca +bug-reports: https://github.com/srid/neuron/issues +synopsis: + Haskell meets Zettelkasten, for your plain-text delight. +description: + neuron is a system for managing your plain-text Zettelkasten notes. +extra-source-files: + README.md + CHANGELOG.md + +source-repository head + type: git + location: https://github.com/srid/neuron common ghc-common ghc-options: @@ -18,7 +32,7 @@ common library-common hs-source-dirs: src default-language: Haskell2010 build-depends: - base, + base >=4.7 && <5, aeson, clay -any, containers, diff --git a/src-dhall/Config/Default.dhall b/src-dhall/Config/Default.dhall index 19b9cdc7b..8c7166b98 100644 --- a/src-dhall/Config/Default.dhall +++ b/src-dhall/Config/Default.dhall @@ -9,5 +9,5 @@ , mathJaxSupport = True , minVersion = - "0.1" + "0.2" } diff --git a/src/Neuron/Version.hs b/src/Neuron/Version.hs index c4a7587c4..69a3c17bb 100644 --- a/src/Neuron/Version.hs +++ b/src/Neuron/Version.hs @@ -2,7 +2,6 @@ {-# LANGUAGE TemplateHaskell #-} {-# LANGUAGE NoImplicitPrelude #-} --- | Neuron version module Neuron.Version where import qualified Data.Text as T @@ -12,14 +11,16 @@ import Paths_neuron (version) import Relude import Text.ParserCombinators.ReadP (readP_to_S) +-- | Neuron cabal library version neuronVersion :: Text neuronVersion = toText $ showVersion version +-- | Neuron full version (cabal library version + git revision) neuronVersionFull :: Text neuronVersionFull = T.concat [neuronVersion, " (", RepoVersion.version, ")"] --- | Check if neuronVersion is older than the given version +-- | Check if `neuronVersion` is older than the given version olderThan :: Text -> Bool olderThan s = case reverse (readP_to_S parseVersion (toString s)) of diff --git a/src/Neuron/Zettelkasten.hs b/src/Neuron/Zettelkasten.hs index 542c27124..e550860b0 100644 --- a/src/Neuron/Zettelkasten.hs +++ b/src/Neuron/Zettelkasten.hs @@ -11,11 +11,19 @@ {-# LANGUAGE TypeApplications #-} {-# LANGUAGE NoImplicitPrelude #-} +-- | Main module for using neuron as a library, instead of as a CLI tool. module Neuron.Zettelkasten - ( generateSite, + ( -- * CLI + App (..), + NewCommand (..), commandParser, run, runWith, + + -- * Rib site generation + generateSite, + + -- * Etc newZettelFile, ) where @@ -67,6 +75,7 @@ data Command Rib Rib.App.Command deriving (Eq, Show) +-- | optparse-applicative parser for neuron CLI commandParser :: Parser App commandParser = App @@ -164,10 +173,12 @@ generateSite writeHtmlRoute' zettelsPat = do writeHtmlRoute Z.Route_IndexRedirect pure (zettelStore, zettelGraph) --- | Create a new zettel file and return its slug --- TODO: refactor this +-- | Create a new zettel file and open it in editor if requested +-- +-- As well as print the path to the created file. newZettelFile :: Path b Dir -> NewCommand -> IO () newZettelFile inputDir NewCommand {..} = do + -- TODO: refactor this function zId <- Z.zettelNextIdForToday inputDir zettelFileName <- parseRelFile $ toString $ Z.zettelIDSourceFileName zId let srcPath = inputDir zettelFileName diff --git a/src/Neuron/Zettelkasten/Config.hs b/src/Neuron/Zettelkasten/Config.hs index ced6f3a72..f9f05d654 100644 --- a/src/Neuron/Zettelkasten/Config.hs +++ b/src/Neuron/Zettelkasten/Config.hs @@ -10,8 +10,11 @@ {-# LANGUAGE TypeApplications #-} {-# LANGUAGE NoImplicitPrelude #-} --- | Zettelkasten config -module Neuron.Zettelkasten.Config where +module Neuron.Zettelkasten.Config + ( Config (..), + getConfig, + ) +where import Data.FileEmbed (embedFile) import Development.Shake (Action, readFile') @@ -23,6 +26,9 @@ import Path.IO (doesFileExist) import Relude import qualified Rib +-- | Config type for @neuron.dhall@ +-- +-- See for description of the fields. makeHaskellTypes [ SingleConstructor "Config" "Config" "./src-dhall/Config/Type.dhall" ] @@ -34,6 +40,7 @@ deriving instance FromDhall Config defaultConfig :: ByteString defaultConfig = $(embedFile "./src-dhall/Config/Default.dhall") +-- | Read the optional @neuron.dhall@ config file from the zettelksaten getConfig :: Action Config getConfig = do inputDir <- Rib.ribInputDir diff --git a/src/Neuron/Zettelkasten/Graph.hs b/src/Neuron/Zettelkasten/Graph.hs index 907f4696d..52e80c11b 100644 --- a/src/Neuron/Zettelkasten/Graph.hs +++ b/src/Neuron/Zettelkasten/Graph.hs @@ -8,8 +8,22 @@ {-# LANGUAGE ViewPatterns #-} {-# LANGUAGE NoImplicitPrelude #-} --- | Graph of zettels. -module Neuron.Zettelkasten.Graph where +module Neuron.Zettelkasten.Graph + ( -- * Graph type + ZettelGraph, + + -- * Construction + mkZettelGraph, + + -- * Algorithms + backlinks, + topSort, + zettelClusters, + dfsForestFrom, + dfsForestBackwards, + obviateRootUnlessForest, + ) +where import qualified Algebra.Graph.AdjacencyMap as AM import qualified Algebra.Graph.AdjacencyMap.Algorithm as Algo @@ -23,9 +37,10 @@ import Neuron.Zettelkasten.Store (ZettelStore) import Neuron.Zettelkasten.Type import Relude +-- | The Zettelkasten graph type ZettelGraph = LAM.AdjacencyMap [Connection] ZettelID --- | Build the entire Zettel graph from the given list of note files. +-- | Build the Zettelkasten graph from the given list of note files. mkZettelGraph :: ZettelStore -> ZettelGraph mkZettelGraph store = mkGraphFrom (Map.elems store) zettelID zettelEdges connectionWhitelist @@ -58,8 +73,8 @@ topSort = Algo.topSort . LAM.skeleton -- | Get the graph without the "index" zettel. -- This is unused, but left for posterity. -withoutIndex :: ZettelGraph -> ZettelGraph -withoutIndex = LAM.induce ((/= "index") . unZettelID) +_withoutIndex :: ZettelGraph -> ZettelGraph +_withoutIndex = LAM.induce ((/= "index") . unZettelID) zettelClusters :: ZettelGraph -> [NonEmpty ZettelID] zettelClusters = mothers . LAM.skeleton diff --git a/src/Neuron/Zettelkasten/ID.hs b/src/Neuron/Zettelkasten/ID.hs index 3fd893163..03f115cc7 100644 --- a/src/Neuron/Zettelkasten/ID.hs +++ b/src/Neuron/Zettelkasten/ID.hs @@ -5,7 +5,6 @@ {-# LANGUAGE TypeApplications #-} {-# LANGUAGE NoImplicitPrelude #-} --- | Zettel ID module Neuron.Zettelkasten.ID ( ZettelID (..), Connection (..), @@ -28,7 +27,7 @@ import System.Directory (listDirectory) import qualified System.FilePattern as FP import Text.Printf --- Short Zettel ID encoding `Day` and a numeric index (on that day). +-- | Short Zettel ID encoding `Day` and a numeric index (on that day). -- -- Based on https://old.reddit.com/r/Zettelkasten/comments/fa09zw/shorter_zettel_ids/ newtype ZettelID = ZettelID {unZettelID :: Text} diff --git a/src/Neuron/Zettelkasten/Link.hs b/src/Neuron/Zettelkasten/Link.hs index 1dd9e28c9..ae6d07192 100644 --- a/src/Neuron/Zettelkasten/Link.hs +++ b/src/Neuron/Zettelkasten/Link.hs @@ -21,7 +21,7 @@ import Relude import qualified Text.MMark.Extension as Ext import Text.MMark.Extension (Extension, Inline (..)) --- | MMark extension to transform `z:/` links in Markdown +-- | MMark extension to transform @z:/@ links in Markdown linkActionExt :: ZettelStore -> Extension linkActionExt store = Ext.inlineRender $ \f -> \case diff --git a/test/Neuron/VersionSpec.hs b/test/Neuron/VersionSpec.hs index e349e0692..9733d1c15 100644 --- a/test/Neuron/VersionSpec.hs +++ b/test/Neuron/VersionSpec.hs @@ -15,20 +15,20 @@ import Test.Hspec spec :: Spec spec = do describe "Application version" $ do - -- TODO: More checks. This one is trivial and unnecessary, just for testing tests. it "should have dots" $ do neuronVersion `shouldSatisfy` T.isInfixOf "." it "should contain the git rev" $ do pending + -- TODO: Check minVersion in Default.dhall is same as the one in Paths_neuron describe "Version comparison" $ do it "must compare simple versions" $ do - "0.2" `shouldSatisfy` olderThan - "0.1" `shouldNotSatisfy` olderThan -- This is current version - "0.0" `shouldNotSatisfy` olderThan + "0.3" `shouldSatisfy` olderThan + "0.2" `shouldNotSatisfy` olderThan -- This is current version + "0.1" `shouldNotSatisfy` olderThan it "must compare full versions" $ do - "0.2.1.2" `shouldSatisfy` olderThan - "0.2.3" `shouldSatisfy` olderThan - "0.1.0.0" `shouldNotSatisfy` olderThan -- This is current version - "0.0.1.0" `shouldNotSatisfy` olderThan + "0.3.1.2" `shouldSatisfy` olderThan + "0.3.3" `shouldSatisfy` olderThan + "0.2.0.0" `shouldNotSatisfy` olderThan -- This is current version + "0.1.1.0" `shouldNotSatisfy` olderThan it "must compare within same major version" $ do - "0.1.0.2" `shouldSatisfy` olderThan -- 0.1.0.0 is the current version + "0.2.0.2" `shouldSatisfy` olderThan -- This is current version