Script 'mail_helper' called by obssrc
Hello community,

here is the log from the commit of package ghc-text-zipper for openSUSE:Factory 
checked in at 2021-01-20 18:24:54
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/ghc-text-zipper (Old)
 and      /work/SRC/openSUSE:Factory/.ghc-text-zipper.new.28504 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "ghc-text-zipper"

Wed Jan 20 18:24:54 2021 rev:4 rq:862333 version:0.11

Changes:
--------
--- /work/SRC/openSUSE:Factory/ghc-text-zipper/ghc-text-zipper.changes  
2020-12-22 11:47:22.297906720 +0100
+++ 
/work/SRC/openSUSE:Factory/.ghc-text-zipper.new.28504/ghc-text-zipper.changes   
    2021-01-20 18:25:29.099407063 +0100
@@ -1,0 +2,11 @@
+Mon Jan  4 11:06:31 UTC 2021 - [email protected]
+
+- Update text-zipper to version 0.11.
+  0.11
+  ----
+
+  API changes:
+   * Added `gotoBOF`, `gotoEOF`, `killToBOF`, and `killToEOF` functions
+     (thanks Itai Y. Efrat)
+
+-------------------------------------------------------------------

Old:
----
  text-zipper-0.10.1.tar.gz

New:
----
  text-zipper-0.11.tar.gz

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ ghc-text-zipper.spec ++++++
--- /var/tmp/diff_new_pack.W7PYX4/_old  2021-01-20 18:25:30.751408636 +0100
+++ /var/tmp/diff_new_pack.W7PYX4/_new  2021-01-20 18:25:30.755408640 +0100
@@ -1,7 +1,7 @@
 #
 # spec file for package ghc-text-zipper
 #
-# Copyright (c) 2020 SUSE LLC
+# Copyright (c) 2021 SUSE LLC
 #
 # All modifications and additions to the file contributed by third parties
 # remain the property of their copyright owners, unless otherwise agreed
@@ -19,7 +19,7 @@
 %global pkg_name text-zipper
 %bcond_with tests
 Name:           ghc-%{pkg_name}
-Version:        0.10.1
+Version:        0.11
 Release:        0
 Summary:        A text editor zipper library
 License:        BSD-3-Clause

++++++ text-zipper-0.10.1.tar.gz -> text-zipper-0.11.tar.gz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/text-zipper-0.10.1/CHANGELOG 
new/text-zipper-0.11/CHANGELOG
--- old/text-zipper-0.10.1/CHANGELOG    2017-09-10 01:07:04.000000000 +0200
+++ new/text-zipper-0.11/CHANGELOG      2001-09-09 03:46:40.000000000 +0200
@@ -1,4 +1,11 @@
 
+0.11
+----
+
+API changes:
+ * Added `gotoBOF`, `gotoEOF`, `killToBOF`, and `killToEOF` functions
+   (thanks Itai Y. Efrat)
+
 0.10.1
 ------
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/text-zipper-0.10.1/src/Data/Text/Zipper.hs 
new/text-zipper-0.11/src/Data/Text/Zipper.hs
--- old/text-zipper-0.10.1/src/Data/Text/Zipper.hs      2017-09-10 
01:07:04.000000000 +0200
+++ new/text-zipper-0.11/src/Data/Text/Zipper.hs        2001-09-09 
03:46:40.000000000 +0200
@@ -1,19 +1,19 @@
--- |This module provides a two-dimensional text zipper data structure.
+-- | This module provides a two-dimensional text zipper data structure.
 -- This structure represents a body of text and an editing cursor
 -- which can be moved throughout the text, along with a set of editing
 -- transformations.
 --
