Community
    • Login

    Control symbols now inserted on macro

    Scheduled Pinned Locked Moved Help wanted · · · – – – · · ·
    27 Posts 6 Posters 2.8k 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.
    • OasisInDesertO
      OasisInDesert @PeterJones
      last edited by

      @PeterJones Thanks for reproducing and confirming weird behavior.

      1 Reply Last reply Reply Quote 1
      • OasisInDesertO
        OasisInDesert
        last edited by OasisInDesert

        I’ve created the topic on the issue, it is available here:
        https://github.com/notepad-plus-plus/notepad-plus-plus/issues/7642

        1 Reply Last reply Reply Quote 2
        • guy038G
          guy038
          last edited by guy038

          Hello, @oasisindesert and All,

          Why don’t you use the Microsoft Alt Numpad input method ? Refer below :

          https://en.wikipedia.org/wiki/Alt_code

          For instance, as I’m French, my default ANSI Windows code-page is Windows-1252. Now, using the Edit > Control Panel feature, of N++, it’s easy to notice that the Horizontal Ellipsis character ( …) has the hexadecimal code 85, so the decimal value 133.

          Thus, to write this character, at any time, simply :

          • Press the Alt key ( at left of the Space key )

          • Press, successively keys 0, 1 , 3 and 3 on the numeric keypad, while keeping the Alt key pressed

          • As soon as the Alt key is released, a … character will automatically be inserted, in your text, at cursor position ;-))

          It is very important to point out that the first key to press must be the 0 key !

          Indeed, if you just press, successively, on the three keys 1 , 3 and 3, a character is inserted, as well, but, this time, it represents the character, with same hexadecimal code, of the DOS OEM code page, which is the CP850 Latin-1 code page, in Western countries !


          The nice thing is that I could record a macro, with the same shortcut ( Ctrl + Alt + . ), by doing the following operations :

          • Click on Macro > Start recording

          • Hold down the Alt key

          • Press, successively, on keys 0, 1 , 3 and 3, of the numeric keypad

          • Release the Alt key

          • Click on Macro > Stop recording

          • Click on Macro > Save Currently Recorded macro

          • Enter “Tri-dot char” as macro’s name

          • Check, both, the CTRL and ALT boxes

          • Select the . item, in the drop-down list

          • Click on the OK button to valid all the changes

          • Preferably, stop and restart Notepad++, in order that this new macro is saved in the Shortcuts.xml file

          I obtained the macro, below, which seems strictly identical to yours !?

                  <Macro name="Tri-Dot char" Ctrl="yes" Alt="yes" Shift="no" Key="190">
                      <Action type="1" message="2170" wParam="0" lParam="0" sParam="&#x2026;" />
                  </Macro>
          

          However, I did not notice any problem, even when hitting , repeatedly, on the macro shortcut ;-)) For instance, I wrote a single line of 200 *ellipsis chars, about, , without any additional control character ! So, how did you record your own macro ?

          May be, it would be interesting to verify your “keyboard speed” In a DOS console window, type mode con rate=32 delay=0 and then, verify, with the command mode con that the values of repetition frequency and delay before repetition are as expected :-)

          Just an idea !

          Best Regards,

          guy038

          Alan KilbornA 1 Reply Last reply Reply Quote 2
          • Alan KilbornA
            Alan Kilborn @guy038
            last edited by Alan Kilborn

            @guy038

            As always, you provided good information, but unfortunately, I don’t think any of it helps the OP in any way with his original problem. :-)

            Regarding the “alt+numpad” method of entry of such characters, what does one do if their keyboard does not have a number pad (like mine)? :-)

            I tried to duplicate the OP’s problem, and I could do it. I then fired up Notepad++ under the Visual Studio debugger…and sadly it worked fine when I ran it that way. :-(

            1 Reply Last reply Reply Quote 2
            • PeterJonesP
              PeterJones
              last edited by

              @guy038 ,

              I tried (with fresh v7.8.1-64 zip, windows 10) to copy/paste your macro into shortcuts.xml (and reload – not shown), and tried running that macro; still shows the bug. Then I tried to record the macro using the ALT+0133, then playing back that macro: it does the same thing. As I experimented with earlier, the macro works just fine in v7.7.1.

              imgur

              So, if you’re good at the ALT+#### keysequences, and can remember it, and have a keypad, that’a a valid alternative for a single macro that only inserts the ellipsis. But if any of those conditions aren’t met (including if the ellipsis entry is just part of a larger macro), then the bug in v7.8.1 can insert extra characters (whatever happens to be after that ellipsis in random memory, it appears, because the extra chars change with each program load)

              1 Reply Last reply Reply Quote 2
              • guy038G
                guy038
                last edited by guy038

                Hi, @oasisindesert, @peterjones and @alan-kilborn,

                I did some other tests, including a short text before and after the ellipsis character and… everything still went right !?

                So, Peter, if you don’t mind, I’m going to e-mail you a zip file contening the macro in the shortcuts.xml file and all the minimum amount of files, needed for the N++ 7.8.1 version 32 bits :-))

                This zip file, named N++_781.zip ( 1,85 Mb ), contains the following elements ( minimum required ) :

                    File Name               Path                    Size       Date Modified
                  ----------------------------------------------------------------------------
                    change.log              N++_781                 2,786       12/11/2019
                    config.xml              N++_781                 5,218       28/11/2019
                    contextMenu.xml         N++_781                 3,512       25/05/2018
                    doLocalConf.xml         N++_781                     0       16/08/2017
                    langs.model.xml         N++_781               336,651       27/09/2019
                    notepad++.exe           N++_781             2,860,176       27/10/2019
                    readme.txt              N++_781                 1,450       26/12/2016
                    SciLexer.dll            N++_781             1,264,784       27/10/2019
                    session.xml             N++_781                   656       28/11/2019
                    shortcuts.xml           N++_781                 1,909       28/11/2019
                    stylers.model.xml       N++_781               168,547       27/09/2019
                    
                    autoCompletion          N++_781                     0       28/11/2019
                    
                    localization            N++_781                     0       28/11/2019
                    english.xml             N++_781\localization   76,503       23/10/2019
                    
                    plugins                 N++_781                     0       28/11/2019
                    Config                  N++_781\plugins             0       28/11/2019
                    
                    themes                  N++_781                     0       28/11/2019
                    updater                 N++_781                     0       28/11/2019
                    userDefineLangs         N++_781                     0       28/11/2019
                  ----------------------------------------------------------------------------
                    Total                                       4,722,192 Bytes
                  ----------------------------------------------------------------------------
                

                So, Peter :

                • Extract all contents of the N++_781.zip archive, let’s say,; on your destop

                • Double click on the extracted N++_781 folder

                • Rename the Notepad++.guy file as Notepad++.exe     ( Step added the next day : see below for explanations ! )

                • Double click on Notepad++.exe ( 32 bits version )

                • In any already opened file or a new file, just hit the Ctrl + Alt + . shortcut to activate the Ellipsis macro

                => Any shortcut hit writes the string ATGC…ATGC, preceded and followed with a space char, without any problem !


                Now, Alan and @oasisindesert, if you would test my archive file, just e-mail me a short message to :

                Best regards

                guy038

                1 Reply Last reply Reply Quote 0
                • guy038G
                  guy038
                  last edited by

                  Hi, @oasisindesert, @peterjones and @alan-kilborn,

                  I should have tried to e-mail my zip file first, because while sending to Peter, I got the message :

                  The message was blocked because its content presents a potential 5.7.0 security issue ?!

                  I even tried to rename the N++_781.zip as N++_781.guy, but no chance, either :-(


                  Now, may be this behavior only happens with a x64 version ? I’m really not convinced !

                  BR

                  guy038

                  1 Reply Last reply Reply Quote 0
                  • guy038G
                    guy038
                    last edited by

                    Hi, @oasisindesert, @peterjones and @alan-kilborn,

                    This morning, an idea popped up in my brain ! Why don’t I try to rename notepad++.exe as notepad++.guy, in the N++_781.zip archive ?

                    Bingo ! This time, this attached archive was accepted ;-)) So, Peter, just an additional step to do :

                    • Once you have opened the N++_781 folder, rename the notepad++.guy file as notepad++.exe

                    You should be able to test my version !

                    Cheers,

                    guy038

                    1 Reply Last reply Reply Quote 0
                    • PeterJonesP
                      PeterJones
                      last edited by

                      @guy038 said in Control symbols now inserted on macro:

                      Now, may be this behavior only happens with a x64 version ? I’m really not convinced !

                      I am convinced.

                      With either the npp 7.8.1 32-bit portable that Guy sent me, or a fresh zip copy from the download page, the 32-bit works with either the pre-packaged shortcuts.xml that Guy sent, or doing a new macro recording of ALT+0133. If I take that exact same shortcuts.xml, and copy it into a fresh unzip of v7.8.1-64bit, the macro shows the bug we’ve been describing.

                      Looking at issue#7642, it appears that @xylographe agrees that it happens on 64-bit and not 32-bit, but @rddim doesn’t see it on 64-bit on Win7. Mine is Win 10. So it might be a 64-bit Win10-only instance of the bug. Wow.

                      1 Reply Last reply Reply Quote 1
                      • EkopalypseE
                        Ekopalypse
                        last edited by

                        Might be an ANSI vs. unicode related issue as well?

                        1 Reply Last reply Reply Quote 2
                        • PeterJonesP
                          PeterJones
                          last edited by

                          @Ekopalypse said in Control symbols now inserted on macro:

                          Might be an ANSI vs. unicode related issue as well?

                          Brilliant.

                          I just took Guy’s edition, and ran his macro once in a new file with Encoding > ANSI set, and it worked as Guy described. Then I made a new file, set Encoding > UTF-8, and the bug showed itself – same load of the program, same shortcuts.xml.

                          1 Reply Last reply Reply Quote 2
                          • guy038G
                            guy038
                            last edited by

                            Hi, @oasisindesert, @peterjones, @alan-kilborn, @ekopalypse and all

                            Peter, by rereading your last post, this morning, you said :

                            I just took Guy’s edition, and ran his macro once in a new file with Encoding > ANSI set, and it worked as Guy described. Then I made a new file, set Encoding > UTF-8, and the bug showed itself – same load of the program, same shortcuts.xml.

                            May be, I’m missing something obvious !


                            Opening N++ with the archive that I sent you, the default encoding of new 1 is UTF-8

                            But, after numerous tests, using, first, any option of the Encoding menu and, even, the options Encoding > Character Set > ... > from Windows-1250 to Windows-1258, which stand for the main ANSI encodings, then running the macro, I’ve never noticed any control character wrongly inserted !?

                            So, I suppose that the main point is to have an old 32-bit operating system and, therefore, to use the 32 bits version of N++, as well. In that case, the bug never seems to be happening !

                            Best Regards

                            guy038

                            1 Reply Last reply Reply Quote 1
                            • EkopalypseE
                              Ekopalypse
                              last edited by

                              So, to summarize, the current state is that

                              32bit version is not affected at all
                              64bit version works with document codec set to one of the 8bit encodings
                              and the troublesome is
                              64bit version with documents having unicode encoding.

                              Which leads to the assumption that macros working on a unicode text
                              with 64bit npp version has a bug.

                              PeterJonesP 1 Reply Last reply Reply Quote 1
                              • PeterJonesP
                                PeterJones @Ekopalypse
                                last edited by

                                @Ekopalypse said in Control symbols now inserted on macro:

                                32bit version is not affected at all

                                I disagree. As described above, by manually setting the Encoding > UTF-8 toggle, I replicated the bug in 7.8.1-32bit

                                1 Reply Last reply Reply Quote 1
                                • EkopalypseE
                                  Ekopalypse
                                  last edited by

                                  Not sure if this is helpful in this case but using
                                  Linux and Wine I don’t see the problem on a 64bit version at all.

                                  Notepad++ v7.8.1 (64-bit)
                                  Build time : Oct 27 2019 - 22:57:19
                                  Path : Z:\home…\notepad-plus-plus\notepad-plus-plus.exe
                                  Admin mode : ON
                                  Local Conf mode : ON
                                  OS Name : Microsoft Windows 7 (64-bit)
                                  OS Build : 7601.0
                                  WINE : 3.0.4
                                  Plugins : mimeTools.dll NppConverter.dll NppExport.dll

                                  5f1c8e7f-0399-4e67-9d38-f022b838cf5e-image.png

                                  1 Reply Last reply Reply Quote 2
                                  • PeterJonesP
                                    PeterJones
                                    last edited by

                                    @Ekopalypse : weird.

                                    To re-confirm what I said earlier today, here’s a screenshot of the bug in action in NPP-32bit on Win10-64bit, showing encoding-dependency:

                                    • @PeterJones: With both 7.8.1-64bit and 7.8.1-32bit on 64bit Win10 Home 1903 18362.476,
                                      • Shows with Encoding > UTF-8 but not with Encoding > ANSI
                                    • @guy038: In WinXP 32bit (@guy038), 7.8.1-32bit, it appears to not show the bug
                                    • @Ekopalypse: In Linux WINE 3.0.4 with Guest=Win7-64bit 7601.0, NPP 7.8.1-64bit, the bug does not show in either UTF-8 or ANSI

                                    Strange bug.

                                    PeterJonesP EkopalypseE 2 Replies Last reply Reply Quote 3
                                    • PeterJonesP
                                      PeterJones @PeterJones
                                      last edited by

                                      updated https://github.com/notepad-plus-plus/notepad-plus-plus/issues/7642 with the new screenshot and the summary of my experiments, @guy038 results, and @Ekopalypse results (ie, basically, copied my last post to github issue)

                                      1 Reply Last reply Reply Quote 3
                                      • EkopalypseE
                                        Ekopalypse @PeterJones
                                        last edited by

                                        @PeterJones

                                        agreed - very strange. I’m wondering if XP and Wine share the same code
                                        for the needed functionality is this case.
                                        Would make some sense. Maybe some older unicode library or different than W7 and W10.
                                        I thought about it for some time now, but I don’t see
                                        how to start on this to track down the bug.

                                        andrecool-68A 1 Reply Last reply Reply Quote 2
                                        • andrecool-68A
                                          andrecool-68 @Ekopalypse
                                          last edited by

                                          @Ekopalypse There has been a problem with the definition of encodings for a very long time, sometimes it is solved but partially))
                                          And then a new surprise appears with encodings))

                                          EkopalypseE 1 Reply Last reply Reply Quote 1
                                          • EkopalypseE
                                            Ekopalypse @andrecool-68
                                            last edited by

                                            @andrecool-68 said in Control symbols now inserted on macro:

                                            There has been a problem with the definition of encodings for a very long time

                                            :-) I agree but it has reached a new level I would say. :-(
                                            I can live with limitation if I understand why their are,
                                            but fishing in the dark for understanding drives me mad.

                                            andrecool-68A 1 Reply Last reply Reply Quote 2
                                            • First post
                                              Last post
                                            The Community of users of the Notepad++ text editor.
                                            Powered by NodeBB | Contributors