{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveFoldable #-}
{-# LANGUAGE DeriveFunctor #-}
{-# LANGUAGE DeriveTraversable #-}
{-# LANGUAGE ExistentialQuantification #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TupleSections #-}
{-# OPTIONS_GHC -fno-warn-orphans #-}
{-# OPTIONS_HADDOCK show-extensions #-}
module Yi.Buffer.Misc
( FBuffer (FBuffer, bmode)
, BufferM (..)
, WinMarks, MarkSet (..)
, bkey
, getMarks
, runBuffer
, runBufferFull
, runBufferDummyWindow
, screenTopLn
, screenMidLn
, screenBotLn
, curLn
, curCol
, colOf
, lineOf
, lineCountB
, sizeB
, pointB
, pointOfLineColB
, solPointB
, eolPointB
, markLines
, moveTo
, moveToColB
, moveToLineColB
, lineMoveRel
, lineUp
, lineDown
, newB
, MarkValue (..)
, Overlay
(overlayAnnotation, overlayBegin, overlayEnd, overlayOwner, overlayStyle)
, mkOverlay
, gotoLn
, gotoLnFrom
, leftB
, rightB
, moveN
, leftN
, rightN
, insertN
, insertNAt
, insertB
, deleteN
, nelemsB
, writeB
, writeN
, newlineB
, deleteNAt
, readB
, elemsB
, undosA
, undoB
, redoB
, getMarkB
, setMarkHereB
, setNamedMarkHereB
, mayGetMarkB
, getMarkValueB
, markPointA
, modifyMarkB
, newMarkB
, deleteMarkB
, getVisibleSelection
, setVisibleSelection
, isUnchangedBuffer
, setAnyMode
, setMode
, setMode0
, modifyMode
, regexRegionB
, regexB
, readAtB
, getModeLine
, getPercent
, setInserting
, savingPrefCol
, forgetPreferCol
, movingToPrefCol
, movingToPrefVisCol
, preferColA
, markSavedB
, retroactivelyAtSavePointB
, addOverlayB
, delOverlayB
, delOverlaysOfOwnerB
, getOverlaysOfOwnerB
, isPointInsideOverlay
, savingExcursionB
, savingPointB
, savingPositionB
, pendingUpdatesA
, highlightSelectionA
, rectangleSelectionA
, readOnlyA
, insertingA
, pointFollowsWindowA
, revertPendingUpdatesB
, askWindow
, clearSyntax
, focusSyntax
, Mode (..)
, modeNameA
, modeAppliesA
, modeHLA
, modePrettifyA
, modeKeymapA
, modeIndentA
, modeFollowA
, modeIndentSettingsA
, modeToggleCommentSelectionA
, modeGetStrokesA
, modeOnLoadA
, modeGotoDeclarationA
, modeModeLineA
, AnyMode (..)
, IndentBehaviour (..)
, IndentSettings (..)
, expandTabsA
, tabSizeA
, shiftWidthA
, modeAlwaysApplies
, modeNeverApplies
, emptyMode
, withModeB
, withMode0
, onMode
, withSyntaxB
, withSyntaxB'
, keymapProcessA
, strokesRangesB
, streamB
, indexedStreamB
, askMarks
, pointAt
, SearchExp
, lastActiveWindowA
, putBufferDyn
, getBufferDyn
, shortIdentString
, identString
, miniIdentString
, identA
, directoryContentA
, BufferId (..)
, file
, lastSyncTimeA
, replaceCharB
, replaceCharWithBelowB
, replaceCharWithAboveB
, insertCharWithBelowB
, insertCharWithAboveB
, pointAfterCursorB
, destinationOfMoveB
, withEveryLineB
, startUpdateTransactionB
, commitUpdateTransactionB
, applyUpdate
, betweenB
, decreaseFontSize
, increaseFontSize
, indentSettingsB
, fontsizeVariationA
, stickyEolA
, queryBuffer
) where
import Prelude hiding (foldr, mapM, notElem)
import Control.Applicative (liftA2)
import Control.Monad (when, void, replicateM_, join)
import Data.Monoid
import Control.Monad.Reader
import Control.Monad.State.Strict hiding (get, put)
import Data.Binary (Binary (..), Get)
import Data.Char (ord)
import Data.Default (Default (def))
import Data.DynamicState.Serializable (getDyn, putDyn)
import Data.Foldable (Foldable (foldr), forM_, notElem)
import qualified Data.Map.Strict as M (Map, empty, insert, lookup)
import Data.Maybe (fromMaybe, isNothing)
import qualified Data.Sequence as S
import qualified Data.Set as Set (Set)
import qualified Data.Text as T (Text, concat, justifyRight, pack, snoc, unpack)
import qualified Data.Text.Encoding as E (decodeUtf8, encodeUtf8)
import Data.Time (UTCTime (UTCTime))
import Data.Traversable (Traversable (mapM), forM)
import Lens.Micro.Platform (Lens', lens, (&), (.~), (%~), (^.), use, (.=), (%=), view)
import Numeric (showHex)
import System.FilePath (joinPath, splitPath)
import Yi.Buffer.Basic (BufferRef, Point (..), Size (Size), WindowRef)
import Yi.Buffer.Implementation
import Yi.Buffer.Undo
import Yi.Interact as I (P (End))
import Yi.Monad (getsAndModify, uses)
import Yi.Region (Region, mkRegion)
import Yi.Rope (YiString)
import qualified Yi.Rope as R
import Yi.Syntax (ExtHL (ExtHL), Stroke, noHighlighter)
import Yi.Types
import Yi.Utils (SemiNum ((+~)), makeClassyWithSuffix, makeLensesWithSuffix)
import Yi.Window (Window (width, wkey, actualLines), dummyWindow)
makeClassyWithSuffix "A" ''Attributes
instance HasAttributes FBuffer where
attributesA :: Lens' FBuffer Attributes
attributesA = (FBuffer -> Attributes)
-> (FBuffer -> Attributes -> FBuffer) -> Lens' FBuffer Attributes
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens FBuffer -> Attributes
attributes (\(FBuffer Mode syntax
f1 BufferImpl syntax
f2 Attributes
_) Attributes
a -> Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
forall syntax.
Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
FBuffer Mode syntax
f1 BufferImpl syntax
f2 Attributes
a)
shortIdentString :: Int
-> FBuffer
-> T.Text
shortIdentString :: Int -> FBuffer -> Text
shortIdentString Int
dl FBuffer
b = case FBuffer
b FBuffer -> Getting BufferId FBuffer BufferId -> BufferId
forall s a. s -> Getting a s a -> a
^. Getting BufferId FBuffer BufferId
forall c. HasAttributes c => Lens' c BufferId
Lens' FBuffer BufferId
identA of
MemBuffer Text
bName -> Text
"*" Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
bName Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
"*"
FileBuffer String
fName -> String -> Text
T.pack (String -> Text) -> ([String] -> String) -> [String] -> Text
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [String] -> String
joinPath ([String] -> String)
-> ([String] -> [String]) -> [String] -> String
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> [String] -> [String]
forall a. Int -> [a] -> [a]
drop Int
dl ([String] -> Text) -> [String] -> Text
forall a b. (a -> b) -> a -> b
$ String -> [String]
splitPath String
fName
identString :: FBuffer -> T.Text
identString :: FBuffer -> Text
identString FBuffer
b = case FBuffer
b FBuffer -> Getting BufferId FBuffer BufferId -> BufferId
forall s a. s -> Getting a s a -> a
^. Getting BufferId FBuffer BufferId
forall c. HasAttributes c => Lens' c BufferId
Lens' FBuffer BufferId
identA of
MemBuffer Text
bName -> Text
"*" Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
bName Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
"*"
FileBuffer String
fName -> String -> Text
T.pack String
fName
instance Show FBuffer where
show :: FBuffer -> String
show FBuffer
b = [String] -> String
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
Prelude.concat [ String
"Buffer #", BufferRef -> String
forall a. Show a => a -> String
show (FBuffer -> BufferRef
bkey FBuffer
b)
, String
" (", Text -> String
T.unpack (FBuffer -> Text
identString FBuffer
b), String
")" ]
miniIdentString :: FBuffer -> T.Text
miniIdentString :: FBuffer -> Text
miniIdentString FBuffer
b = case FBuffer
b FBuffer -> Getting BufferId FBuffer BufferId -> BufferId
forall s a. s -> Getting a s a -> a
^. Getting BufferId FBuffer BufferId
forall c. HasAttributes c => Lens' c BufferId
Lens' FBuffer BufferId
identA of
MemBuffer Text
bufName -> Text
bufName
FileBuffer String
_ -> Text
"MINIFILE:"
instance Binary FBuffer where
put :: FBuffer -> Put
put (FBuffer Mode syntax
binmode BufferImpl syntax
r Attributes
attributes_) =
let strippedRaw :: BufferImpl ()
strippedRaw :: BufferImpl ()
strippedRaw = ExtHL () -> BufferImpl syntax -> BufferImpl ()
forall syntax oldSyntax.
ExtHL syntax -> BufferImpl oldSyntax -> BufferImpl syntax
setSyntaxBI (Mode () -> ExtHL ()
forall syntax. Mode syntax -> ExtHL syntax
modeHL Mode ()
forall syntax. Mode syntax
emptyMode) BufferImpl syntax
r
in do
Mode syntax -> Put
forall t. Binary t => t -> Put
put Mode syntax
binmode
BufferImpl () -> Put
forall t. Binary t => t -> Put
put BufferImpl ()
strippedRaw
Attributes -> Put
forall t. Binary t => t -> Put
put Attributes
attributes_
get :: Get FBuffer
get =
Mode () -> BufferImpl () -> Attributes -> FBuffer
forall syntax.
Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
FBuffer (Mode () -> BufferImpl () -> Attributes -> FBuffer)
-> Get (Mode ()) -> Get (BufferImpl () -> Attributes -> FBuffer)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Get (Mode ())
forall t. Binary t => Get t
get Get (BufferImpl () -> Attributes -> FBuffer)
-> Get (BufferImpl ()) -> Get (Attributes -> FBuffer)
forall a b. Get (a -> b) -> Get a -> Get b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Get (BufferImpl ())
getStripped Get (Attributes -> FBuffer) -> Get Attributes -> Get FBuffer
forall a b. Get (a -> b) -> Get a -> Get b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Get Attributes
forall t. Binary t => Get t
get
where getStripped :: Get (BufferImpl ())
getStripped :: Get (BufferImpl ())
getStripped = Get (BufferImpl ())
forall t. Binary t => Get t
get
clearSyntax :: FBuffer -> FBuffer
clearSyntax :: FBuffer -> FBuffer
clearSyntax = (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer -> FBuffer
modifyRawbuf BufferImpl syntax -> BufferImpl syntax
forall syntax. BufferImpl syntax -> BufferImpl syntax
updateSyntax
queryRawbuf :: (forall syntax. BufferImpl syntax -> x) -> FBuffer -> x
queryRawbuf :: forall x. (forall syntax. BufferImpl syntax -> x) -> FBuffer -> x
queryRawbuf forall syntax. BufferImpl syntax -> x
f (FBuffer Mode syntax
_ BufferImpl syntax
fb Attributes
_) = BufferImpl syntax -> x
forall syntax. BufferImpl syntax -> x
f BufferImpl syntax
fb
modifyRawbuf :: (forall syntax. BufferImpl syntax -> BufferImpl syntax) -> FBuffer -> FBuffer
modifyRawbuf :: (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer -> FBuffer
modifyRawbuf forall syntax. BufferImpl syntax -> BufferImpl syntax
f (FBuffer Mode syntax
f1 BufferImpl syntax
f2 Attributes
f3) = Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
forall syntax.
Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
FBuffer Mode syntax
f1 (BufferImpl syntax -> BufferImpl syntax
forall syntax. BufferImpl syntax -> BufferImpl syntax
f BufferImpl syntax
f2) Attributes
f3
queryAndModifyRawbuf :: (forall syntax. BufferImpl syntax -> (BufferImpl syntax,x)) ->
FBuffer -> (FBuffer, x)
queryAndModifyRawbuf :: forall x.
(forall syntax. BufferImpl syntax -> (BufferImpl syntax, x))
-> FBuffer -> (FBuffer, x)
queryAndModifyRawbuf forall syntax. BufferImpl syntax -> (BufferImpl syntax, x)
f (FBuffer Mode syntax
f1 BufferImpl syntax
f5 Attributes
f3) =
let (BufferImpl syntax
f5', x
x) = BufferImpl syntax -> (BufferImpl syntax, x)
forall syntax. BufferImpl syntax -> (BufferImpl syntax, x)
f BufferImpl syntax
f5
in (Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
forall syntax.
Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
FBuffer Mode syntax
f1 BufferImpl syntax
f5' Attributes
f3, x
x)
file :: FBuffer -> Maybe FilePath
file :: FBuffer -> Maybe String
file FBuffer
b = case FBuffer
b FBuffer -> Getting BufferId FBuffer BufferId -> BufferId
forall s a. s -> Getting a s a -> a
^. Getting BufferId FBuffer BufferId
forall c. HasAttributes c => Lens' c BufferId
Lens' FBuffer BufferId
identA of
FileBuffer String
f -> String -> Maybe String
forall a. a -> Maybe a
Just String
f
MemBuffer Text
_ -> Maybe String
forall a. Maybe a
Nothing
highlightSelectionA :: Lens' FBuffer Bool
highlightSelectionA :: Lens' FBuffer Bool
highlightSelectionA = (SelectionStyle -> f SelectionStyle) -> FBuffer -> f FBuffer
forall c. HasAttributes c => Lens' c SelectionStyle
Lens' FBuffer SelectionStyle
selectionStyleA ((SelectionStyle -> f SelectionStyle) -> FBuffer -> f FBuffer)
-> ((Bool -> f Bool) -> SelectionStyle -> f SelectionStyle)
-> (Bool -> f Bool)
-> FBuffer
-> f FBuffer
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
(SelectionStyle -> Bool)
-> (SelectionStyle -> Bool -> SelectionStyle)
-> Lens SelectionStyle SelectionStyle Bool Bool
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens SelectionStyle -> Bool
highlightSelection (\SelectionStyle
e Bool
x -> SelectionStyle
e { highlightSelection = x })
rectangleSelectionA :: Lens' FBuffer Bool
rectangleSelectionA :: Lens' FBuffer Bool
rectangleSelectionA = (SelectionStyle -> f SelectionStyle) -> FBuffer -> f FBuffer
forall c. HasAttributes c => Lens' c SelectionStyle
Lens' FBuffer SelectionStyle
selectionStyleA ((SelectionStyle -> f SelectionStyle) -> FBuffer -> f FBuffer)
-> ((Bool -> f Bool) -> SelectionStyle -> f SelectionStyle)
-> (Bool -> f Bool)
-> FBuffer
-> f FBuffer
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
(SelectionStyle -> Bool)
-> (SelectionStyle -> Bool -> SelectionStyle)
-> Lens SelectionStyle SelectionStyle Bool Bool
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens SelectionStyle -> Bool
rectangleSelection (\SelectionStyle
e Bool
x -> SelectionStyle
e { rectangleSelection = x })
instance Binary (Mode syntax) where
put :: Mode syntax -> Put
put = ByteString -> Put
forall t. Binary t => t -> Put
put (ByteString -> Put)
-> (Mode syntax -> ByteString) -> Mode syntax -> Put
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Text -> ByteString
E.encodeUtf8 (Text -> ByteString)
-> (Mode syntax -> Text) -> Mode syntax -> ByteString
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Mode syntax -> Text
forall syntax. Mode syntax -> Text
modeName
get :: Get (Mode syntax)
get = do
n <- ByteString -> Text
E.decodeUtf8 (ByteString -> Text) -> Get ByteString -> Get Text
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Get ByteString
forall t. Binary t => Get t
get
return (emptyMode {modeName = n})
increaseFontSize :: Int -> BufferM ()
increaseFontSize :: Int -> BufferM ()
increaseFontSize Int
x = (Int -> Identity Int) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c Int
Lens' FBuffer Int
fontsizeVariationA ((Int -> Identity Int) -> FBuffer -> Identity FBuffer)
-> (Int -> Int) -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> (a -> b) -> m ()
%= \Int
fs -> Int -> Int -> Int
forall a. Ord a => a -> a -> a
max Int
1 (Int
fs Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
x)
decreaseFontSize :: Int -> BufferM ()
decreaseFontSize :: Int -> BufferM ()
decreaseFontSize Int
x = (Int -> Identity Int) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c Int
Lens' FBuffer Int
fontsizeVariationA ((Int -> Identity Int) -> FBuffer -> Identity FBuffer)
-> (Int -> Int) -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> (a -> b) -> m ()
%= \Int
fs -> Int -> Int -> Int
forall a. Ord a => a -> a -> a
max Int
1 (Int
fs Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
x)
getModeLine :: [T.Text] -> BufferM T.Text
getModeLine :: [Text] -> BufferM Text
getModeLine [Text]
prefix = (forall syntax. Mode syntax -> BufferM Text) -> BufferM Text
forall a. (forall syntax. Mode syntax -> BufferM a) -> BufferM a
withModeB (Mode syntax -> [Text] -> BufferM Text
forall syntax. Mode syntax -> [Text] -> BufferM Text
`modeModeLine` [Text]
prefix)
defaultModeLine :: [T.Text] -> BufferM T.Text
defaultModeLine :: [Text] -> BufferM Text
defaultModeLine [Text]
prefix = do
col <- BufferM Int
curCol
pos <- pointB
ln <- curLn
p <- pointB
s <- sizeB
curChar <- readB
ro <-use readOnlyA
modeNm <- gets (withMode0 modeName)
unchanged <- gets isUnchangedBuffer
let pct
| Point
pos Point -> Point -> Bool
forall a. Eq a => a -> a -> Bool
== Point
0 Bool -> Bool -> Bool
|| Point
s Point -> Point -> Bool
forall a. Eq a => a -> a -> Bool
== Point
0 = Text
" Top"
| Point
pos Point -> Point -> Bool
forall a. Eq a => a -> a -> Bool
== Point
s = Text
" Bot"
| Bool
otherwise = Point -> Point -> Text
getPercent Point
p Point
s
changed = if Bool
unchanged then Text
"-" else Text
"*"
readOnly' = if Bool
ro then Text
"%" else Text
changed
hexxed = String -> Text
T.pack (String -> Text) -> String -> Text
forall a b. (a -> b) -> a -> b
$ Int -> ShowS
forall a. Integral a => a -> ShowS
showHex (Char -> Int
ord Char
curChar) String
""
hexChar = Text
"0x" Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Int -> Char -> Text -> Text
T.justifyRight Int
2 Char
'0' Text
hexxed
toT = String -> Text
T.pack (String -> Text) -> (Int -> String) -> Int -> Text
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> String
forall a. Show a => a -> String
show
nm <- gets $ shortIdentString (length prefix)
return $ T.concat [ readOnly', changed, " ", nm
, " ", hexChar, " "
, "L", T.justifyRight 5 ' ' (toT ln)
, " "
, "C", T.justifyRight 3 ' ' (toT col)
, " ", pct , " ", modeNm , " ", toT $ fromPoint p
]
getPercent :: Point -> Point -> T.Text
getPercent :: Point -> Point -> Text
getPercent Point
a Point
b = Int -> Char -> Text -> Text
T.justifyRight Int
3 Char
' ' (String -> Text
T.pack (String -> Text) -> String -> Text
forall a b. (a -> b) -> a -> b
$ Int -> String
forall a. Show a => a -> String
show Int
p) Text -> Char -> Text
`T.snoc` Char
'%'
where p :: Int
p = Double -> Int
forall b. Integral b => Double -> b
forall a b. (RealFrac a, Integral b) => a -> b
ceiling (Double
aa Double -> Double -> Double
forall a. Fractional a => a -> a -> a
/ Double
bb Double -> Double -> Double
forall a. Num a => a -> a -> a
* Double
100.0 :: Double) :: Int
aa :: Double
aa = Point -> Double
forall a b. (Integral a, Num b) => a -> b
fromIntegral Point
a :: Double
bb :: Double
bb = Point -> Double
forall a b. (Integral a, Num b) => a -> b
fromIntegral Point
b :: Double
queryBuffer :: (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer :: forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer forall syntax. BufferImpl syntax -> x
x = (FBuffer -> x) -> BufferM x
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets ((forall syntax. BufferImpl syntax -> x) -> FBuffer -> x
forall x. (forall syntax. BufferImpl syntax -> x) -> FBuffer -> x
queryRawbuf BufferImpl syntax -> x
forall syntax. BufferImpl syntax -> x
x)
modifyBuffer :: (forall syntax. BufferImpl syntax -> BufferImpl syntax) -> BufferM ()
modifyBuffer :: (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
modifyBuffer forall syntax. BufferImpl syntax -> BufferImpl syntax
x = (FBuffer -> FBuffer) -> BufferM ()
forall s (m :: * -> *). MonadState s m => (s -> s) -> m ()
modify' ((forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer -> FBuffer
modifyRawbuf BufferImpl syntax -> BufferImpl syntax
forall syntax. BufferImpl syntax -> BufferImpl syntax
x)
queryAndModify :: (forall syntax. BufferImpl syntax -> (BufferImpl syntax,x)) -> BufferM x
queryAndModify :: forall x.
(forall syntax. BufferImpl syntax -> (BufferImpl syntax, x))
-> BufferM x
queryAndModify forall syntax. BufferImpl syntax -> (BufferImpl syntax, x)
x = (FBuffer -> (FBuffer, x)) -> BufferM x
forall s (m :: * -> *) a. MonadState s m => (s -> (s, a)) -> m a
getsAndModify ((forall syntax. BufferImpl syntax -> (BufferImpl syntax, x))
-> FBuffer -> (FBuffer, x)
forall x.
(forall syntax. BufferImpl syntax -> (BufferImpl syntax, x))
-> FBuffer -> (FBuffer, x)
queryAndModifyRawbuf BufferImpl syntax -> (BufferImpl syntax, x)
forall syntax. BufferImpl syntax -> (BufferImpl syntax, x)
x)
addOverlayB :: Overlay -> BufferM ()
addOverlayB :: Overlay -> BufferM ()
addOverlayB Overlay
ov = do
(Seq UIUpdate -> Identity (Seq UIUpdate))
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c (Seq UIUpdate)
Lens' FBuffer (Seq UIUpdate)
pendingUpdatesA ((Seq UIUpdate -> Identity (Seq UIUpdate))
-> FBuffer -> Identity FBuffer)
-> (Seq UIUpdate -> Seq UIUpdate) -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> (a -> b) -> m ()
%= (Seq UIUpdate -> UIUpdate -> Seq UIUpdate
forall a. Seq a -> a -> Seq a
S.|> Overlay -> UIUpdate
overlayUpdate Overlay
ov)
(forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
modifyBuffer ((forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ())
-> (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
forall a b. (a -> b) -> a -> b
$ Overlay -> BufferImpl syntax -> BufferImpl syntax
forall syntax. Overlay -> BufferImpl syntax -> BufferImpl syntax
addOverlayBI Overlay
ov
getOverlaysOfOwnerB :: R.YiString -> BufferM (Set.Set Overlay)
getOverlaysOfOwnerB :: YiString -> BufferM (Set Overlay)
getOverlaysOfOwnerB YiString
owner = (forall syntax. BufferImpl syntax -> Set Overlay)
-> BufferM (Set Overlay)
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer (YiString -> BufferImpl syntax -> Set Overlay
forall syntax. YiString -> BufferImpl syntax -> Set Overlay
getOverlaysOfOwnerBI YiString
owner)
delOverlayB :: Overlay -> BufferM ()
delOverlayB :: Overlay -> BufferM ()
delOverlayB Overlay
ov = do
(Seq UIUpdate -> Identity (Seq UIUpdate))
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c (Seq UIUpdate)
Lens' FBuffer (Seq UIUpdate)
pendingUpdatesA ((Seq UIUpdate -> Identity (Seq UIUpdate))
-> FBuffer -> Identity FBuffer)
-> (Seq UIUpdate -> Seq UIUpdate) -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> (a -> b) -> m ()
%= (Seq UIUpdate -> UIUpdate -> Seq UIUpdate
forall a. Seq a -> a -> Seq a
S.|> Overlay -> UIUpdate
overlayUpdate Overlay
ov)
(forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
modifyBuffer ((forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ())
-> (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
forall a b. (a -> b) -> a -> b
$ Overlay -> BufferImpl syntax -> BufferImpl syntax
forall syntax. Overlay -> BufferImpl syntax -> BufferImpl syntax
delOverlayBI Overlay
ov
delOverlaysOfOwnerB :: R.YiString -> BufferM ()
delOverlaysOfOwnerB :: YiString -> BufferM ()
delOverlaysOfOwnerB YiString
owner =
(forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
modifyBuffer ((forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ())
-> (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
forall a b. (a -> b) -> a -> b
$ YiString -> BufferImpl syntax -> BufferImpl syntax
forall syntax. YiString -> BufferImpl syntax -> BufferImpl syntax
delOverlaysOfOwnerBI YiString
owner
isPointInsideOverlay :: Point -> Overlay -> Bool
isPointInsideOverlay :: Point -> Overlay -> Bool
isPointInsideOverlay Point
point Overlay
overlay =
let Overlay YiString
_ (MarkValue Point
start Direction
_) (MarkValue Point
finish Direction
_) StyleName
_ YiString
_ = Overlay
overlay
in Point
start Point -> Point -> Bool
forall a. Ord a => a -> a -> Bool
<= Point
point Bool -> Bool -> Bool
&& Point
point Point -> Point -> Bool
forall a. Ord a => a -> a -> Bool
<= Point
finish
runBuffer :: Window -> FBuffer -> BufferM a -> (a, FBuffer)
runBuffer :: forall a. Window -> FBuffer -> BufferM a -> (a, FBuffer)
runBuffer Window
w FBuffer
b BufferM a
f =
let (a
a, Seq Update
_, FBuffer
b') = Window -> FBuffer -> BufferM a -> (a, Seq Update, FBuffer)
forall a.
Window -> FBuffer -> BufferM a -> (a, Seq Update, FBuffer)
runBufferFull Window
w FBuffer
b BufferM a
f
in (a
a, FBuffer
b')
getMarks :: Window -> BufferM (Maybe WinMarks)
getMarks :: Window -> BufferM (Maybe WinMarks)
getMarks = (FBuffer -> Maybe WinMarks) -> BufferM (Maybe WinMarks)
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets ((FBuffer -> Maybe WinMarks) -> BufferM (Maybe WinMarks))
-> (Window -> FBuffer -> Maybe WinMarks)
-> Window
-> BufferM (Maybe WinMarks)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Window -> FBuffer -> Maybe WinMarks
getMarksRaw
getMarksRaw :: Window -> FBuffer -> Maybe WinMarks
getMarksRaw :: Window -> FBuffer -> Maybe WinMarks
getMarksRaw Window
w FBuffer
b = WindowRef -> Map WindowRef WinMarks -> Maybe WinMarks
forall k a. Ord k => k -> Map k a -> Maybe a
M.lookup (Window -> WindowRef
wkey Window
w) (FBuffer
b FBuffer
-> Getting
(Map WindowRef WinMarks) FBuffer (Map WindowRef WinMarks)
-> Map WindowRef WinMarks
forall s a. s -> Getting a s a -> a
^. Getting (Map WindowRef WinMarks) FBuffer (Map WindowRef WinMarks)
forall c. HasAttributes c => Lens' c (Map WindowRef WinMarks)
Lens' FBuffer (Map WindowRef WinMarks)
winMarksA)
runBufferFull :: Window -> FBuffer -> BufferM a -> (a, S.Seq Update, FBuffer)
runBufferFull :: forall a.
Window -> FBuffer -> BufferM a -> (a, Seq Update, FBuffer)
runBufferFull Window
w FBuffer
b BufferM a
f =
let (a
a, FBuffer
b') = State FBuffer a -> FBuffer -> (a, FBuffer)
forall s a. State s a -> s -> (a, s)
runState (ReaderT Window (StateT FBuffer Identity) a
-> Window -> State FBuffer a
forall r (m :: * -> *) a. ReaderT r m a -> r -> m a
runReaderT (BufferM a -> ReaderT Window (StateT FBuffer Identity) a
forall a. BufferM a -> ReaderT Window (StateT FBuffer Identity) a
fromBufferM BufferM a
f') Window
w) FBuffer
b
updates :: Seq Update
updates = FBuffer
b' FBuffer -> Getting (Seq Update) FBuffer (Seq Update) -> Seq Update
forall s a. s -> Getting a s a -> a
^. Getting (Seq Update) FBuffer (Seq Update)
forall c. HasAttributes c => Lens' c (Seq Update)
Lens' FBuffer (Seq Update)
updateStreamA
!newSt :: FBuffer
newSt = FBuffer
b' FBuffer -> (FBuffer -> FBuffer) -> FBuffer
forall a b. a -> (a -> b) -> b
& (Seq Update -> Identity (Seq Update))
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c (Seq Update)
Lens' FBuffer (Seq Update)
updateStreamA ((Seq Update -> Identity (Seq Update))
-> FBuffer -> Identity FBuffer)
-> Seq Update -> FBuffer -> FBuffer
forall s t a b. ASetter s t a b -> b -> s -> t
.~ Seq Update
forall a. Monoid a => a
mempty
f' :: BufferM a
f' = do
ms <- Window -> BufferM (Maybe WinMarks)
getMarks Window
w
when (isNothing ms) $ do
newMarkValues <- if wkey (b ^. lastActiveWindowA) == def
then return
MarkSet { insMark = MarkValue 0 Forward,
selMark = MarkValue 0 Backward,
fromMark = MarkValue 0 Backward }
else do
Just mrks <- uses winMarksA (M.lookup $ wkey (b ^. lastActiveWindowA))
forM mrks getMarkValueB
newMrks <- forM newMarkValues newMarkB
winMarksA %= M.insert (wkey w) newMrks
lastActiveWindowA .= w
f
in (a
a, Seq Update
updates, (Seq UIUpdate -> Identity (Seq UIUpdate))
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c (Seq UIUpdate)
Lens' FBuffer (Seq UIUpdate)
pendingUpdatesA ((Seq UIUpdate -> Identity (Seq UIUpdate))
-> FBuffer -> Identity FBuffer)
-> (Seq UIUpdate -> Seq UIUpdate) -> FBuffer -> FBuffer
forall s t a b. ASetter s t a b -> (a -> b) -> s -> t
%~ (Seq UIUpdate -> Seq UIUpdate -> Seq UIUpdate
forall a. Seq a -> Seq a -> Seq a
S.>< (Update -> UIUpdate) -> Seq Update -> Seq UIUpdate
forall a b. (a -> b) -> Seq a -> Seq b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap Update -> UIUpdate
TextUpdate Seq Update
updates) (FBuffer -> FBuffer) -> FBuffer -> FBuffer
forall a b. (a -> b) -> a -> b
$ FBuffer
newSt)
getMarkValueRaw :: Mark -> FBuffer -> MarkValue
getMarkValueRaw :: Mark -> FBuffer -> MarkValue
getMarkValueRaw Mark
m = MarkValue -> Maybe MarkValue -> MarkValue
forall a. a -> Maybe a -> a
fromMaybe (Point -> Direction -> MarkValue
MarkValue Point
0 Direction
Forward) (Maybe MarkValue -> MarkValue)
-> (FBuffer -> Maybe MarkValue) -> FBuffer -> MarkValue
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall syntax. BufferImpl syntax -> Maybe MarkValue)
-> FBuffer -> Maybe MarkValue
forall x. (forall syntax. BufferImpl syntax -> x) -> FBuffer -> x
queryRawbuf (Mark -> BufferImpl syntax -> Maybe MarkValue
forall syntax. Mark -> BufferImpl syntax -> Maybe MarkValue
getMarkValueBI Mark
m)
getMarkValueB :: Mark -> BufferM MarkValue
getMarkValueB :: Mark -> BufferM MarkValue
getMarkValueB = (FBuffer -> MarkValue) -> BufferM MarkValue
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets ((FBuffer -> MarkValue) -> BufferM MarkValue)
-> (Mark -> FBuffer -> MarkValue) -> Mark -> BufferM MarkValue
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Mark -> FBuffer -> MarkValue
getMarkValueRaw
newMarkB :: MarkValue -> BufferM Mark
newMarkB :: MarkValue -> BufferM Mark
newMarkB MarkValue
v = (forall syntax. BufferImpl syntax -> (BufferImpl syntax, Mark))
-> BufferM Mark
forall x.
(forall syntax. BufferImpl syntax -> (BufferImpl syntax, x))
-> BufferM x
queryAndModify ((forall syntax. BufferImpl syntax -> (BufferImpl syntax, Mark))
-> BufferM Mark)
-> (forall syntax. BufferImpl syntax -> (BufferImpl syntax, Mark))
-> BufferM Mark
forall a b. (a -> b) -> a -> b
$ MarkValue -> BufferImpl syntax -> (BufferImpl syntax, Mark)
forall syntax.
MarkValue -> BufferImpl syntax -> (BufferImpl syntax, Mark)
newMarkBI MarkValue
v
deleteMarkB :: Mark -> BufferM ()
deleteMarkB :: Mark -> BufferM ()
deleteMarkB Mark
m = (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
modifyBuffer ((forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ())
-> (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> BufferM ()
forall a b. (a -> b) -> a -> b
$ Mark -> BufferImpl syntax -> BufferImpl syntax
forall syntax. Mark -> BufferImpl syntax -> BufferImpl syntax
deleteMarkValueBI Mark
m
runBufferDummyWindow :: FBuffer -> BufferM a -> a
runBufferDummyWindow :: forall a. FBuffer -> BufferM a -> a
runBufferDummyWindow FBuffer
b = (a, FBuffer) -> a
forall a b. (a, b) -> a
fst ((a, FBuffer) -> a)
-> (BufferM a -> (a, FBuffer)) -> BufferM a -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Window -> FBuffer -> BufferM a -> (a, FBuffer)
forall a. Window -> FBuffer -> BufferM a -> (a, FBuffer)
runBuffer (BufferRef -> Window
dummyWindow (BufferRef -> Window) -> BufferRef -> Window
forall a b. (a -> b) -> a -> b
$ FBuffer -> BufferRef
bkey FBuffer
b) FBuffer
b
markSavedB :: UTCTime -> BufferM ()
markSavedB :: UTCTime -> BufferM ()
markSavedB UTCTime
t = do
(URList -> Identity URList) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c URList
Lens' FBuffer URList
undosA ((URList -> Identity URList) -> FBuffer -> Identity FBuffer)
-> (URList -> URList) -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> (a -> b) -> m ()
%= URList -> URList
setSavedFilePointU
(UTCTime -> Identity UTCTime) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c UTCTime
Lens' FBuffer UTCTime
lastSyncTimeA ((UTCTime -> Identity UTCTime) -> FBuffer -> Identity FBuffer)
-> UTCTime -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.= UTCTime
t
bkey :: FBuffer -> BufferRef
bkey :: FBuffer -> BufferRef
bkey = Getting BufferRef FBuffer BufferRef -> FBuffer -> BufferRef
forall s (m :: * -> *) a. MonadReader s m => Getting a s a -> m a
view Getting BufferRef FBuffer BufferRef
forall c. HasAttributes c => Lens' c BufferRef
Lens' FBuffer BufferRef
bkey__A
isUnchangedBuffer :: FBuffer -> Bool
isUnchangedBuffer :: FBuffer -> Bool
isUnchangedBuffer = URList -> Bool
isAtSavedFilePointU (URList -> Bool) -> (FBuffer -> URList) -> FBuffer -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Getting URList FBuffer URList -> FBuffer -> URList
forall s (m :: * -> *) a. MonadReader s m => Getting a s a -> m a
view Getting URList FBuffer URList
forall c. HasAttributes c => Lens' c URList
Lens' FBuffer URList
undosA
startUpdateTransactionB :: BufferM ()
startUpdateTransactionB :: BufferM ()
startUpdateTransactionB = do
transactionPresent <- Getting Bool FBuffer Bool -> BufferM Bool
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting Bool FBuffer Bool
forall c. HasAttributes c => Lens' c Bool
Lens' FBuffer Bool
updateTransactionInFlightA
when (not transactionPresent) $ do
undosA %= addChangeU InteractivePoint
updateTransactionInFlightA .= True
commitUpdateTransactionB :: BufferM ()
commitUpdateTransactionB :: BufferM ()
commitUpdateTransactionB = do
transactionPresent <- Getting Bool FBuffer Bool -> BufferM Bool
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting Bool FBuffer Bool
forall c. HasAttributes c => Lens' c Bool
Lens' FBuffer Bool
updateTransactionInFlightA
if not transactionPresent
then error "Not in update transaction"
else do
updateTransactionInFlightA .= False
transacAccum <- use updateTransactionAccumA
updateTransactionAccumA .= mempty
undosA %= (appEndo . foldr (<>) mempty) (Endo . addChangeU . AtomicChange <$> transacAccum)
undosA %= addChangeU InteractivePoint
undoRedo :: (forall syntax. Mark -> URList -> BufferImpl syntax
-> (BufferImpl syntax, (URList, S.Seq Update)))
-> BufferM ()
undoRedo :: (forall syntax.
Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update)))
-> BufferM ()
undoRedo forall syntax.
Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update))
f = do
isTransacPresent <- Getting Bool FBuffer Bool -> BufferM Bool
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting Bool FBuffer Bool
forall c. HasAttributes c => Lens' c Bool
Lens' FBuffer Bool
updateTransactionInFlightA
if isTransacPresent
then error "Can't undo while undo transaction is in progress"
else do
m <- getInsMark
ur <- use undosA
(ur', updates) <- queryAndModify (f m ur)
undosA .= ur'
updateStreamA %= (<> updates)
undoB :: BufferM ()
undoB :: BufferM ()
undoB = (forall syntax.
Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update)))
-> BufferM ()
undoRedo Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update))
forall syntax.
Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update))
undoU
redoB :: BufferM ()
redoB :: BufferM ()
redoB = (forall syntax.
Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update)))
-> BufferM ()
undoRedo Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update))
forall syntax.
Mark
-> URList
-> BufferImpl syntax
-> (BufferImpl syntax, (URList, Seq Update))
redoU
retroactivelyAtSavePointB :: BufferM a -> BufferM a
retroactivelyAtSavePointB :: forall a. BufferM a -> BufferM a
retroactivelyAtSavePointB BufferM a
action = do
(undoDepth, result) <- Int -> BufferM (Int, a)
forall {t}. Num t => t -> BufferM (t, a)
go Int
0
replicateM_ undoDepth redoB
return result
where
go :: t -> BufferM (t, a)
go t
step = do
atSavedPoint <- (FBuffer -> Bool) -> BufferM Bool
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets FBuffer -> Bool
isUnchangedBuffer
if atSavedPoint
then (step,) <$> action
else undoB >> go (step + 1)
const2 :: t -> t1 -> t2 -> t
const2 :: forall t t1 t2. t -> t1 -> t2 -> t
const2 t
x t1
_ t2
_ = t
x
modeAlwaysApplies :: a -> b -> Bool
modeAlwaysApplies :: forall a b. a -> b -> Bool
modeAlwaysApplies = Bool -> a -> b -> Bool
forall t t1 t2. t -> t1 -> t2 -> t
const2 Bool
True
modeNeverApplies :: a -> b -> Bool
modeNeverApplies :: forall a b. a -> b -> Bool
modeNeverApplies = Bool -> a -> b -> Bool
forall t t1 t2. t -> t1 -> t2 -> t
const2 Bool
False
emptyMode :: Mode syntax
emptyMode :: forall syntax. Mode syntax
emptyMode = Mode
{
modeName :: Text
modeName = Text
"empty",
modeApplies :: String -> YiString -> Bool
modeApplies = String -> YiString -> Bool
forall a b. a -> b -> Bool
modeNeverApplies,
modeHL :: ExtHL syntax
modeHL = Highlighter () syntax -> ExtHL syntax
forall syntax cache. Highlighter cache syntax -> ExtHL syntax
ExtHL Highlighter () syntax
forall syntax. Highlighter () syntax
noHighlighter,
modePrettify :: syntax -> BufferM ()
modePrettify = BufferM () -> syntax -> BufferM ()
forall a b. a -> b -> a
const (BufferM () -> syntax -> BufferM ())
-> BufferM () -> syntax -> BufferM ()
forall a b. (a -> b) -> a -> b
$ () -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (),
modeKeymap :: KeymapSet -> KeymapSet
modeKeymap = KeymapSet -> KeymapSet
forall a. a -> a
id,
modeIndent :: syntax -> IndentBehaviour -> BufferM ()
modeIndent = \syntax
_ IndentBehaviour
_ -> () -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (),
modeFollow :: syntax -> Action
modeFollow = Action -> syntax -> Action
forall a b. a -> b -> a
const Action
emptyAction,
modeIndentSettings :: IndentSettings
modeIndentSettings = IndentSettings
{ expandTabs :: Bool
expandTabs = Bool
True
, tabSize :: Int
tabSize = Int
8
, shiftWidth :: Int
shiftWidth = Int
4
},
modeToggleCommentSelection :: Maybe (BufferM ())
modeToggleCommentSelection = Maybe (BufferM ())
forall a. Maybe a
Nothing,
modeGetStrokes :: syntax -> Point -> Point -> Point -> [Stroke]
modeGetStrokes = \syntax
_ Point
_ Point
_ Point
_ -> [],
modeOnLoad :: BufferM ()
modeOnLoad = () -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (),
modeGotoDeclaration :: BufferM ()
modeGotoDeclaration = () -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (),
modeModeLine :: [Text] -> BufferM Text
modeModeLine = [Text] -> BufferM Text
defaultModeLine
}
newB :: BufferRef -> BufferId -> YiString -> FBuffer
newB :: BufferRef -> BufferId -> YiString -> FBuffer
newB BufferRef
unique BufferId
nm YiString
s =
FBuffer { bmode :: Mode ()
bmode = Mode ()
forall syntax. Mode syntax
emptyMode
, rawbuf :: BufferImpl ()
rawbuf = YiString -> BufferImpl ()
newBI YiString
s
, attributes :: Attributes
attributes =
Attributes { ident :: BufferId
ident = BufferId
nm
, bkey__ :: BufferRef
bkey__ = BufferRef
unique
, undos :: URList
undos = URList
emptyU
, preferCol :: Maybe Int
preferCol = Maybe Int
forall a. Maybe a
Nothing
, preferVisCol :: Maybe Int
preferVisCol = Maybe Int
forall a. Maybe a
Nothing
, stickyEol :: Bool
stickyEol = Bool
False
, bufferDynamic :: DynamicState
bufferDynamic = DynamicState
forall a. Monoid a => a
mempty
, pendingUpdates :: Seq UIUpdate
pendingUpdates = Seq UIUpdate
forall a. Monoid a => a
mempty
, selectionStyle :: SelectionStyle
selectionStyle = Bool -> Bool -> SelectionStyle
SelectionStyle Bool
False Bool
False
, keymapProcess :: KeymapProcess
keymapProcess = KeymapProcess
forall event w. P event w
I.End
, winMarks :: Map WindowRef WinMarks
winMarks = Map WindowRef WinMarks
forall k a. Map k a
M.empty
, lastActiveWindow :: Window
lastActiveWindow = BufferRef -> Window
dummyWindow BufferRef
unique
, lastSyncTime :: UTCTime
lastSyncTime = UTCTime
epoch
, readOnly :: Bool
readOnly = Bool
False
, directoryContent :: Bool
directoryContent = Bool
False
, inserting :: Bool
inserting = Bool
True
, pointFollowsWindow :: Set WindowRef
pointFollowsWindow = Set WindowRef
forall a. Monoid a => a
mempty
, updateTransactionInFlight :: Bool
updateTransactionInFlight = Bool
False
, updateTransactionAccum :: Seq Update
updateTransactionAccum = Seq Update
forall a. Monoid a => a
mempty
, fontsizeVariation :: Int
fontsizeVariation = Int
0
, updateStream :: Seq Update
updateStream = Seq Update
forall a. Monoid a => a
mempty
} }
epoch :: UTCTime
epoch :: UTCTime
epoch = Day -> DiffTime -> UTCTime
UTCTime (Int -> Day
forall a. Enum a => Int -> a
toEnum Int
0) (Int -> DiffTime
forall a. Enum a => Int -> a
toEnum Int
0)
sizeB :: BufferM Point
sizeB :: BufferM Point
sizeB = (forall syntax. BufferImpl syntax -> Point) -> BufferM Point
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer BufferImpl syntax -> Point
forall syntax. BufferImpl syntax -> Point
sizeBI
pointB :: BufferM Point
pointB :: BufferM Point
pointB = Getting Point FBuffer Point -> BufferM Point
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use (Getting Point FBuffer Point -> BufferM Point)
-> (Mark -> Getting Point FBuffer Point) -> Mark -> BufferM Point
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Mark -> Getting Point FBuffer Point
forall (f :: * -> *).
Functor f =>
Mark -> (Point -> f Point) -> FBuffer -> f FBuffer
markPointA (Mark -> BufferM Point) -> BufferM Mark -> BufferM Point
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM Mark
getInsMark
nelemsB :: Int -> Point -> BufferM YiString
nelemsB :: Int -> Point -> BufferM YiString
nelemsB Int
n Point
i = Int -> YiString -> YiString
R.take Int
n (YiString -> YiString) -> BufferM YiString -> BufferM YiString
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Direction -> Point -> BufferM YiString
streamB Direction
Forward Point
i
streamB :: Direction -> Point -> BufferM YiString
streamB :: Direction -> Point -> BufferM YiString
streamB Direction
dir Point
i = (forall syntax. BufferImpl syntax -> YiString) -> BufferM YiString
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer ((forall syntax. BufferImpl syntax -> YiString)
-> BufferM YiString)
-> (forall syntax. BufferImpl syntax -> YiString)
-> BufferM YiString
forall a b. (a -> b) -> a -> b
$ Direction -> Point -> BufferImpl syntax -> YiString
forall syntax. Direction -> Point -> BufferImpl syntax -> YiString
getStream Direction
dir Point
i
indexedStreamB :: Direction -> Point -> BufferM [(Point,Char)]
indexedStreamB :: Direction -> Point -> BufferM [(Point, Char)]
indexedStreamB Direction
dir Point
i = (forall syntax. BufferImpl syntax -> [(Point, Char)])
-> BufferM [(Point, Char)]
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer ((forall syntax. BufferImpl syntax -> [(Point, Char)])
-> BufferM [(Point, Char)])
-> (forall syntax. BufferImpl syntax -> [(Point, Char)])
-> BufferM [(Point, Char)]
forall a b. (a -> b) -> a -> b
$ Direction -> Point -> BufferImpl syntax -> [(Point, Char)]
forall syntax.
Direction -> Point -> BufferImpl syntax -> [(Point, Char)]
getIndexedStream Direction
dir Point
i
strokesRangesB :: Maybe SearchExp -> Region -> BufferM [[Stroke]]
strokesRangesB :: Maybe SearchExp -> Region -> BufferM [[Stroke]]
strokesRangesB Maybe SearchExp
regex Region
r = do
p <- BufferM Point
pointB
getStrokes <- withSyntaxB modeGetStrokes
queryBuffer $ strokesRangesBI getStrokes regex r p
moveTo :: Point -> BufferM ()
moveTo :: Point -> BufferM ()
moveTo Point
x = do
BufferM ()
forgetPreferCol
maxP <- BufferM Point
sizeB
let p = case () of
()
_ | Point
x Point -> Point -> Bool
forall a. Ord a => a -> a -> Bool
< Point
0 -> Int -> Point
Point Int
0
| Point
x Point -> Point -> Bool
forall a. Ord a => a -> a -> Bool
> Point
maxP -> Point
maxP
| Bool
otherwise -> Point
x
(.= p) . markPointA =<< getInsMark
setInserting :: Bool -> BufferM ()
setInserting :: Bool -> BufferM ()
setInserting = ((Bool -> Identity Bool) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c Bool
Lens' FBuffer Bool
insertingA ((Bool -> Identity Bool) -> FBuffer -> Identity FBuffer)
-> Bool -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.=)
checkRO :: BufferM Bool
checkRO :: BufferM Bool
checkRO = do
ro <- Getting Bool FBuffer Bool -> BufferM Bool
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting Bool FBuffer Bool
forall c. HasAttributes c => Lens' c Bool
Lens' FBuffer Bool
readOnlyA
when ro (fail "Read Only Buffer")
return ro
applyUpdate :: Update -> BufferM ()
applyUpdate :: Update -> BufferM ()
applyUpdate Update
update = do
runp <- (Bool -> Bool -> Bool)
-> BufferM Bool -> BufferM Bool -> BufferM Bool
forall a b c. (a -> b -> c) -> BufferM a -> BufferM b -> BufferM c
forall (f :: * -> *) a b c.
Applicative f =>
(a -> b -> c) -> f a -> f b -> f c
liftA2 Bool -> Bool -> Bool
(&&) (Bool -> Bool
not (Bool -> Bool) -> BufferM Bool -> BufferM Bool
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM Bool
checkRO) ((forall syntax. BufferImpl syntax -> Bool) -> BufferM Bool
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer (Update -> BufferImpl syntax -> Bool
forall syntax. Update -> BufferImpl syntax -> Bool
isValidUpdate Update
update))
when runp $ do
forgetPreferCol
modifyBuffer (applyUpdateI update)
isTransacPresent <- use updateTransactionInFlightA
if isTransacPresent
then updateTransactionAccumA %= (reverseUpdateI update S.<|)
else undosA %= addChangeU (AtomicChange $ reverseUpdateI update)
updateStreamA %= (S.|> update)
revertPendingUpdatesB :: BufferM ()
revertPendingUpdatesB :: BufferM ()
revertPendingUpdatesB = do
updates <- Getting (Seq UIUpdate) FBuffer (Seq UIUpdate)
-> BufferM (Seq UIUpdate)
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting (Seq UIUpdate) FBuffer (Seq UIUpdate)
forall c. HasAttributes c => Lens' c (Seq UIUpdate)
Lens' FBuffer (Seq UIUpdate)
pendingUpdatesA
modifyBuffer $ \BufferImpl syntax
stx ->
let applyTextUpdate :: UIUpdate -> BufferImpl syntax -> BufferImpl syntax
applyTextUpdate (TextUpdate Update
u) BufferImpl syntax
bi = Update -> BufferImpl syntax -> BufferImpl syntax
forall syntax. Update -> BufferImpl syntax -> BufferImpl syntax
applyUpdateI (Update -> Update
reverseUpdateI Update
u) BufferImpl syntax
bi
applyTextUpdate UIUpdate
_ BufferImpl syntax
bi = BufferImpl syntax
bi
in (UIUpdate -> BufferImpl syntax -> BufferImpl syntax)
-> BufferImpl syntax -> Seq UIUpdate -> BufferImpl syntax
forall a b. (a -> b -> b) -> b -> Seq a -> b
forall (t :: * -> *) a b.
Foldable t =>
(a -> b -> b) -> b -> t a -> b
foldr UIUpdate -> BufferImpl syntax -> BufferImpl syntax
forall {syntax}. UIUpdate -> BufferImpl syntax -> BufferImpl syntax
applyTextUpdate BufferImpl syntax
stx Seq UIUpdate
updates
writeB :: Char -> BufferM ()
writeB :: Char -> BufferM ()
writeB Char
c = do
Int -> BufferM ()
deleteN Int
1
Char -> BufferM ()
insertB Char
c
writeN :: YiString -> BufferM ()
writeN :: YiString -> BufferM ()
writeN YiString
cs = do
off <- BufferM Point
pointB
deleteNAt Forward (R.length cs) off
insertNAt cs off
newlineB :: BufferM ()
newlineB :: BufferM ()
newlineB = Char -> BufferM ()
insertB Char
'\n'
insertNAt :: YiString -> Point -> BufferM ()
insertNAt :: YiString -> Point -> BufferM ()
insertNAt YiString
rope Point
pnt = Update -> BufferM ()
applyUpdate (Point -> Direction -> YiString -> Update
Insert Point
pnt Direction
Forward YiString
rope)
insertN :: YiString -> BufferM ()
insertN :: YiString -> BufferM ()
insertN YiString
cs = BufferM Point
pointB BufferM Point -> (Point -> BufferM ()) -> BufferM ()
forall a b. BufferM a -> (a -> BufferM b) -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= YiString -> Point -> BufferM ()
insertNAt YiString
cs
insertB :: Char -> BufferM ()
insertB :: Char -> BufferM ()
insertB = YiString -> BufferM ()
insertN (YiString -> BufferM ())
-> (Char -> YiString) -> Char -> BufferM ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> YiString
R.singleton
deleteNAt :: Direction -> Int -> Point -> BufferM ()
deleteNAt :: Direction -> Int -> Point -> BufferM ()
deleteNAt Direction
_ Int
0 Point
_ = () -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
deleteNAt Direction
dir Int
n Point
pos = do
els <- Int -> YiString -> YiString
R.take Int
n (YiString -> YiString) -> BufferM YiString -> BufferM YiString
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Direction -> Point -> BufferM YiString
streamB Direction
Forward Point
pos
applyUpdate $ Delete pos dir els
curLn :: BufferM Int
curLn :: BufferM Int
curLn = do
p <- BufferM Point
pointB
queryBuffer (lineAt p)
screenTopLn :: BufferM Int
screenTopLn :: BufferM Int
screenTopLn = do
p <- Getting Point FBuffer Point -> BufferM Point
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use (Getting Point FBuffer Point -> BufferM Point)
-> (Mark -> Getting Point FBuffer Point) -> Mark -> BufferM Point
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Mark -> Getting Point FBuffer Point
forall (f :: * -> *).
Functor f =>
Mark -> (Point -> f Point) -> FBuffer -> f FBuffer
markPointA (Mark -> BufferM Point) -> BufferM Mark -> BufferM Point
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< WinMarks -> Mark
forall a. MarkSet a -> a
fromMark (WinMarks -> Mark) -> BufferM WinMarks -> BufferM Mark
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM WinMarks
askMarks
queryBuffer (lineAt p)
screenMidLn :: BufferM Int
screenMidLn :: BufferM Int
screenMidLn = Int -> Int -> Int
forall a. Num a => a -> a -> a
(+) (Int -> Int -> Int) -> BufferM Int -> BufferM (Int -> Int)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM Int
screenTopLn BufferM (Int -> Int) -> BufferM Int -> BufferM Int
forall a b. BufferM (a -> b) -> BufferM a -> BufferM b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (Int -> Int -> Int
forall a. Integral a => a -> a -> a
div (Int -> Int -> Int) -> BufferM Int -> BufferM (Int -> Int)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM Int
screenLines BufferM (Int -> Int) -> BufferM Int -> BufferM Int
forall a b. BufferM (a -> b) -> BufferM a -> BufferM b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Int -> BufferM Int
forall a. a -> BufferM a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Int
2)
screenBotLn :: BufferM Int
screenBotLn :: BufferM Int
screenBotLn = Int -> Int -> Int
forall a. Num a => a -> a -> a
(+) (Int -> Int -> Int) -> BufferM Int -> BufferM (Int -> Int)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM Int
screenTopLn BufferM (Int -> Int) -> BufferM Int -> BufferM Int
forall a b. BufferM (a -> b) -> BufferM a -> BufferM b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> BufferM Int
screenLines
screenLines :: BufferM Int
screenLines :: BufferM Int
screenLines = Int -> Int
forall a. Enum a => a -> a
pred (Int -> Int) -> BufferM Int -> BufferM Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Window -> Int) -> BufferM Int
forall a. (Window -> a) -> BufferM a
askWindow Window -> Int
actualLines
markLines :: BufferM (MarkSet Int)
markLines :: BufferM (MarkSet Int)
markLines = (Mark -> BufferM Int) -> WinMarks -> BufferM (MarkSet Int)
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b.
Monad m =>
(a -> m b) -> MarkSet a -> m (MarkSet b)
mapM Mark -> BufferM Int
getLn (WinMarks -> BufferM (MarkSet Int))
-> BufferM WinMarks -> BufferM (MarkSet Int)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM WinMarks
askMarks
where getLn :: Mark -> BufferM Int
getLn Mark
m = Getting Point FBuffer Point -> BufferM Point
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use (Mark -> Getting Point FBuffer Point
forall (f :: * -> *).
Functor f =>
Mark -> (Point -> f Point) -> FBuffer -> f FBuffer
markPointA Mark
m) BufferM Point -> (Point -> BufferM Int) -> BufferM Int
forall a b. BufferM a -> (a -> BufferM b) -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Point -> BufferM Int
lineOf
gotoLn :: Int -> BufferM Int
gotoLn :: Int -> BufferM Int
gotoLn Int
x = do
Point -> BufferM ()
moveTo Point
0
Int -> Int
forall a. Enum a => a -> a
succ (Int -> Int) -> BufferM Int -> BufferM Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Int -> BufferM Int
gotoLnFrom (Int
x Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
1)
setMode0 :: forall syntax. Mode syntax -> FBuffer -> FBuffer
setMode0 :: forall syntax. Mode syntax -> FBuffer -> FBuffer
setMode0 Mode syntax
m (FBuffer Mode syntax
_ BufferImpl syntax
rb Attributes
at) = Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
forall syntax.
Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
FBuffer Mode syntax
m (ExtHL syntax -> BufferImpl syntax -> BufferImpl syntax
forall syntax oldSyntax.
ExtHL syntax -> BufferImpl oldSyntax -> BufferImpl syntax
setSyntaxBI (Mode syntax -> ExtHL syntax
forall syntax. Mode syntax -> ExtHL syntax
modeHL Mode syntax
m) BufferImpl syntax
rb) Attributes
at
modifyMode0 :: (forall syntax. Mode syntax -> Mode syntax) -> FBuffer -> FBuffer
modifyMode0 :: (forall syntax. Mode syntax -> Mode syntax) -> FBuffer -> FBuffer
modifyMode0 forall syntax. Mode syntax -> Mode syntax
f (FBuffer Mode syntax
m BufferImpl syntax
rb Attributes
f3) = Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
forall syntax.
Mode syntax -> BufferImpl syntax -> Attributes -> FBuffer
FBuffer Mode syntax
m' (ExtHL syntax -> BufferImpl syntax -> BufferImpl syntax
forall syntax oldSyntax.
ExtHL syntax -> BufferImpl oldSyntax -> BufferImpl syntax
setSyntaxBI (Mode syntax -> ExtHL syntax
forall syntax. Mode syntax -> ExtHL syntax
modeHL Mode syntax
m') BufferImpl syntax
rb) Attributes
f3
where m' :: Mode syntax
m' = Mode syntax -> Mode syntax
forall syntax. Mode syntax -> Mode syntax
f Mode syntax
m
setAnyMode :: AnyMode -> BufferM ()
setAnyMode :: AnyMode -> BufferM ()
setAnyMode (AnyMode Mode syntax
m) = Mode syntax -> BufferM ()
forall syntax. Mode syntax -> BufferM ()
setMode Mode syntax
m
setMode :: Mode syntax -> BufferM ()
setMode :: forall syntax. Mode syntax -> BufferM ()
setMode Mode syntax
m = do
(FBuffer -> FBuffer) -> BufferM ()
forall s (m :: * -> *). MonadState s m => (s -> s) -> m ()
modify (Mode syntax -> FBuffer -> FBuffer
forall syntax. Mode syntax -> FBuffer -> FBuffer
setMode0 Mode syntax
m)
(KeymapProcess -> Identity KeymapProcess)
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c KeymapProcess
Lens' FBuffer KeymapProcess
keymapProcessA ((KeymapProcess -> Identity KeymapProcess)
-> FBuffer -> Identity FBuffer)
-> KeymapProcess -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.= KeymapProcess
forall event w. P event w
I.End
Mode syntax -> BufferM ()
forall syntax. Mode syntax -> BufferM ()
modeOnLoad Mode syntax
m
modifyMode :: (forall syntax. Mode syntax -> Mode syntax) -> BufferM ()
modifyMode :: (forall syntax. Mode syntax -> Mode syntax) -> BufferM ()
modifyMode forall syntax. Mode syntax -> Mode syntax
f = do
(FBuffer -> FBuffer) -> BufferM ()
forall s (m :: * -> *). MonadState s m => (s -> s) -> m ()
modify ((forall syntax. Mode syntax -> Mode syntax) -> FBuffer -> FBuffer
modifyMode0 Mode syntax -> Mode syntax
forall syntax. Mode syntax -> Mode syntax
f)
(KeymapProcess -> Identity KeymapProcess)
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c KeymapProcess
Lens' FBuffer KeymapProcess
keymapProcessA ((KeymapProcess -> Identity KeymapProcess)
-> FBuffer -> Identity FBuffer)
-> KeymapProcess -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.= KeymapProcess
forall event w. P event w
I.End
onMode :: (forall syntax. Mode syntax -> Mode syntax) -> AnyMode -> AnyMode
onMode :: (forall syntax. Mode syntax -> Mode syntax) -> AnyMode -> AnyMode
onMode forall syntax. Mode syntax -> Mode syntax
f (AnyMode Mode syntax
m) = Mode syntax -> AnyMode
forall syntax. Mode syntax -> AnyMode
AnyMode (Mode syntax -> Mode syntax
forall syntax. Mode syntax -> Mode syntax
f Mode syntax
m)
withMode0 :: (forall syntax. Mode syntax -> a) -> FBuffer -> a
withMode0 :: forall a. (forall syntax. Mode syntax -> a) -> FBuffer -> a
withMode0 forall syntax. Mode syntax -> a
f FBuffer {bmode :: ()
bmode = Mode syntax
m} = Mode syntax -> a
forall syntax. Mode syntax -> a
f Mode syntax
m
withModeB :: (forall syntax. Mode syntax -> BufferM a) -> BufferM a
withModeB :: forall a. (forall syntax. Mode syntax -> BufferM a) -> BufferM a
withModeB forall syntax. Mode syntax -> BufferM a
x = BufferM (BufferM a) -> BufferM a
forall (m :: * -> *) a. Monad m => m (m a) -> m a
join ((FBuffer -> BufferM a) -> BufferM (BufferM a)
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets ((forall syntax. Mode syntax -> BufferM a) -> FBuffer -> BufferM a
forall a. (forall syntax. Mode syntax -> a) -> FBuffer -> a
withMode0 Mode syntax -> BufferM a
forall syntax. Mode syntax -> BufferM a
x))
withSyntax0 :: (forall syntax. Mode syntax -> syntax -> a) -> WindowRef -> FBuffer -> a
withSyntax0 :: forall a.
(forall syntax. Mode syntax -> syntax -> a)
-> WindowRef -> FBuffer -> a
withSyntax0 forall syntax. Mode syntax -> syntax -> a
f WindowRef
wk (FBuffer Mode syntax
bm BufferImpl syntax
rb Attributes
_attrs) = Mode syntax -> syntax -> a
forall syntax. Mode syntax -> syntax -> a
f Mode syntax
bm (WindowRef -> BufferImpl syntax -> syntax
forall syntax. WindowRef -> BufferImpl syntax -> syntax
getAst WindowRef
wk BufferImpl syntax
rb)
withSyntaxB :: (forall syntax. Mode syntax -> syntax -> a) -> BufferM a
withSyntaxB :: forall a. (forall syntax. Mode syntax -> syntax -> a) -> BufferM a
withSyntaxB forall syntax. Mode syntax -> syntax -> a
f = (forall syntax. Mode syntax -> syntax -> a)
-> WindowRef -> FBuffer -> a
forall a.
(forall syntax. Mode syntax -> syntax -> a)
-> WindowRef -> FBuffer -> a
withSyntax0 Mode syntax -> syntax -> a
forall syntax. Mode syntax -> syntax -> a
f (WindowRef -> FBuffer -> a)
-> BufferM WindowRef -> BufferM (FBuffer -> a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Window -> WindowRef) -> BufferM WindowRef
forall a. (Window -> a) -> BufferM a
askWindow Window -> WindowRef
wkey BufferM (FBuffer -> a) -> BufferM FBuffer -> BufferM a
forall a b. BufferM (a -> b) -> BufferM a -> BufferM b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Getting FBuffer FBuffer FBuffer -> BufferM FBuffer
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting FBuffer FBuffer FBuffer
forall a. a -> a
id
focusSyntax :: M.Map WindowRef Region -> FBuffer -> FBuffer
focusSyntax :: Map WindowRef Region -> FBuffer -> FBuffer
focusSyntax Map WindowRef Region
r = (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer -> FBuffer
modifyRawbuf (Map WindowRef Region -> BufferImpl syntax -> BufferImpl syntax
forall syntax.
Map WindowRef Region -> BufferImpl syntax -> BufferImpl syntax
focusAst Map WindowRef Region
r)
withSyntaxB' :: (forall syntax. Mode syntax -> syntax -> BufferM a) -> BufferM a
withSyntaxB' :: forall a.
(forall syntax. Mode syntax -> syntax -> BufferM a) -> BufferM a
withSyntaxB' forall syntax. Mode syntax -> syntax -> BufferM a
x = BufferM (BufferM a) -> BufferM a
forall (m :: * -> *) a. Monad m => m (m a) -> m a
join ((forall syntax. Mode syntax -> syntax -> BufferM a)
-> BufferM (BufferM a)
forall a. (forall syntax. Mode syntax -> syntax -> a) -> BufferM a
withSyntaxB Mode syntax -> syntax -> BufferM a
forall syntax. Mode syntax -> syntax -> BufferM a
x)
regexRegionB :: SearchExp -> Region -> BufferM [Region]
regexRegionB :: SearchExp -> Region -> BufferM [Region]
regexRegionB SearchExp
regex Region
region = (forall syntax. BufferImpl syntax -> [Region]) -> BufferM [Region]
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer ((forall syntax. BufferImpl syntax -> [Region])
-> BufferM [Region])
-> (forall syntax. BufferImpl syntax -> [Region])
-> BufferM [Region]
forall a b. (a -> b) -> a -> b
$ SearchExp -> Region -> forall syntax. BufferImpl syntax -> [Region]
regexRegionBI SearchExp
regex Region
region
regexB :: Direction -> SearchExp -> BufferM [Region]
regexB :: Direction -> SearchExp -> BufferM [Region]
regexB Direction
dir SearchExp
rx = do
p <- BufferM Point
pointB
s <- sizeB
regexRegionB rx (mkRegion p (case dir of Direction
Forward -> Point
s; Direction
Backward -> Point
0))
modifyMarkRaw :: Mark -> (MarkValue -> MarkValue) -> FBuffer -> FBuffer
modifyMarkRaw :: Mark -> (MarkValue -> MarkValue) -> FBuffer -> FBuffer
modifyMarkRaw Mark
m MarkValue -> MarkValue
f = (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer -> FBuffer
modifyRawbuf ((forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer -> FBuffer)
-> (forall syntax. BufferImpl syntax -> BufferImpl syntax)
-> FBuffer
-> FBuffer
forall a b. (a -> b) -> a -> b
$ Mark
-> (MarkValue -> MarkValue)
-> forall syntax. BufferImpl syntax -> BufferImpl syntax
modifyMarkBI Mark
m MarkValue -> MarkValue
f
modifyMarkB :: Mark -> (MarkValue -> MarkValue) -> BufferM ()
modifyMarkB :: Mark -> (MarkValue -> MarkValue) -> BufferM ()
modifyMarkB = ((FBuffer -> FBuffer) -> BufferM ()
forall s (m :: * -> *). MonadState s m => (s -> s) -> m ()
modify ((FBuffer -> FBuffer) -> BufferM ())
-> ((MarkValue -> MarkValue) -> FBuffer -> FBuffer)
-> (MarkValue -> MarkValue)
-> BufferM ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
.) (((MarkValue -> MarkValue) -> FBuffer -> FBuffer)
-> (MarkValue -> MarkValue) -> BufferM ())
-> (Mark -> (MarkValue -> MarkValue) -> FBuffer -> FBuffer)
-> Mark
-> (MarkValue -> MarkValue)
-> BufferM ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Mark -> (MarkValue -> MarkValue) -> FBuffer -> FBuffer
modifyMarkRaw
setMarkHereB :: BufferM Mark
setMarkHereB :: BufferM Mark
setMarkHereB = Maybe String -> BufferM Mark
getMarkB Maybe String
forall a. Maybe a
Nothing
setNamedMarkHereB :: String -> BufferM ()
setNamedMarkHereB :: String -> BufferM ()
setNamedMarkHereB String
name = do
p <- BufferM Point
pointB
getMarkB (Just name) >>= (.= p) . markPointA
setVisibleSelection :: Bool -> BufferM ()
setVisibleSelection :: Bool -> BufferM ()
setVisibleSelection = ((Bool -> Identity Bool) -> FBuffer -> Identity FBuffer
Lens' FBuffer Bool
highlightSelectionA ((Bool -> Identity Bool) -> FBuffer -> Identity FBuffer)
-> Bool -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.=)
getVisibleSelection :: BufferM Bool
getVisibleSelection :: BufferM Bool
getVisibleSelection = Getting Bool FBuffer Bool -> BufferM Bool
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting Bool FBuffer Bool
Lens' FBuffer Bool
highlightSelectionA
getInsMark :: BufferM Mark
getInsMark :: BufferM Mark
getInsMark = WinMarks -> Mark
forall a. MarkSet a -> a
insMark (WinMarks -> Mark) -> BufferM WinMarks -> BufferM Mark
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM WinMarks
askMarks
askMarks :: BufferM WinMarks
askMarks :: BufferM WinMarks
askMarks = do
Just !ms <- Window -> BufferM (Maybe WinMarks)
getMarks (Window -> BufferM (Maybe WinMarks))
-> BufferM Window -> BufferM (Maybe WinMarks)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM Window
forall r (m :: * -> *). MonadReader r m => m r
ask
return ms
getMarkB :: Maybe String -> BufferM Mark
getMarkB :: Maybe String -> BufferM Mark
getMarkB Maybe String
m = do
p <- BufferM Point
pointB
queryAndModify (getMarkDefaultPosBI m p)
mayGetMarkB :: String -> BufferM (Maybe Mark)
mayGetMarkB :: String -> BufferM (Maybe Mark)
mayGetMarkB String
m = (forall syntax. BufferImpl syntax -> Maybe Mark)
-> BufferM (Maybe Mark)
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer (String -> BufferImpl syntax -> Maybe Mark
forall syntax. String -> BufferImpl syntax -> Maybe Mark
getMarkBI String
m)
moveN :: Int -> BufferM ()
moveN :: Int -> BufferM ()
moveN Int
n = do
s <- BufferM Point
sizeB
moveTo =<< min s . max 0 . (+~ Size n) <$> pointB
leftB :: BufferM ()
leftB :: BufferM ()
leftB = Int -> BufferM ()
leftN Int
1
leftN :: Int -> BufferM ()
leftN :: Int -> BufferM ()
leftN Int
n = Int -> BufferM ()
moveN (-Int
n)
rightB :: BufferM ()
rightB :: BufferM ()
rightB = Int -> BufferM ()
rightN Int
1
rightN :: Int -> BufferM ()
rightN :: Int -> BufferM ()
rightN = Int -> BufferM ()
moveN
lineMoveRel :: Int -> BufferM Int
lineMoveRel :: Int -> BufferM Int
lineMoveRel = BufferM Int -> BufferM Int
forall a. BufferM a -> BufferM a
movingToPrefCol (BufferM Int -> BufferM Int)
-> (Int -> BufferM Int) -> Int -> BufferM Int
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> BufferM Int
gotoLnFrom
movingToPrefCol :: BufferM a -> BufferM a
movingToPrefCol :: forall a. BufferM a -> BufferM a
movingToPrefCol BufferM a
f = do
prefCol <- Getting (Maybe Int) FBuffer (Maybe Int) -> BufferM (Maybe Int)
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting (Maybe Int) FBuffer (Maybe Int)
forall c. HasAttributes c => Lens' c (Maybe Int)
Lens' FBuffer (Maybe Int)
preferColA
targetCol <- maybe curCol return prefCol
r <- f
moveToColB targetCol
preferColA .= Just targetCol
return r
movingToPrefVisCol :: BufferM a -> BufferM a
movingToPrefVisCol :: forall a. BufferM a -> BufferM a
movingToPrefVisCol BufferM a
f = do
prefCol <- Getting (Maybe Int) FBuffer (Maybe Int) -> BufferM (Maybe Int)
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting (Maybe Int) FBuffer (Maybe Int)
forall c. HasAttributes c => Lens' c (Maybe Int)
Lens' FBuffer (Maybe Int)
preferVisColA
targetCol <- maybe curVisCol return prefCol
r <- f
moveToVisColB targetCol
preferVisColA .= Just targetCol
return r
moveToColB :: Int -> BufferM ()
moveToColB :: Int -> BufferM ()
moveToColB Int
targetCol = do
solPnt <- Point -> BufferM Point
solPointB (Point -> BufferM Point) -> BufferM Point -> BufferM Point
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM Point
pointB
chrs <- R.toString <$> nelemsB targetCol solPnt
is <- indentSettingsB
let cols = (Int -> Char -> Int) -> Int -> String -> [Int]
forall b a. (b -> a -> b) -> b -> [a] -> [b]
scanl (IndentSettings -> Int -> Char -> Int
colMove IndentSettings
is) Int
0 String
chrs
toSkip = ((Char, Int) -> Bool) -> [(Char, Int)] -> [(Char, Int)]
forall a. (a -> Bool) -> [a] -> [a]
takeWhile (\(Char
char,Int
col) -> Char
char Char -> Char -> Bool
forall a. Eq a => a -> a -> Bool
/= Char
'\n' Bool -> Bool -> Bool
&& Int
col Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
targetCol) (String -> [Int] -> [(Char, Int)]
forall a b. [a] -> [b] -> [(a, b)]
zip String
chrs [Int]
cols)
moveTo $ solPnt +~ fromIntegral (length toSkip)
moveToVisColB :: Int -> BufferM ()
moveToVisColB :: Int -> BufferM ()
moveToVisColB Int
targetCol = do
col <- BufferM Int
curCol
wid <- width <$> use lastActiveWindowA
let jumps = Int
col Int -> Int -> Int
forall a. Integral a => a -> a -> a
`div` Int
wid
moveToColB $ jumps * wid + targetCol
moveToLineColB :: Int -> Int -> BufferM ()
moveToLineColB :: Int -> Int -> BufferM ()
moveToLineColB Int
line Int
col = Int -> BufferM Int
gotoLn Int
line BufferM Int -> BufferM () -> BufferM ()
forall a b. BufferM a -> BufferM b -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> Int -> BufferM ()
moveToColB Int
col
pointOfLineColB :: Int -> Int -> BufferM Point
pointOfLineColB :: Int -> Int -> BufferM Point
pointOfLineColB Int
line Int
col = BufferM Point -> BufferM Point
forall a. BufferM a -> BufferM a
savingPointB (BufferM Point -> BufferM Point) -> BufferM Point -> BufferM Point
forall a b. (a -> b) -> a -> b
$ Int -> Int -> BufferM ()
moveToLineColB Int
line Int
col BufferM () -> BufferM Point -> BufferM Point
forall a b. BufferM a -> BufferM b -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> BufferM Point
pointB
forgetPreferCol :: BufferM ()
forgetPreferCol :: BufferM ()
forgetPreferCol = do
(Maybe Int -> Identity (Maybe Int)) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c (Maybe Int)
Lens' FBuffer (Maybe Int)
preferColA ((Maybe Int -> Identity (Maybe Int))
-> FBuffer -> Identity FBuffer)
-> Maybe Int -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.= Maybe Int
forall a. Maybe a
Nothing
(Maybe Int -> Identity (Maybe Int)) -> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c (Maybe Int)
Lens' FBuffer (Maybe Int)
preferVisColA ((Maybe Int -> Identity (Maybe Int))
-> FBuffer -> Identity FBuffer)
-> Maybe Int -> BufferM ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.= Maybe Int
forall a. Maybe a
Nothing
!st <- (FBuffer -> FBuffer) -> BufferM FBuffer
forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets FBuffer -> FBuffer
forall a. a -> a
id
return $! (st `seq` ())
savingPrefCol :: BufferM a -> BufferM a
savingPrefCol :: forall a. BufferM a -> BufferM a
savingPrefCol BufferM a
f = do
pc <- Getting (Maybe Int) FBuffer (Maybe Int) -> BufferM (Maybe Int)
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting (Maybe Int) FBuffer (Maybe Int)
forall c. HasAttributes c => Lens' c (Maybe Int)
Lens' FBuffer (Maybe Int)
preferColA
pv <- use preferVisColA
result <- f
preferColA .= pc
preferVisColA .= pv
return result
lineUp :: BufferM ()
lineUp :: BufferM ()
lineUp = BufferM Int -> BufferM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (Int -> BufferM Int
lineMoveRel (-Int
1))
lineDown :: BufferM ()
lineDown :: BufferM ()
lineDown = BufferM Int -> BufferM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (Int -> BufferM Int
lineMoveRel Int
1)
elemsB :: BufferM YiString
elemsB :: BufferM YiString
elemsB = (forall syntax. BufferImpl syntax -> YiString) -> BufferM YiString
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer BufferImpl syntax -> YiString
forall syntax. BufferImpl syntax -> YiString
mem
betweenB :: Point
-> Point
-> BufferM YiString
betweenB :: Point -> Point -> BufferM YiString
betweenB (Point Int
s) (Point Int
e) =
if Int
s Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
>= Int
e
then YiString -> BufferM YiString
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (YiString
forall a. Monoid a => a
mempty :: YiString)
else (YiString, YiString) -> YiString
forall a b. (a, b) -> b
snd ((YiString, YiString) -> YiString)
-> (YiString -> (YiString, YiString)) -> YiString -> YiString
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> YiString -> (YiString, YiString)
R.splitAt Int
s (YiString -> (YiString, YiString))
-> (YiString -> YiString) -> YiString -> (YiString, YiString)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (YiString, YiString) -> YiString
forall a b. (a, b) -> a
fst ((YiString, YiString) -> YiString)
-> (YiString -> (YiString, YiString)) -> YiString -> YiString
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> YiString -> (YiString, YiString)
R.splitAt Int
e (YiString -> YiString) -> BufferM YiString -> BufferM YiString
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM YiString
elemsB
readB :: BufferM Char
readB :: BufferM Char
readB = BufferM Point
pointB BufferM Point -> (Point -> BufferM Char) -> BufferM Char
forall a b. BufferM a -> (a -> BufferM b) -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Point -> BufferM Char
readAtB
readAtB :: Point -> BufferM Char
readAtB :: Point -> BufferM Char
readAtB Point
i = YiString -> Maybe Char
R.head (YiString -> Maybe Char)
-> BufferM YiString -> BufferM (Maybe Char)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Int -> Point -> BufferM YiString
nelemsB Int
1 Point
i BufferM (Maybe Char)
-> (Maybe Char -> BufferM Char) -> BufferM Char
forall a b. BufferM a -> (a -> BufferM b) -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Char -> BufferM Char
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (Char -> BufferM Char)
-> (Maybe Char -> Char) -> Maybe Char -> BufferM Char
forall b c a. (b -> c) -> (a -> b) -> a -> c
. \case
Maybe Char
Nothing -> Char
'\0'
Just Char
c -> Char
c
replaceCharB :: Char -> BufferM ()
replaceCharB :: Char -> BufferM ()
replaceCharB Char
c = do
Char -> BufferM ()
writeB Char
c
BufferM ()
leftB
replaceCharWithBelowB :: BufferM ()
replaceCharWithBelowB :: BufferM ()
replaceCharWithBelowB = Int -> BufferM ()
replaceCharWithVerticalOffset Int
1
replaceCharWithAboveB :: BufferM ()
replaceCharWithAboveB :: BufferM ()
replaceCharWithAboveB = Int -> BufferM ()
replaceCharWithVerticalOffset (-Int
1)
insertCharWithBelowB :: BufferM ()
insertCharWithBelowB :: BufferM ()
insertCharWithBelowB = BufferM () -> (Char -> BufferM ()) -> Maybe Char -> BufferM ()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (() -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return ()) Char -> BufferM ()
insertB (Maybe Char -> BufferM ()) -> BufferM (Maybe Char) -> BufferM ()
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM (Maybe Char)
maybeCharBelowB
insertCharWithAboveB :: BufferM ()
insertCharWithAboveB :: BufferM ()
insertCharWithAboveB = BufferM () -> (Char -> BufferM ()) -> Maybe Char -> BufferM ()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (() -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return ()) Char -> BufferM ()
insertB (Maybe Char -> BufferM ()) -> BufferM (Maybe Char) -> BufferM ()
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM (Maybe Char)
maybeCharAboveB
replaceCharWithVerticalOffset :: Int -> BufferM ()
replaceCharWithVerticalOffset :: Int -> BufferM ()
replaceCharWithVerticalOffset Int
offset =
BufferM () -> (Char -> BufferM ()) -> Maybe Char -> BufferM ()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (() -> BufferM ()
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return ()) Char -> BufferM ()
replaceCharB (Maybe Char -> BufferM ()) -> BufferM (Maybe Char) -> BufferM ()
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< Int -> BufferM (Maybe Char)
maybeCharWithVerticalOffset Int
offset
maybeCharBelowB :: BufferM (Maybe Char)
maybeCharBelowB :: BufferM (Maybe Char)
maybeCharBelowB = Int -> BufferM (Maybe Char)
maybeCharWithVerticalOffset Int
1
maybeCharAboveB :: BufferM (Maybe Char)
maybeCharAboveB :: BufferM (Maybe Char)
maybeCharAboveB = Int -> BufferM (Maybe Char)
maybeCharWithVerticalOffset (-Int
1)
maybeCharWithVerticalOffset :: Int -> BufferM (Maybe Char)
maybeCharWithVerticalOffset :: Int -> BufferM (Maybe Char)
maybeCharWithVerticalOffset Int
offset = BufferM (Maybe Char) -> BufferM (Maybe Char)
forall a. BufferM a -> BufferM a
savingPointB (BufferM (Maybe Char) -> BufferM (Maybe Char))
-> BufferM (Maybe Char) -> BufferM (Maybe Char)
forall a b. (a -> b) -> a -> b
$ do
l0 <- BufferM Int
curLn
c0 <- curCol
void $ lineMoveRel offset
l1 <- curLn
c1 <- curCol
curChar <- readB
return $ if c0 == c1
&& l0 + offset == l1
&& curChar `notElem` ("\n\0" :: String)
then Just curChar
else Nothing
deleteN :: Int -> BufferM ()
deleteN :: Int -> BufferM ()
deleteN Int
n = BufferM Point
pointB BufferM Point -> (Point -> BufferM ()) -> BufferM ()
forall a b. BufferM a -> (a -> BufferM b) -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Direction -> Int -> Point -> BufferM ()
deleteNAt Direction
Forward Int
n
indentSettingsB :: BufferM IndentSettings
indentSettingsB :: BufferM IndentSettings
indentSettingsB = (forall syntax. Mode syntax -> BufferM IndentSettings)
-> BufferM IndentSettings
forall a. (forall syntax. Mode syntax -> BufferM a) -> BufferM a
withModeB ((forall syntax. Mode syntax -> BufferM IndentSettings)
-> BufferM IndentSettings)
-> (forall syntax. Mode syntax -> BufferM IndentSettings)
-> BufferM IndentSettings
forall a b. (a -> b) -> a -> b
$ IndentSettings -> BufferM IndentSettings
forall a. a -> BufferM a
forall (m :: * -> *) a. Monad m => a -> m a
return (IndentSettings -> BufferM IndentSettings)
-> (Mode syntax -> IndentSettings)
-> Mode syntax
-> BufferM IndentSettings
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Mode syntax -> IndentSettings
forall syntax. Mode syntax -> IndentSettings
modeIndentSettings
curCol :: BufferM Int
curCol :: BufferM Int
curCol = Point -> BufferM Int
colOf (Point -> BufferM Int) -> BufferM Point -> BufferM Int
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM Point
pointB
curVisCol :: BufferM Int
curVisCol :: BufferM Int
curVisCol = Int -> Int -> Int
forall a. Integral a => a -> a -> a
rem (Int -> Int -> Int) -> BufferM Int -> BufferM (Int -> Int)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM Int
curCol BufferM (Int -> Int) -> BufferM Int -> BufferM Int
forall a b. BufferM (a -> b) -> BufferM a -> BufferM b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (Window -> Int
width (Window -> Int) -> BufferM Window -> BufferM Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Getting Window FBuffer Window -> BufferM Window
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting Window FBuffer Window
forall c. HasAttributes c => Lens' c Window
Lens' FBuffer Window
lastActiveWindowA)
colOf :: Point -> BufferM Int
colOf :: Point -> BufferM Int
colOf Point
p = do
is <- BufferM IndentSettings
indentSettingsB
R.foldl' (colMove is) 0 <$> queryBuffer (charsFromSolBI p)
lineOf :: Point -> BufferM Int
lineOf :: Point -> BufferM Int
lineOf Point
p = (forall syntax. BufferImpl syntax -> Int) -> BufferM Int
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer ((forall syntax. BufferImpl syntax -> Int) -> BufferM Int)
-> (forall syntax. BufferImpl syntax -> Int) -> BufferM Int
forall a b. (a -> b) -> a -> b
$ Point -> BufferImpl syntax -> Int
forall syntax. Point -> BufferImpl syntax -> Int
lineAt Point
p
lineCountB :: BufferM Int
lineCountB :: BufferM Int
lineCountB = Point -> BufferM Int
lineOf (Point -> BufferM Int) -> BufferM Point -> BufferM Int
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< BufferM Point
sizeB
colMove :: IndentSettings -> Int -> Char -> Int
colMove :: IndentSettings -> Int -> Char -> Int
colMove IndentSettings
is Int
col Char
'\t' | IndentSettings -> Int
tabSize IndentSettings
is Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
> Int
1 = Int
col Int -> Int -> Int
forall a. Num a => a -> a -> a
+ IndentSettings -> Int
tabSize IndentSettings
is
colMove IndentSettings
_ Int
col Char
_ = Int
col Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1
solPointB :: Point -> BufferM Point
solPointB :: Point -> BufferM Point
solPointB Point
p = (forall syntax. BufferImpl syntax -> Point) -> BufferM Point
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer ((forall syntax. BufferImpl syntax -> Point) -> BufferM Point)
-> (forall syntax. BufferImpl syntax -> Point) -> BufferM Point
forall a b. (a -> b) -> a -> b
$ Point -> BufferImpl syntax -> Point
forall syntax. Point -> BufferImpl syntax -> Point
solPoint' Point
p
eolPointB :: Point -> BufferM Point
eolPointB :: Point -> BufferM Point
eolPointB Point
p = (forall syntax. BufferImpl syntax -> Point) -> BufferM Point
forall x. (forall syntax. BufferImpl syntax -> x) -> BufferM x
queryBuffer ((forall syntax. BufferImpl syntax -> Point) -> BufferM Point)
-> (forall syntax. BufferImpl syntax -> Point) -> BufferM Point
forall a b. (a -> b) -> a -> b
$ Point -> BufferImpl syntax -> Point
forall syntax. Point -> BufferImpl syntax -> Point
eolPoint' Point
p
gotoLnFrom :: Int -> BufferM Int
gotoLnFrom :: Int -> BufferM Int
gotoLnFrom Int
x = do
l <- BufferM Int
curLn
p' <- queryBuffer $ solPoint (l + x)
moveTo p'
l' <- curLn
return (l' - l)
getBufferDyn :: forall m a. (Default a, YiVariable a, MonadState FBuffer m, Functor m) => m a
getBufferDyn :: forall (m :: * -> *) a.
(Default a, YiVariable a, MonadState FBuffer m, Functor m) =>
m a
getBufferDyn = a -> Maybe a -> a
forall a. a -> Maybe a -> a
fromMaybe (a
forall a. Default a => a
def :: a) (Maybe a -> a) -> m (Maybe a) -> m a
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> m DynamicState -> (DynamicState -> m ()) -> m (Maybe a)
forall (m :: * -> *) a.
(Typeable a, Binary a, Monad m) =>
m DynamicState -> (DynamicState -> m ()) -> m (Maybe a)
getDyn (Getting DynamicState FBuffer DynamicState -> m DynamicState
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting DynamicState FBuffer DynamicState
forall c. HasAttributes c => Lens' c DynamicState
Lens' FBuffer DynamicState
bufferDynamicA) ((DynamicState -> Identity DynamicState)
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c DynamicState
Lens' FBuffer DynamicState
bufferDynamicA ((DynamicState -> Identity DynamicState)
-> FBuffer -> Identity FBuffer)
-> DynamicState -> m ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.=)
putBufferDyn :: (YiVariable a, MonadState FBuffer m, Functor m) => a -> m ()
putBufferDyn :: forall a (m :: * -> *).
(YiVariable a, MonadState FBuffer m, Functor m) =>
a -> m ()
putBufferDyn = m DynamicState -> (DynamicState -> m ()) -> a -> m ()
forall (m :: * -> *) a.
(Typeable a, Binary a, Monad m) =>
m DynamicState -> (DynamicState -> m ()) -> a -> m ()
putDyn (Getting DynamicState FBuffer DynamicState -> m DynamicState
forall s (m :: * -> *) a. MonadState s m => Getting a s a -> m a
use Getting DynamicState FBuffer DynamicState
forall c. HasAttributes c => Lens' c DynamicState
Lens' FBuffer DynamicState
bufferDynamicA) ((DynamicState -> Identity DynamicState)
-> FBuffer -> Identity FBuffer
forall c. HasAttributes c => Lens' c DynamicState
Lens' FBuffer DynamicState
bufferDynamicA ((DynamicState -> Identity DynamicState)
-> FBuffer -> Identity FBuffer)
-> DynamicState -> m ()
forall s (m :: * -> *) a b.
MonadState s m =>
ASetter s s a b -> b -> m ()
.=)
savingExcursionB :: BufferM a -> BufferM a
savingExcursionB :: forall a. BufferM a -> BufferM a
savingExcursionB BufferM a
f = do
m <- Maybe String -> BufferM Mark
getMarkB Maybe String
forall a. Maybe a
Nothing
res <- f
moveTo =<< use (markPointA m)
return res
markPointA :: forall f . Functor f => Mark -> (Point -> f Point) -> (FBuffer -> f FBuffer)
markPointA :: forall (f :: * -> *).
Functor f =>
Mark -> (Point -> f Point) -> FBuffer -> f FBuffer
markPointA Mark
mark = (FBuffer -> Point)
-> (FBuffer -> Point -> FBuffer)
-> Lens FBuffer FBuffer Point Point
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
lens FBuffer -> Point
getter FBuffer -> Point -> FBuffer
setter where
getter :: FBuffer -> Point
getter FBuffer
b = MarkValue -> Point
markPoint (MarkValue -> Point) -> MarkValue -> Point
forall a b. (a -> b) -> a -> b
$ Mark -> FBuffer -> MarkValue
getMarkValueRaw Mark
mark FBuffer
b
setter :: FBuffer -> Point -> FBuffer
setter FBuffer
b Point
pos = Mark -> (MarkValue -> MarkValue) -> FBuffer -> FBuffer
modifyMarkRaw Mark
mark (\MarkValue
v -> MarkValue
v {markPoint = pos}) FBuffer
b
savingPointB :: BufferM a -> BufferM a
savingPointB :: forall a. BufferM a -> BufferM a
savingPointB BufferM a
f = BufferM a -> BufferM a
forall a. BufferM a -> BufferM a
savingPrefCol (BufferM a -> BufferM a) -> BufferM a -> BufferM a
forall a b. (a -> b) -> a -> b
$ do
p <- BufferM Point
pointB
res <- f
moveTo p
return res
savingPositionB :: BufferM a -> BufferM a
savingPositionB :: forall a. BufferM a -> BufferM a
savingPositionB BufferM a
f = BufferM a -> BufferM a
forall a. BufferM a -> BufferM a
savingPrefCol (BufferM a -> BufferM a) -> BufferM a -> BufferM a
forall a b. (a -> b) -> a -> b
$ do
(c, l) <- (,) (Int -> Int -> (Int, Int))
-> BufferM Int -> BufferM (Int -> (Int, Int))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BufferM Int
curCol BufferM (Int -> (Int, Int)) -> BufferM Int -> BufferM (Int, Int)
forall a b. BufferM (a -> b) -> BufferM a -> BufferM b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> BufferM Int
curLn
res <- f
moveToLineColB l c
return res
pointAt :: BufferM a -> BufferM Point
pointAt :: forall a. BufferM a -> BufferM Point
pointAt BufferM a
f = BufferM Point -> BufferM Point
forall a. BufferM a -> BufferM a
savingPointB (BufferM a
f BufferM a -> BufferM Point -> BufferM Point
forall a b. BufferM a -> BufferM b -> BufferM b
forall (f :: * -> *) a b. Applicative f => f a -> f b -> f b
*> BufferM Point
pointB)
pointAfterCursorB :: Point -> BufferM Point
pointAfterCursorB :: Point -> BufferM Point
pointAfterCursorB Point
p = BufferM () -> BufferM Point
forall a. BufferM a -> BufferM Point
pointAt (BufferM () -> BufferM Point) -> BufferM () -> BufferM Point
forall a b. (a -> b) -> a -> b
$ do
Point -> BufferM ()
moveTo Point
p
BufferM ()
rightB
destinationOfMoveB :: BufferM a -> BufferM Point
destinationOfMoveB :: forall a. BufferM a -> BufferM Point
destinationOfMoveB BufferM a
f = BufferM Point -> BufferM Point
forall a. BufferM a -> BufferM a
savingPointB (BufferM a
f BufferM a -> BufferM Point -> BufferM Point
forall a b. BufferM a -> BufferM b -> BufferM b
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> BufferM Point
pointB)
askWindow :: (Window -> a) -> BufferM a
askWindow :: forall a. (Window -> a) -> BufferM a
askWindow = (Window -> a) -> BufferM a
forall r (m :: * -> *) a. MonadReader r m => (r -> a) -> m a
asks
withEveryLineB :: BufferM () -> BufferM ()
withEveryLineB :: BufferM () -> BufferM ()
withEveryLineB BufferM ()
action = BufferM () -> BufferM ()
forall a. BufferM a -> BufferM a
savingPointB (BufferM () -> BufferM ()) -> BufferM () -> BufferM ()
forall a b. (a -> b) -> a -> b
$ do
lineCount <- BufferM Int
lineCountB
forM_ [1 .. lineCount] $ \Int
l -> do
BufferM Int -> BufferM ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (BufferM Int -> BufferM ()) -> BufferM Int -> BufferM ()
forall a b. (a -> b) -> a -> b
$ Int -> BufferM Int
gotoLn Int
l
BufferM ()
action
makeLensesWithSuffix "A" ''IndentSettings