--- Text zippers are generalized over the set of data types that might
--- be used to store lists of characters (e.g., 'String', 'T.Text',
--- etc.).  As a result, the most general way to create a text zipper
--- is to use 'mkZipper' and provide all of the functions required to
--- manipulate the underlying text data.
+-- Text zippers are generalized over the set of data types that might be
+-- used to store lists of characters (e.g., 'String', 'T.Text', etc.).
+-- As a result, the most general way to create a text zipper is to use
+-- 'mkZipper' and provide all of the functions required to manipulate
+-- the underlying text data.
 --
 -- Implementations using 'T.Text' and 'String' are provided.
 module Data.Text.Zipper
     ( TextZipper
 
-    -- *Construction and extraction
+    -- * Construction and extraction
     , mkZipper
     , textZipper
     , stringZipper
@@ -25,7 +25,7 @@
     , lineLengths
     , getLineLimit
 
-    -- *Navigation functions
+    -- * Navigation functions
     , moveCursor
     , moveRight
     , moveLeft
@@ -33,13 +33,15 @@
     , moveDown
     , gotoEOL
     , gotoBOL
+    , gotoEOF
+    , gotoBOF
 
-    -- *Inspection functions
+    -- * Inspection functions
     , currentChar
     , nextChar
     , previousChar
 
-    -- *Editing functions
+    -- * Editing functions
     , insertChar
     , insertMany
     , deletePrevChar
@@ -47,6 +49,8 @@
     , breakLine
     , killToEOL
     , killToBOL
+    , killToEOF
+    , killToBOF
     , transposeChars
     )
 where
@@ -107,9 +111,9 @@
                      , " }"
                      ]
 
--- |Create a zipper using a custom text storage type.  Takes the
--- initial text as well as all of the functions necessary to
--- manipulate the underlying text values.
+-- | Create a zipper using a custom text storage type. Takes the initial
+-- text as well as all of the functions necessary to manipulate the
+-- underlying text values.
 mkZipper :: (Monoid a) =>
             (Char -> a)
          -- ^A singleton constructor.
@@ -143,31 +147,30 @@
                         else (head limitedLs, tail limitedLs)
     in TZ mempty first [] rest fromCh drp tk lngth lst int nl linesFunc 
toListF lmt
 
--- |Get the text contents of the zipper.
+-- | Get the text contents of the zipper.
 getText :: (Monoid a) => TextZipper a -> [a]
 getText tz = concat [ above tz
                     , [currentLine tz]
                     , below tz
                     ]
 
--- |Return the lengths of the lines in the zipper.
+-- | Return the lengths of the lines in the zipper.
 lineLengths :: (Monoid a) => TextZipper a -> [Int]
 lineLengths tz = (length_ tz) <$> concat [ above tz
                                          , [currentLine tz]
                                          , below tz
                                          ]
 
--- |Get the cursor position of the zipper; returns @(row, col)@.
+-- | Get the cursor position of the zipper; returns @(row, col)@.
 -- @row@ ranges from @[0..num_rows-1]@ inclusive; @col@ ranges from
--- @[0..length of current line]@ inclusive.  Column values equal to
--- line width indicate a cursor that is just past the end of a line of
--- text.
+-- @[0..length of current line]@ inclusive. Column values equal to line
+-- width indicate a cursor that is just past the end of a line of text.
 cursorPosition :: TextZipper a -> (Int, Int)
 cursorPosition tz = (length $ above tz, length_ tz $ toLeft tz)
 
--- |Move the cursor to the specified row and column.  Invalid cursor
--- positions will be ignored.  Valid cursor positions range as
--- described for 'cursorPosition'.
+-- | Move the cursor to the specified row and column. Invalid cursor
+-- positions will be ignored. Valid cursor positions range as described
+-- for 'cursorPosition'.
 moveCursor :: (Monoid a) => (Int, Int) -> TextZipper a -> TextZipper a
 moveCursor (row, col) tz =
     let t = getText tz
@@ -191,11 +194,11 @@
 nextLine :: TextZipper a -> a
 nextLine = head . below
 
--- |The line of text on which the zipper's cursor currently resides.
+-- | The line of text on which the zipper's cursor currently resides.
 currentLine :: (Monoid a) => TextZipper a -> a
 currentLine tz = (toLeft tz) `mappend` (toRight tz)
 
--- |Insert a character at the current cursor position.
+-- | Insert a character at the current cursor position.
 --
 -- If the character is a newline, break the current line.
 --
@@ -212,7 +215,7 @@
     | isPrint ch = Just $ tz { toLeft = toLeft tz `mappend` (fromChar tz ch) }
     | otherwise  = Nothing
 
--- |Insert many characters at the current cursor position. Move the
+-- | Insert many characters at the current cursor position. Move the
 -- cursor to the end of the inserted text.
 insertMany :: (Monoid a) => a -> TextZipper a -> TextZipper a
 insertMany str tz =
@@ -220,7 +223,7 @@
         go (c:cs) z = maybe z (go cs) $ insertChar_ c z
     in go (toList_ tz str) tz
 
