• Login
Community
  • Login

Using Mark (Markers) and Styles

Scheduled Pinned Locked Moved Help wanted · · · – – – · · ·
34 Posts 6 Posters 20.1k Views
Loading More Posts
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • A
    Alan Kilborn
    last edited by Jun 7, 2021, 8:45 PM

    I thought of another bit of a downside to hiding lines:
    If you switch away from the tab in which you’ve hidden lines (via script), when you return to that tab, all the lines become visible again.

    That makes for an easy way to make lines visible again in a simple demo, but in a real application the code would have to handle that situation reasonably, which makes the code much more complicated.

    Here’s a simple demo for only showing lines with hits and two lines before and three lines after:

    # -*- coding: utf-8 -*-
    from __future__ import print_function
    
    from Npp import editor, notepad
    
    # Notepad++'s style numbers:
    #  25 = Style #1
    #  24 = Style #2
    #  23 = Style #3
    #  22 = Style #4
    #  21 = Style #5
    
    class T_21275a(object):
    
        def __init__(self):
            lines_above = 2
            lines_below = 3
            search_input = notepad.prompt('Enter search string:', '', '')
            if search_input == None or len(search_input) == 0: return
            matches = []
            editor.search(search_input, lambda m: matches.append(m.span(0)))
            if len(matches) > 0:
                color_input = notepad.prompt('Enter style color number (1-5):', '', '')
                try:
                    color_input = int(color_input)
                except ValueError:
                    return
                if 1 <= color_input <= 5:
                    color_input -= 1
                    editor.hideLines(1, editor.getLineCount() - 1)
                    for (match_start_pos, match_end_pos) in matches:
                        editor.setIndicatorCurrent(25 - color_input)
                        editor.indicatorFillRange(match_start_pos, match_end_pos - match_start_pos)
                        match_start_line = editor.lineFromPosition(match_start_pos)
                        match_end_line = editor.lineFromPosition(match_end_pos)
                        show_start_line = match_start_line - lines_above
                        if show_start_line < 1: show_start_line = 1
                        show_end_line = match_end_line + lines_below
                        if show_end_line > editor.getLineCount() - 1: show_end_line = editor.getLineCount() - 1
                        editor.showLines(show_start_line, show_end_line)
    
    if __name__ == '__main__': T_21275a()
    
    1 Reply Last reply Reply Quote 2
    • A
      Alan Kilborn @Sridhar Raghavan
      last edited by Jun 7, 2021, 8:48 PM

      @Sridhar-Raghavan said in Using Mark (Markers) and Styles:

      unless Scripting is done carefully, one may easily break the consistencies ensured rigorously in the core code.

      Well, to be honest, I think in the core code the hidden line feature is just not that good. So much for the need for “consistencies ensured rigorously”. :-)

      And, strangely, in all of the forum postings here, hiding and showing lines again is very rarely discussed. Probably, because in Notepad++ the feature is very basic as I described earlier.

      A 1 Reply Last reply Jun 7, 2021, 9:08 PM Reply Quote 2
      • A
        Alan Kilborn @Alan Kilborn
        last edited by Alan Kilborn Jun 7, 2021, 9:08 PM Jun 7, 2021, 9:08 PM

        @Alan-Kilborn said in Using Mark (Markers) and Styles:

        I think in the core code the hidden line feature is just not that good

        As an example, it is easy to get the UI out of sync just using the built-in features (no scripting).

        Example:

        Start with text:

        one
        two
        three
        four
        five
        six
        seven
        eight
        nine
        ten
        

        Make a selection of some lines:

        7d1b8e7d-3b23-4cf9-a08a-e36bf12f21cb-image.png

        Right-click that selection and pick Hide Lines to obtain:

        b1f41544-63c7-45aa-9258-5087ba51078e-image.png

        Make another selection, like so:

        b30efab0-2fb3-4a13-93ff-95d52c414754-image.png

        Right-click that selection and pick Hide Lines to obtain:

        62fa30c0-990a-4d46-87bc-2cd9f3a75866-image.png

        Left-click the green arrow in the margin on line 2.
        This seems like it should expand the text back to a no-lines-hidden state, or perhaps the previous state where lines 5, 6 and 7 were the only hidden ones.
        But what we get is:

        d98da195-f284-46a5-ae01-8a42b60dd8bf-image.png

        So we do get the state where lines 5, 6 and 7 are the hidden ones.
        But…there’s no way to ever unhide them (well, switching tabs and back does it!)
        There’s no right-pointing green arrow, and clicking on the left-pointing arrow does nothing.

        So the conclusion is that this feature is broken (if I can break it so easily).

        V 3 Replies Last reply Aug 9, 2023, 2:17 AM Reply Quote 1
        • S
          Sridhar Raghavan
          last edited by Jun 7, 2021, 9:12 PM

          Thanks Alan for that tip. I would have never found it by trying things (hoping for the hidden commands!). That gets me going now.

          Thanks for the quick work on the code for the “windowed” display. Great.

          I think your code with additional check boxes and drop downs is rapidly getting to becoming a good plugin!!

          It was a general experiential statement on my part that APIs and Scripting languages are after-thought add-ons, done with less rigor. But not always the case, including the example you cite.

          br Sri.

          1 Reply Last reply Reply Quote 2
          • G
            guy038
            last edited by Jun 8, 2021, 12:13 PM

            Hi, @sridhar-raghavan, @alan-kilborn and All,

            Just tried your second version, using 1 line before hit and 1 line after it. Interesting, indeed, with the “Hide Lines” mechanism. Just enable the line number margin !

            Of course, as soon as you switch to another tab and switch back to your file, all the hidden lines appear again !


            Now, I thought about two improvements. But, Alan, they are just suggestions and ONLY IF @sridhar-raghavan would need it, too !

            • By default, the Python search is sensible to case et does not care about the whole word notion. So, could it possible to search for any case and to search for whole words only ?

            • I thought that you could also enter all the parameters in an unique prompt window !

            • With double quotes to surround expressions containing space characters

            • With inside a couple of parentheses :

              • w would mean Word only

              • i would mean Ignore case

              • r would mean Remove all styles

              • # would mean Style #

            When absent, each parameter would be supposed to be the default present Python script behavior !


            So, for instance, the text License (rw5) software (i3) "GNU GENERAL PUBLIC LICENSE" (iw43) would mean :

            • Remove all styles first

            • Highlight any word License, with this exact case, in style 5

            • Highlight any string software, whatever its case, in style 3

            • Highlight any exact expression GNU GENERAL PUBLIC LICENSE, whatever its case, in style 4 AND in style 3, too

            Best Regards,

            guy038

            A 1 Reply Last reply Jun 8, 2021, 12:20 PM Reply Quote 0
            • A
              Alan Kilborn @guy038
              last edited by Jun 8, 2021, 12:20 PM

              @guy038 said in Using Mark (Markers) and Styles:

              Of course, as soon as you switch to another tab and switch back to your file, all the hidden lines appear again !

              Yes, this limitation was mentioned earlier.
              It can be avoided with more code, but as this was just intended to be a demo to show @Sridhar-Raghavan the possibilities of scripting, I didn’t do it.

              Regarding other changes: Yes, with scripting the possibilities are limitless! :-)

              1 Reply Last reply Reply Quote 1
              • V
                Victorel Petrovich @Alan Kilborn
                last edited by Aug 9, 2023, 2:17 AM

                @Alan-Kilborn said in Using Mark (Markers) and Styles:

                But…there’s no way to ever unhide them (well, switching tabs and back does it!)
                There’s no right-pointing green arrow, and clicking on the left-pointing arrow does nothing.
                So the conclusion is that this feature is broken (if I can break it so easily).

                Maybe you already know, as > 2 years passed, but if not: I could not reproduce that bug, so I guess it’s been fixed.

                A 1 Reply Last reply Aug 9, 2023, 11:03 AM Reply Quote 0
                • A
                  Alan Kilborn @Victorel Petrovich
                  last edited by Aug 9, 2023, 11:03 AM

                  @Victorel-Petrovich said in Using Mark (Markers) and Styles:

                  Maybe you already know, as > 2 years passed, but if not: I could not reproduce that bug, so I guess it’s been fixed.

                  Not sure what you mean has been fixed…

                  1 Reply Last reply Reply Quote 0
                  • V
                    Victorel Petrovich @Alan Kilborn
                    last edited by Victorel Petrovich Aug 9, 2023, 2:35 PM Aug 9, 2023, 2:34 PM

                    This post is deleted!
                    1 Reply Last reply Reply Quote 0
                    • V
                      Victorel Petrovich @Alan Kilborn
                      last edited by Aug 9, 2023, 2:38 PM

                      @Alan-Kilborn , the bug in your message above:

                      As an example, it is easy to get the UI out of sync just using the built-in features (no scripting).

                      Example:

                      Start with text:

                      one
                      two
                      three
                      four
                      five
                      six
                      seven
                      eight
                      nine
                      ten
                      

                      Make a selection of some lines:

                      7d1b8e7d-3b23-4cf9-a08a-e36bf12f21cb-image.png

                      Right-click that selection and pick Hide Lines to obtain:

                      b1f41544-63c7-45aa-9258-5087ba51078e-image.png

                      Make another selection, like so:

                      b30efab0-2fb3-4a13-93ff-95d52c414754-image.png

                      Right-click that selection and pick Hide Lines to obtain:

                      62fa30c0-990a-4d46-87bc-2cd9f3a75866-image.png

                      Left-click the green arrow in the margin on line 2.
                      This seems like it should expand the text back to a no-lines-hidden state, or perhaps the previous state where lines 5, 6 and 7 were the only hidden ones.
                      But what we get is:

                      d98da195-f284-46a5-ae01-8a42b60dd8bf-image.png

                      So we do get the state where lines 5, 6 and 7 are the hidden ones.
                      But…there’s no way to ever unhide them (well, switching tabs and back does it!)
                      There’s no right-pointing green arrow, and clicking on the left-pointing arrow does nothing.

                      So the conclusion is that this feature is broken (if I can break it so easily).

                      A 1 Reply Last reply Aug 9, 2023, 2:41 PM Reply Quote 0
                      • A
                        Alan Kilborn @Victorel Petrovich
                        last edited by Alan Kilborn Aug 9, 2023, 2:42 PM Aug 9, 2023, 2:41 PM

                        @Victorel-Petrovich said in Using Mark (Markers) and Styles:

                        the conclusion is that this feature is broken (if I can break it so easily).

                        it is easy to get the UI out of sync just using the built-in features (no scripting).

                        Ah, OK – I thought you meant something with the script.
                        Yes, the feature is very broken, for many reasons.
                        This has long been known.

                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post
                        The Community of users of the Notepad++ text editor.
                        Powered by NodeBB | Contributors