--- |Insert a line break at the current cursor position.
+-- | Insert a line break at the current cursor position.
 breakLine :: (Monoid a) => TextZipper a -> TextZipper a
 breakLine tz = maybe tz id $ breakLine_ tz
 
@@ -238,14 +241,28 @@
                       else Just modified
           Nothing -> Just modified
 
--- |Move the cursor to the end of the current line.
+-- | Move the cursor to the end of the current line.
 gotoEOL :: (Monoid a) => TextZipper a -> TextZipper a
 gotoEOL tz = tz { toLeft = currentLine tz
                 , toRight = mempty
                 }
 
--- |Remove all text from the cursor position to the end of the current
--- line.  If the cursor is at the beginning of a line and the line is
+-- | Move the cursor to the end of a text zipper.
+gotoEOF :: (Monoid a) => TextZipper a -> TextZipper a
+gotoEOF tz =
+    tz { toLeft = end
+       , toRight = mempty
+       , above = top
+       , below = mempty
+       }
+   where
+       tx = getText tz
+       (top, end) = if null tx
+                    then (mempty, mempty)
+                    else (init tx, last tx)
+
+-- | Remove all text from the cursor position to the end of the current
+-- line. If the cursor is at the beginning of a line and the line is
 -- empty, the entire line will be removed.
 killToEOL :: (Monoid a) => TextZipper a -> TextZipper a
 killToEOL tz
@@ -257,21 +274,38 @@
     | otherwise = tz { toRight = mempty
                      }
 
--- |Remove all text from the cursor position to the beginning of the
+-- | Remove all text from the cursor position to the beginning of the
 -- current line.
 killToBOL :: Monoid a => TextZipper a -> TextZipper a
 killToBOL tz = tz { toLeft = mempty
                   }
 
--- |Delete the character preceding the cursor position, and move the
+-- | Remove all text from the cursor position to the end of the text
+-- zipper. If the cursor is at the beginning of a line and the line is
+-- empty, the entire line will be removed.
+killToEOF :: (Monoid a) => TextZipper a -> TextZipper a
+killToEOF tz =
+    tz { toRight = mempty
+       , below = mempty
+       }
+
+-- | Remove all text from the cursor position to the beginning of the
+-- text zipper.
+killToBOF :: Monoid a => TextZipper a -> TextZipper a
+killToBOF tz =
+    tz { toLeft = mempty
+       , above = mempty
+       }
+
+-- | Delete the character preceding the cursor position, and move the
 -- cursor backwards by one character.
 deletePrevChar :: (Eq a, Monoid a) => TextZipper a -> TextZipper a
 deletePrevChar tz
     | moveLeft tz == tz = tz
     | otherwise = deleteChar $ moveLeft tz
 
--- |Delete the character at the cursor position.  Leaves the cursor
--- position unchanged.  If the cursor is at the end of a line of text,
+-- | Delete the character at the cursor position. Leaves the cursor
+-- position unchanged. If the cursor is at the end of a line of text,
 -- this combines the line with the line below.
 deleteChar :: (Monoid a) => TextZipper a -> TextZipper a
 deleteChar tz
@@ -286,21 +320,21 @@
            }
     | otherwise = tz
 
--- |Get the Char on which the cursor currently resides. If the cursor is
--- at the end of the text or the text is empty return @Nothing@.
+-- | Get the Char on which the cursor currently resides. If the cursor
+-- is at the end of the text or the text is empty return @Nothing@.
 currentChar :: TextZipper a -> Maybe Char
 currentChar tz
   | not (null_ tz (toRight tz)) =
     Just (last_ tz (take_ tz 1 (toRight tz)))
   | otherwise = Nothing
 
--- |Get the Char after the cursor position. If the cursor is at the end
+-- | Get the Char after the cursor position. If the cursor is at the end
 -- of a line return the first character of the next line, or if that one
 -- is empty as well, return @Nothing@.
 nextChar :: (Monoid a) => TextZipper a -> Maybe Char
 nextChar tz = currentChar (moveRight tz)
 
--- |Get the Char before the cursor position. If the cursor is at the
+-- | Get the Char before the cursor position. If the cursor is at the
 -- beginning of the text, return @Nothing@
 previousChar :: (Monoid a) => TextZipper a -> Maybe Char
 previousChar tz
@@ -311,15 +345,29 @@
   | otherwise =
     currentChar (moveLeft tz)
 
--- |Move the cursor to the beginning of the current line.
+-- | Move the cursor to the beginning of the current line.
 gotoBOL :: (Monoid a) => TextZipper a -> TextZipper a
 gotoBOL tz = tz { toLeft = mempty
                 , toRight = currentLine tz
                 }
 
--- |Move the cursor right by one position.  If the cursor is at the
--- end of a line, the cursor is moved to the first position of the
--- following line (if any).
+-- | Move the cursor to the beginning of a text zipper.
+gotoBOF :: (Monoid a) => TextZipper a -> TextZipper a
+gotoBOF tz =
+    tz { toLeft = mempty
+       , toRight = first
+       , above = mempty
+       , below = rest
+       }
+    where
+        tx = getText tz
+        (first, rest) = if null tx
+                        then (mempty, mempty)
+                        else (head tx, tail tx)
+
+-- | Move the cursor right by one position. If the cursor is at the end
+-- of a line, the cursor is moved to the first position of the following
+-- line (if any).
 moveRight :: (Monoid a) => TextZipper a -> TextZipper a
 moveRight tz
     -- Are we able to keep moving right on the current line?
@@ -338,9 +386,9 @@
            }
     | otherwise = tz
 
--- |Move the cursor left by one position.  If the cursor is at the
--- beginning of a line, the cursor is moved to the last position of
--- the preceding line (if any).
+-- | Move the cursor left by one position. If the cursor is at the
+-- beginning of a line, the cursor is moved to the last position of the
+-- preceding line (if any).
 moveLeft :: (Monoid a) => TextZipper a -> TextZipper a
 moveLeft tz
     -- Are we able to keep moving left on the current line?
@@ -359,8 +407,8 @@
            }
     | otherwise = tz
 
--- |Move the cursor up by one row.  If there no are rows above the
--- current one, move to the first position of the current row.  If the
+-- | Move the cursor up by one row. If there no are rows above the
+-- current one, move to the first position of the current row. If the
 -- row above is shorter, move to the end of that row.
 moveUp :: (Monoid a) => TextZipper a -> TextZipper a
 moveUp tz
@@ -382,9 +430,9 @@
     -- If nothing else, go to the beginning of the current line
     | otherwise = gotoBOL tz
 
--- |Move the cursor down by one row.  If there are no rows below the
--- current one, move to the last position of the current row.  If the
--- row below is shorter, move to the end of that row.
+-- | Move the cursor down by one row. If there are no rows below the
+-- current one, move to the last position of the current row. If the row
+-- below is shorter, move to the end of that row.
 moveDown :: (Monoid a) => TextZipper a -> TextZipper a
 moveDown tz
     -- Is there a line below at least as long as the current one?
@@ -428,17 +476,17 @@
                      , toRight = (drop_ tz 1 $ toRight tz)
                      }
 
--- |Construct a zipper from list values.
+-- | Construct a zipper from list values.
 stringZipper :: [String] -> Maybe Int -> TextZipper String
 stringZipper =
     mkZipper (:[]) drop take length last init null lines id
 
--- |Construct a zipper from vectors of characters.
+-- | Construct a zipper from vectors of characters.
 vectorZipper :: [V.Vector Char] -> Maybe Int -> TextZipper (V.Vector Char)
 vectorZipper =
     mkZipper V.singleton V.drop V.take V.length V.last V.init V.null 
V.vecLines V.toList
 
--- |Empty a zipper.
+-- | Empty a zipper.
 clearZipper :: (Monoid a) => TextZipper a -> TextZipper a
 clearZipper tz =
     tz { toLeft = mempty
@@ -447,7 +495,7 @@
        , below = []
        }
 
--- |Construct a zipper from 'T.Text' values.
+-- | Construct a zipper from 'T.Text' values.
 textZipper :: [T.Text] -> Maybe Int -> TextZipper T.Text
 textZipper =
     mkZipper T.singleton T.drop T.take T.length T.last T.init T.null T.lines 
T.unpack
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/text-zipper-0.10.1/text-zipper.cabal 
new/text-zipper-0.11/text-zipper.cabal
--- old/text-zipper-0.10.1/text-zipper.cabal    2017-09-10 01:07:04.000000000 
+0200
+++ new/text-zipper-0.11/text-zipper.cabal      2001-09-09 03:46:40.000000000 
+0200
@@ -1,5 +1,5 @@
 name:                text-zipper
-version:             0.10.1
+version:             0.11
 synopsis:            A text editor zipper library
 description:         This library provides a zipper and API for editing text.
 license:             BSD3

Reply via email to