Community
    • Login

    Compare Plugin - Unable to turn off Synchronize Vertical Scrolling Version 7.6.6 with Compare V2

    Scheduled Pinned Locked Moved Help wanted · · · – – – · · ·
    38 Posts 9 Posters 16.5k 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.
    • Jeff MillerJ
      Jeff Miller
      last edited by

      So is there something that works similar to the Compare prior to Version 2 that can be used as a Plugin, or do we consider this effectively end of life for the Product, if you need to use the old Compare Plugin?

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

        @Jeff-Miller,

        There are plenty of solutions for you.

        1. Use old version of Notepad++ and old version of Compare Plugin
        2. Use new version of Notepad++ and manually install old version of Compare Plugin. (This might not work if you’re using 64-bit Notepad++… I don’t know if the old version of Compare Plugin had 64-bit version.)
        3. Use different software.
          • If you’ve already got TortoiseGit or TortoiseSVN, it’s diff utility is pretty good
          • I know that gvimdiff perpetually gets me out of sync in the two windows that I’m comparing, especially when I don’t want it to, so I assume that one could eventually learn how to keep it in sync when desired, and break the sync when desired.
        4. Put in a feature request on the Compare Plugin Issues Page – since @pnedev is the lead over there, he actually already knows you want that feature. You might want to talk nice to him here before doing that. I bet if you were to kindly and politely request the feature, and explain a use case for wanting to be able to temporarily break the sync, he would either take it under consideration as a feature for a future release, or be willing to explain the technical reasons .

        -----

        Personally, @pnedev, I can see a use case for breaking the sync. There are times, especially with a lot of changes between files, that the “real” lines it should be comparing are quite a ways down the document from where the diff thinks the comparison should be; often by breaking the sync and scrolling down, I am able to line things back up in my mind, and figure out how to do the edits (even if just inserting blank lines in one side or the other of the compare). I tried to come up with a short example of two files that would do it, but it wouldn’t show the issue… I run across that in the linux world a lot (and my gvimdiff hyperbole is exaggerated from my real-world experience of accidentally breaking the link when I want it synced, and having trouble breaking the link when I want to peak ahead on one side or the other.) Is there a technical reason that the vertical scroll sync was made fixed for v2, or had you/the-others just not thought of a use case for non-synced diff?

        1 Reply Last reply Reply Quote 3
        • Jeff MillerJ
          Jeff Miller
          last edited by

          Thanks for the Suggestion.
          Use Case for How we have been using the Compare Function.
          In the product we support we use the Compare Function to Customize the ERP Package, to a specific Customer’s needs.
          The Source Code is Based upon java.
          Event Driven Actions called “Stanza’s” which are represented as sections that begin with
          [[MODULE.ACTION]]
          This comes out of a Rapid Development System which then compiles this into a more concise form that ends up being executed in Java.
          What we do not have control of is the specific presence or lack of an action, but within specific subsections we may do a lot of Cutting and Pasting.
          The two Attached files are the same Program Source. One in its original un-modified form, and the other in a modified form for a customer.
          Areas of Differences within a Stanza may be more than 30 Lines, but it is a case of simply not
          using them in one version, but comparing only those parts that are similar to fix things, then doing Cut and Paste to merge things within a Stanza.
          This has been easy to do by doing the Compare.
          Breaking the Sync.
          Aligning on a Stanza Declaration.
          Then re-establishing the Vertical Sync at that point.
          The Entire File itself is not the object of our Edits, rather the sub-sections within.

          I am not sure how to directly Attach Code Samples.
          Original Version:

          [[OPE_ORDHDR.ADIS]]
          rem --- Check for void
          
          if callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE")="V" then
             msg_id$="OP_ORDINV_VOID"
             gosub disp_message
             callpoint!.setStatus("NEWREC")
             break
             rem --- exit from callpoint
          endif
          
          rem --- Check for invoice
          
          if callpoint!.getColumnData("OPE_ORDHDR.ORDINV_FLAG")="I" then
             msg_id$="OP_IS_INVOICE"
             gosub disp_message
             callpoint!.setStatus("NEWREC")
             break
             rem --- exit from callpoint
          endif
          
          rem --- Check locked status
          
          gosub check_lock_flag
          
          if locked=1 then
             user_tpl.do_end_of_form=0
          
             callpoint!.setStatus("NEWREC")
             break
             rem --- exit callpoint
          endif
          
          rem --- Reprint order?
          
          if callpoint!.getColumnData("OPE_ORDHDR.REPRINT_FLAG")<>"Y" then
             cust_id$=callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID")
             order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
             ar_type$=callpoint!.getColumnData("OPE_ORDHDR.AR_TYPE")
             reprint=0
             gosub check_if_reprintable
          else
             callpoint!.setDevObject("reprintable",1)
          endif
          
          rem --- Show customer data
          
          cust_id$=callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID")
          order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
          gosub display_customer
          gosub add_to_batch_print
          
          if callpoint!.getColumnData("OPE_ORDHDR.CASH_SALE")<>"Y" then
             gosub display_aging
             gosub check_credit
          endif
          
          gosub disp_cust_comments
          
          rem --- Display Ship to information
          
          ship_to_type$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_TYPE")
          ship_to_no$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_NO")
          order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
          gosub ship_to_info
          
          rem --- Set comm percent (if calling up a B/O, it will have been cleared);rem bug 8001
          
          slsp$=callpoint!.getColumnData("OPE_ORDHDR.SLSPSN_CODE")
          gosub get_comm_percent
          
          rem --- Enable buttons
          
          callpoint!.setOptionEnabled("PRNT",1)
          callpoint!.setOptionEnabled("RPRT",num(callpoint!.getDevObject("reprintable")))
          callpoint!.setOptionEnabled("TTLS",1)
          callpoint!.setOptionEnabled("SHPT",1)
          
          
          rem --- Set all previous values
          
          user_tpl.prev_ext_cost=num(callpoint!.getColumnData("OPE_ORDHDR.TOTAL_COST"))
          user_tpl.prev_disc_code$=callpoint!.getColumnData("OPE_ORDHDR.DISC_CODE")
          user_tpl.prev_ship_to$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_NO")
          user_tpl.prev_sales_total=num(callpoint!.getColumnData("OPE_ORDHDR.TOTAL_SALES"))
          
          rem --- Set codes and flags
          
          user_tpl.price_code$=callpoint!.getColumnData("OPE_ORDHDR.PRICE_CODE")
          user_tpl.pricing_code$=callpoint!.getColumnData("OPE_ORDHDR.PRICING_CODE")
          user_tpl.order_date$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_DATE")
          user_tpl.disc_code$=callpoint!.getColumnData("OPE_ORDHDR.DISC_CODE")
          user_tpl.new_order=0
          user_tpl.record_deleted=0
          
          rem --- Set OrderHelper object fields
          
          ordHelp!=cast(OrderHelper, callpoint!.getDevObject("order_helper_object"))
          ordHelp!.setCust_id(callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID"))
          ordHelp!.setOrder_no(callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO"))
          ordHelp!.setInv_type(callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE"))
          ordHelp!.setTaxCode(callpoint!.getColumnData("OPE_ORDHDR.TAX_CODE"))
          print "---OrderHelper object fields set"
          rem debug
          
          rem --- Clear availability
          
          gosub clear_avail
          
          rem --- Capture current totals so we can tell later if they were changed in the grid
          
          callpoint!.setDevObject("initial_rec_data$",rec_data$)
          callpoint!.setDevObject("discount_amt",callpoint!.getColumnData("OPE_ORDHDR.DISCOUNT_AMT"))
          callpoint!.setDevObject("freight_amt",callpoint!.getColumnData("OPE_ORDHDR.FREIGHT_AMT"))
          callpoint!.setDevObject("tax_amount",callpoint!.getColumnData("OPE_ORDHDR.TAX_AMOUNT"))
          callpoint!.setDevObject("taxable_amt",callpoint!.getColumnData("OPE_ORDHDR.TAXABLE_AMT"))
          callpoint!.setDevObject("total_cost",callpoint!.getColumnData("OPE_ORDHDR.TOTAL_COST"))
          callpoint!.setDevObject("total_sales",callpoint!.getColumnData("OPE_ORDHDR.TOTAL_SALES"))
          
          rem --- Fix bad records with missing ordinv_flag
          
          if cvs(callpoint!.getColumnData("OPE_ORDHDR.ORDINV_FLAG"),2)="" then
             callpoint!.setColumnData("OPE_ORDHDR.ORDINV_FLAG","O")
             callpoint!.setStatus("SAVE")
          endif
          
          rem --- Create soCreateWO! instance if needed
          
          op_create_wo$=callpoint!.getDevObject("op_create_wo")
          if op_create_wo$="A" then
             rem --- Clean up previous instance as necessary
             if soCreateWO!<>null() then
                soCreateWO!.close()
             endif
             
             customer_id$=callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID")
             order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
             soCreateWO!=new SalesOrderCreateWO(firm_id$,customer_id$,order_no$)
             
             rem --- Initialize soCreateWO! only if order NOT on Credit Hold and NOT a Quote
             if callpoint!.getColumnData("OPE_ORDHDR.CREDIT_FLAG")<>"C" and  callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE")<>"P" then
                soCreateWO!.initIsnWOMap(GridVect!.getItem(0))
                if soCreateWO!.woCount() then
                   callpoint!.setOptionEnabled("WOLN",1)
                else
                   callpoint!.setOptionEnabled("WOLN",0)
                endif
                
                rem --- If order was created via Duplicate Invoice, then create all possible Work Orders.
                if user_tpl.hist_ord$="Y" and callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE")<>"P" then
                   soCreateWO!.setCreateWO(Boolean.valueOf("true"))
                   user_tpl.hist_ord$=""
                endif
             endif
             
             callpoint!.setDevObject("soCreateWO",soCreateWO!)
             callpoint!.setDevObject("createWOs_status","")
          endif
          
          rem --- Disable Ship To fields
          
          ship_to_type$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_TYPE")
          gosub disable_shipto
          
          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
          Customized Version
          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
          [[OPE_ORDHDR.ADIS]]
          rem --- Check for void
          
          if callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE")="V" then
             msg_id$="OP_ORDINV_VOID"
             gosub disp_message
             callpoint!.setStatus("NEWREC")
             break
             rem --- exit from callpoint
          endif
          
          rem --- Check for invoice
          
          if callpoint!.getColumnData("OPE_ORDHDR.ORDINV_FLAG")="I" then
             msg_id$="OP_IS_INVOICE"
             gosub disp_message
             callpoint!.setStatus("NEWREC")
             break
             rem --- exit from callpoint
          endif
          
          rem --- Check EDI Flags
          if callpoint!.getColumnData("OPE_ORDHDR.EDI_ORIGINATED")="Y" then
             dim msg_tokens$[6]
             msg_id$="OP_EDI_PROGRESS"
             msg_ix=0
             rem "Only Warn Once"
             if  callpoint!.getColumnData("OPE_ORDHDR.EDI_REQPO_MISS")="Y" and callpoint!.getDevObject("op_po_warn")="yes" then
                msg_tokens$[msg_ix]="This Customer Requires a PO but not Specified in this Order"
                msg_ix=msg_ix+1
                callpoint!.setDevObject("op_po_warn","no")
             endif
             if callpoint!.getColumnData("OPE_ORDHDR.EDI_DUPLICATED_P")="Y" then
                msg_tokens$[msg_ix]="This Customer has a Duplicate PO Specified in this Order"
                msg_ix=msg_ix+1
             endif
             if callpoint!.getColumnData("OPE_ORDHDR.EDI_SHIPTO_MIS")="Y" then
                msg_tokens$[msg_ix]="This Customer Requires a Ship  To but not Specified in this Order"
                msg_ix=msg_ix+1
             endif
             if callpoint!.getColumnData("OPE_ORDHDR.EDI_LINE_ERROR")="Y" then
                msg_tokens$[msg_ix]="A Line Item Exception Exists!"
                msg_ix=msg_ix+1
             endif
             if callpoint!.getColumnData("OPE_ORDHDR.EDI_TTL_ERROR")="Y" then
                msg_tokens$[msg_ix]="EDI Total Count doesn't Match Line Items"
                msg_ix=msg_ix+1
             endif
             if msg_ix>0 then
                gosub disp_message
                if pos("PASSVALID"=msg_opt$)<>0 then
                   callpoint!.setColumnData("OPE_ORDHDR.EDI_REQPO_MISS","")
                   callpoint!.setColumnData("OPE_ORDHDR.EDI_DUPLICATED_P","")
                   callpoint!.setColumnData("OPE_ORDHDR.EDI_SHIPTO_MIS","")
                   callpoint!.setColumnData("OPE_ORDHDR.EDI_LINE_ERROR","")
                   callpoint!.setColumnData("OPE_ORDHDR.EDI_TTL_ERROR","")
                   callpoint!.setStatus("MODIFIED")
                endif
             endif
          endif
          
          rem --- Check locked status
          
          gosub check_lock_flag
          
          if locked=1 then
             user_tpl.do_end_of_form=0
             callpoint!.clearStatus()
             callpoint!.setStatus("NEWREC")
             break
             rem --- exit callpoint
          endif
          
          rem --- Reprint order?
          
          if callpoint!.getColumnData("OPE_ORDHDR.REPRINT_FLAG")<>"Y" then
             cust_id$=callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID")
             order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
             ar_type$=callpoint!.getColumnData("OPE_ORDHDR.AR_TYPE")
             reprint=0
             gosub check_if_reprintable
          else
             callpoint!.setDevObject("reprintable",1)
          endif
          
          rem --- Show customer data
          
          cust_id$=callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID")
          order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
          gosub display_customer
          gosub add_to_batch_print
          
          if callpoint!.getColumnData("OPE_ORDHDR.CASH_SALE")<>"Y" then
             gosub display_aging
             gosub check_credit
          endif
          
          gosub disp_cust_comments
          
          rem --- Display Ship to information
          
          ship_to_type$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_TYPE")
          ship_to_no$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_NO")
          order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
          gosub ship_to_info
          
          rem --- Set comm percent (if calling up a B/O, it will have been cleared);rem bug 8001 CAH
          
          slsp$=callpoint!.getColumnData("OPE_ORDHDR.SLSPSN_CODE")
          gosub get_comm_percent
          
          rem --- Enable buttons
          
          callpoint!.setOptionEnabled("PRNT",1)
          callpoint!.setOptionEnabled("RPRT",num(callpoint!.getDevObject("reprintable")))
          callpoint!.setOptionEnabled("TTLS",1)
          callpoint!.setOptionEnabled("SHPT",1)
          callpoint!.setOptionEnabled("BOLP",1)
          
          rem --- Set all previous values
          
          user_tpl.prev_ext_cost=num(callpoint!.getColumnData("OPE_ORDHDR.TOTAL_COST"))
          user_tpl.prev_disc_code$=callpoint!.getColumnData("OPE_ORDHDR.DISC_CODE")
          user_tpl.prev_ship_to$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_NO")
          user_tpl.prev_sales_total=num(callpoint!.getColumnData("OPE_ORDHDR.TOTAL_SALES"))
          
          rem --- Set codes and flags
          
          user_tpl.price_code$=callpoint!.getColumnData("OPE_ORDHDR.PRICE_CODE")
          user_tpl.pricing_code$=callpoint!.getColumnData("OPE_ORDHDR.PRICING_CODE")
          user_tpl.order_date$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_DATE")
          user_tpl.disc_code$=callpoint!.getColumnData("OPE_ORDHDR.DISC_CODE")
          user_tpl.new_order=0
          user_tpl.record_deleted=0
          
          rem --- Set OrderHelper object fields
          
          ordHelp!=cast(OrderHelper, callpoint!.getDevObject("order_helper_object"))
          ordHelp!.setCust_id(callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID"))
          ordHelp!.setOrder_no(callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO"))
          ordHelp!.setInv_type(callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE"))
          ordHelp!.setTaxCode(callpoint!.getColumnData("OPE_ORDHDR.TAX_CODE"))
          print "---OrderHelper object fields set"
          rem debug
          
          rem --- Clear availability
          
          gosub clear_avail
          
          rem --- Capture current totals so we can tell later if they were changed in the grid
          
          callpoint!.setDevObject("initial_rec_data$",rec_data$)
          callpoint!.setDevObject("discount_amt",callpoint!.getColumnData("OPE_ORDHDR.DISCOUNT_AMT"))
          callpoint!.setDevObject("freight_amt",callpoint!.getColumnData("OPE_ORDHDR.FREIGHT_AMT"))
          callpoint!.setDevObject("tax_amount",callpoint!.getColumnData("OPE_ORDHDR.TAX_AMOUNT"))
          callpoint!.setDevObject("taxable_amt",callpoint!.getColumnData("OPE_ORDHDR.TAXABLE_AMT"))
          callpoint!.setDevObject("total_cost",callpoint!.getColumnData("OPE_ORDHDR.TOTAL_COST"))
          callpoint!.setDevObject("total_sales",callpoint!.getColumnData("OPE_ORDHDR.TOTAL_SALES"))
          
          rem --- Fix bad records with missing ordinv_flag
          
          if cvs(callpoint!.getColumnData("OPE_ORDHDR.ORDINV_FLAG"),2)="" then
             callpoint!.setColumnData("OPE_ORDHDR.ORDINV_FLAG","O",1)
             callpoint!.setStatus("SAVE-FLUSHOFF")
          endif
          
          rem --- Create soCreateWO! instance if needed
          
          op_create_wo$=callpoint!.getDevObject("op_create_wo")
          if op_create_wo$="A" then
             rem --- Clean up previous instance as necessary
             if soCreateWO!<>null() then
                soCreateWO!.close()
             endif
             
             customer_id$=callpoint!.getColumnData("OPE_ORDHDR.CUSTOMER_ID")
             order_no$=callpoint!.getColumnData("OPE_ORDHDR.ORDER_NO")
             soCreateWO!=new SalesOrderCreateWO(firm_id$,customer_id$,order_no$)
             
             rem --- Initialize soCreateWO! only if order NOT on Credit Hold and NOT a Quote
             if callpoint!.getColumnData("OPE_ORDHDR.CREDIT_FLAG")<>"C" and  callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE")<>"P" then
                soCreateWO!.initIsnWOMap(GridVect!.getItem(0))
                if soCreateWO!.woCount() then
                   callpoint!.setOptionEnabled("WOLN",1)
                else
                   callpoint!.setOptionEnabled("WOLN",0)
                endif
                
                rem --- If order was created via Duplicate Invoice, then create all possible Work Orders.
                if user_tpl.hist_ord$="Y" and callpoint!.getColumnData("OPE_ORDHDR.INVOICE_TYPE")<>"P" then
                   soCreateWO!.setCreateWO(Boolean.valueOf("true"))
                   user_tpl.hist_ord$=""
                endif
             endif
             
             callpoint!.setDevObject("soCreateWO",soCreateWO!)
             callpoint!.setDevObject("createWOs_status","")
          endif
          
          rem --- Disable Ship To fields
          
          ship_to_type$=callpoint!.getColumnData("OPE_ORDHDR.SHIPTO_TYPE")
          gosub disable_shipto
          
          rem --- Enable EDI Transcript of Data Present
          edi_text$=cvs(callpoint!.getColumnData("OPE_ORDHDR.EDI_TRANS_TEXT"),3)
          if edi_text$>"" then
             callpoint!.setOptionEnabled("EDI",1)
          else
             callpoint!.setOptionEnabled("EDI",0)
          endif
          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
          
          The Full Program in the original version is 3,469 Lines and the Modified Version i 5,384 Lines.
          
          I will post a Zip file containing both Sources up on DropBox and send a link to anyone interested.
          1 Reply Last reply Reply Quote 2
          • pnedevP
            pnedev
            last edited by pnedev

            @PeterJones ,

            or had you/the-others just not thought of a use case for non-synced diff?

            Yes, I didn’t come-up with such use case.
            Strictly speaking it is not exactly a “compare” function. Compare finds similarities and differences and aligns them. Manual alignment can be done simply if you put each file in a separate view without comparing them. I agree however that it might be useful addition.

            @Jeff-Miller,

            I didn’t get your thorough description but I have two questions:

            Then re-establishing the Vertical Sync at that point.

            1. Does that sentence mean that you would like to establish vertical sync but manually (at place of your liking) instead of just disabling vertical sync completely?

            The Entire File itself is not the object of our Edits, rather the sub-sections within.

            1. Does the last sentence mean that you would like to compare sub-sections of the files instead of disabling the vertical scroll sync? (The current development version of Compare already has such function)
            1 Reply Last reply Reply Quote 2
            • Jeff MillerJ
              Jeff Miller
              last edited by

              Usually I Open Both files. Click on Compare, which automatically turns on all the Syncing.
              Scroll Down to the header of a Stanza that I am working on, which typically no longer aligns with the other Screen.
              Turn off Vertical Sync. Search to the Same “Header” and manually realign them. Then Turn Vertical Sync back on.
              So the answer is the ability to toggle the Sync on and off manually, but the initial Automatic On is fine.
              Likewise I sometimes toggle off Horizontal Sync to compare long lines with Word Wrap Toggled Off, but this is usually to
              find Fat Finger Typing on my part.

              Something I didn’t touch upon, is that the two files being compared may not necessarily have the Stanza’s in the Same Order.
              It is amazing at how well the Compare can find these and mark them up accordingly, then the ability to turn off the Vertical Sync.
              Manually Align them, and then turn the Vertical Sync back on, works great.

              I do have the full version of those two files zipped up, if you would like to evaluate. I wasn’t sure how to attach them here, or an email address to send a Dropbox Share to.

              I don’t know how you would implement the sub-section of a file concept with what I am dealing with. My examples show a single
              generated Program, but a lot of times there are parallel program constructs. Like an Order Entry versus an Invoice Entry screen both dealing with Line Item Details. The Module Name in my Example of [[MODULE.ACTION]] might be different, but the Action part would be similar, which requires human interaction. This is where KDIFF and Tortois Git start running into problems, because it tries to help, and the simple Merge Left or Right starts to fall apart.

              For Example
              [[OPE_ORDHDR.ADIS]]
              rem — Check for void
              if callpoint!.getColumnData(“OPE_ORDHDR.INVOICE_TYPE”)=“V” then
              msg_id$=“OP_ORDINV_VOID”
              gosub disp_message
              callpoint!.setStatus(“NEWREC”)
              break
              rem — exit from callpoint
              endif

              Would be getting compared to
              [[OPE_INVHDR.ADIS]]
              rem — Check for void
              if callpoint!.getColumnData(“OPE_INVHDR.INVOICE_TYPE”)=“V” then
              msg_id$=“OP_ORDINV_VOID”
              gosub disp_message
              callpoint!.setStatus(“NEWREC”)
              break
              rem — exit from callpoint
              endif

              Which are essentially the same pieces of code in different sections of the Application, but not in the same file.

              Many thanks for looking at this issue.

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

                @pnedev said:

                Strictly speaking it is not exactly a “compare” function. Compare finds similarities and differences and aligns them.

                But no diff algorithm is perfect. There are times when I just insert code between, so a “perfect” diff/compare should show lines matching, then lines inserted, then lines matching again… but often, depending on how complicated the insert was, it will find enough common characters that it shows lines matching, then lines drastically changed and lines deleted, then a whole bunch of lines inserted.

                Here’s one that kindof shows the issue:

                Original

                SomeGroup(param1, param2)
                SomeGroup(param3, param3)
                SomeGroup(param4, param4)
                SomeGroup(param5, param5)
                SomeGroup(param6, param6)
                
                SomeGroup(param1b, param2)
                SomeGroup(param3b, param3b)
                SomeGroup(param4b, param4)
                SomeGroup(param5b, param5b)
                SomeGroup(param6b, param6)
                

                I will call those two groups of lines A and B. If I now insert a group C between those two, which is similar but not identical to B, and then edit B also, so it looks like:

                Inserted and edited B

                SomeGroup(param1, param2)
                SomeGroup(param3, param3)
                SomeGroup(param4, param4)
                SomeGroup(param5, param5)
                SomeGroup(param6, param6)
                
                SomeGroup(param1b, param2)
                SomeGroup(param3, param3b)
                SomeGroup(param4b, param4)
                SomeGroup(param5, param5b)
                SomeGroup(param6, param6)
                
                SomeGroup(param1b, param2)
                SomeGroup(param3, param3b)
                SomeGroup(param4b, param4)
                SomeGroup(param5, param5b)
                SomeGroup(param6, param6)
                

                I’d really like it to show the 5 inserted lines of code and blank line (section C), and the changes in the group B… but insteead, it shows inserts/changes interleaved rather than a group of inserts followed by a group of edits.

                This is exacerbated by the blocks being longer…

                I understand that’s a deficiency in any diff algorithm, and not something you can fix. But I would solve it by

                Now assume it’s a page or two in each block, and t

                When I run across a situation like that, I break the sync to scroll down on the “longer” side until I see the block that I knew was originally “B”, while still looking at the top of where “C” went; I then start adding blank (or comment) lines to the “left” file, refreshing the comparison frequently, and watch the “C” highlights on the LEFT, and watch the “B” hightlights on the RIGHT – waiting until both the “C” group and “B” group show up as the diff I want, vs the default diff.

                It would make more sense with longer blocks, and being able to show you how I have things scrolled… but this is proof of concept.

                I did 5sec pauses on the first/wrong compare, and the final/right compare. And if that’s not long enough, here are the two compares alone:

                To sum up: at every step along the way, I am comparing… I am just doing edits/scrolls, so I want to watch different segments of the compare, depending on whether I’m on the LEFT or the RIGHT – but I still want to see what portions on the LEFT the diff/compare thinks are changed and what portions on the RIGHT the diff/compare thinks are changed.

                1 Reply Last reply Reply Quote 2
                • Jeff MillerJ
                  Jeff Miller
                  last edited by

                  Actually both the “This is NOT the diff I want to see” and “This is really the diff I want to see” work for me, as long as I can
                  toggle off the Sync. Manually reposition the beginning of the Comparison point displayed and then turn the sync back on.

                  More often then not, I am looking for similarities in Logic between two sections for the place to insert several lines of code that had been used for another client. An exact Diff would usually not match because bits and pieces might have different names. It would be sort of like I am looking for the Lines in Green on the Right that Do not appear at all in the Lines on Left in relatively the same logic blocks. Conversely looking for the Lines in Red on the Left that Do Not appear at all in the lines on the Right, that were probably deleted and Superseded.

                  Then directly editing and Saving.

                  Usually after doing one of these Edits, that Source File is then passed through a Parser that performs the Syntax Checking and compiles it into closer to its final form. Then additionally running it through Git to further document changes and the features it brings to the table.

                  Then when there is a System Wide Update of the Original Base Code, run Kdiff3 against the entire before and after directories. Most Cases using the Kdiff3 functions to deal with slight alterations, then resorting to launching the Before and After files to Notepad++ where the human element must come into play.

                  The other Notepad++ tool I make heavy use of is “Search - Find” and “Search - Find in Files”.
                  A field may have changed names in a Table and all of the Code has to be Adjusted, or a File/Path name is directly referenced in the Text and has to be relocated to its new File/Path name throughout the subsystem.

                  The Actual Applications run in Windows/Mac/Linux and are primarily Linux Based, but the GUI Interface from Tortoise Git, KDiff3, and Notepad++ are the Tools primarily used in development.

                  1 Reply Last reply Reply Quote 1
                  • pnedevP
                    pnedev
                    last edited by

                    Hello @Jeff-Miller and @Peter-Jones,

                    Sorry for the late reply guys.

                    Jeff,

                    Manually Align them, and then turn the Vertical Sync back on, works great.

                    Turning vertical sync back on will NOT do re-compare from your new alignment point. So you are visually “comparing” the stanzas yourself, correct?

                    Peter,

                    But no diff algorithm is perfect …

                    I know what you are talking about.
                    I remember the times when I was using BeyondCompare extensively and there were cases when I used to set manual sync points. Those were triggering re-comparison from the points set forward.

                    I am much or less close to releasing a new compare plugin based on the current Compare but with lots of additions, extensions and fixes.
                    Here are the x86 and x64 versions of my development build for you to try.
                    Please manually delete your current ComparePlugin.ini config file and manually replace your ComparePlugin.dll with the new one.

                    The new version doesn’t have the possibility to turn off and then back on the vertical sync (it actually does the vertical sync itself without relying on Notepad++ because of the complicated alignment) but it has another function that might be what you are looking for.
                    It is called Compare Selections and what it does is simply comparing only the selected lines portion of the two files.
                    So your use case might look like this:

                    1. Compare the whole files.
                    2. When you find your “stanza” or manual compare point select the lines after it in both files (or only the lines of the stanzas you want compared) and do Compare Selections.

                    Tell me if it works for you.
                    Any other feedback is appreciated as well.

                    BR

                    andrecool-68A 3 Replies Last reply Reply Quote 3
                    • andrecool-68A
                      andrecool-68 @pnedev
                      last edited by

                      Hello @pnedev
                      This version of the plugin works without freezes, unlike “ComparePlus”!

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

                        @pnedev
                        The old version of ComparePlugin 2.0 still runs faster than ComparePlugin 3.0

                        Meta ChuhM 1 Reply Last reply Reply Quote 1
                        • Meta ChuhM
                          Meta Chuh moderator @andrecool-68
                          last edited by

                          @andrecool-68

                          This version of the plugin works without freezes, unlike “ComparePlus”!

                          i can still reproduce the freeze you discovered, when comparing english.xml with russian.xml using the new ComparePlugin.dll from above, same as ComparePlus, but maybe a few seconds faster.

                          the freeze happens for me, when reaching about the middle of the progress bar, close to the cancel button.
                          after the freeze, the progress bar jumps right to the end.

                          does it run fast for you now ?

                          @pnedev

                          many thanks.
                          as i can see this build is called Compare again, and not ComparePlus.

                          will you make two separately developed projects, or is it just temporary, and everything above 2.0 will be called ComparePlus ?

                          big thanks, your work is very appreciated. 👍
                          best regards.

                          andrecool-68A 1 Reply Last reply Reply Quote 1
                          • andrecool-68A
                            andrecool-68 @Meta Chuh
                            last edited by

                            @Meta-Chuh
                            Here is a comparison ComparePlugin 2.0 ComparePlugin 3.0 and builds the latest version of ComparePlus
                            The first version of the ComparePlus plugin generally hung for 2 minutes (this project was not preserved)

                            Imgur

                            Imgur

                            Imgur

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

                              @pnedev said:

                              … Compare Selections. Tell me if it works for you.

                              Oh, that’s just awesome. I will now be taking the effort to do my compares using this plugin via samba shares, rather than living with the outdated diff tools on the linux box, a lot more often than I used to.

                              Thank you.

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

                                @pnedev
                                Notepad ++ with the version of the plugin ComparePlugin 3.0 hangs tight!

                                Notepad++ v7.6.6 (64-bit)
                                Build time : May 1 2019 - 23:51:03
                                Path : C:\Users\Uzeer\Desktop\npp.7.6.6\x64\notepad++.exe
                                Admin mode : ON
                                Local Conf mode : ON
                                OS : Windows 7 (64-bit)
                                Plugins : ComparePlugin.dll DSpellCheck.dll HTMLTag.dll JSMinNPP.dll MarkdownViewerPlusPlus.dll mimeTools.dll NppConverter.dll NppExport.dll NppMarkdownPanel.dll PluginManager.dll VisualStudioLineCopy.dll XMLTools.dll _CustomizeToolbar.dll

                                ==================================================
                                Файл процесса     : notepad++.exe
                                Событие           : Не отвечает и была закрыта
                                Время события     : 08.05.2019 16:13:59
                                Пользователь      : Uzeer
                                Путь к процессу   : C:\Users\Uzeer\Desktop\npp.7.6.6\x64\notepad++.exe
                                ==================================================
                                Version=1
                                EventType=AppHangB1
                                EventTime=132017948399693149
                                ReportType=3
                                Consent=1
                                ReportIdentifier=23f06d3c-7193-11e9-b847-902b343f04b6
                                IntegratorReportIdentifier=23f06d3d-7193-11e9-b847-902b343f04b6
                                Response.type=4
                                Sig[0].Name=Имя приложения
                                Sig[0].Value=notepad++.exe
                                Sig[1].Name=Версия приложения
                                Sig[1].Value=7.6.6.0
                                Sig[2].Name=Отметка времени приложения
                                Sig[2].Value=5cca06f7
                                Sig[3].Name=Сигнатура зависания
                                Sig[3].Value=84b2
                                Sig[4].Name=Тип зависания
                                Sig[4].Value=0
                                DynamicSig[1].Name=Версия ОС
                                DynamicSig[1].Value=6.1.7601.2.1.0.768.3
                                DynamicSig[2].Name=Код языка
                                DynamicSig[2].Value=1049
                                DynamicSig[22].Name=Доп. сигнатура зависания 1
                                DynamicSig[22].Value=84b229ed73cc04a1d4d457685b853177
                                DynamicSig[23].Name=Доп. сигнатура зависания 2
                                DynamicSig[23].Value=c3d7
                                DynamicSig[24].Name=Доп. сигнатура зависания 3
                                DynamicSig[24].Value=c3d77a4a6a5eadb9dbdbd155b5d197fc
                                DynamicSig[25].Name=Доп. сигнатура зависания 4
                                DynamicSig[25].Value=84b2
                                DynamicSig[26].Name=Доп. сигнатура зависания 5
                                DynamicSig[26].Value=84b229ed73cc04a1d4d457685b853177
                                DynamicSig[27].Name=Доп. сигнатура зависания 6
                                DynamicSig[27].Value=c3d7
                                DynamicSig[28].Name=Доп. сигнатура зависания 7
                                DynamicSig[28].Value=c3d77a4a6a5eadb9dbdbd155b5d197fc
                                UI[3]=Notepad++ : a free (GNU) source code editor не отвечает
                                UI[4]=Windows может поискать решение проблемы в Интернете. При закрытии не отвечающей программы может быть потеряна несохраненная информация.
                                UI[5]=Выполнить поиск решения и закрыть программу
                                UI[6]=Выполнить поиск решения и закрыть программу
                                UI[7]=Закрыть программу
                                LoadedModule[0]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\notepad++.exe
                                LoadedModule[1]=C:\Windows\SYSTEM32\ntdll.dll
                                LoadedModule[2]=C:\Windows\system32\kernel32.dll
                                LoadedModule[3]=C:\Windows\system32\KERNELBASE.dll
                                LoadedModule[4]=C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.7601.17514_none_fa396087175ac9ac\COMCTL32.dll
                                LoadedModule[5]=C:\Windows\system32\msvcrt.dll
                                LoadedModule[6]=C:\Windows\system32\GDI32.dll
                                LoadedModule[7]=C:\Windows\system32\USER32.dll
                                LoadedModule[8]=C:\Windows\system32\LPK.dll
                                LoadedModule[9]=C:\Windows\system32\USP10.dll
                                LoadedModule[10]=C:\Windows\system32\SHLWAPI.dll
                                LoadedModule[11]=C:\Windows\system32\SHELL32.dll
                                LoadedModule[12]=C:\Windows\system32\dbghelp.dll
                                LoadedModule[13]=C:\Windows\system32\VERSION.dll
                                LoadedModule[14]=C:\Windows\system32\CRYPT32.dll
                                LoadedModule[15]=C:\Windows\system32\MSASN1.dll
                                LoadedModule[16]=C:\Windows\system32\WINTRUST.dll
                                LoadedModule[17]=C:\Windows\system32\RPCRT4.dll
                                LoadedModule[18]=C:\Windows\system32\SensApi.dll
                                LoadedModule[19]=C:\Windows\system32\COMDLG32.dll
                                LoadedModule[20]=C:\Windows\system32\ADVAPI32.dll
                                LoadedModule[21]=C:\Windows\SYSTEM32\sechost.dll
                                LoadedModule[22]=C:\Windows\system32\ole32.dll
                                LoadedModule[23]=C:\Windows\system32\IMM32.DLL
                                LoadedModule[24]=C:\Windows\system32\MSCTF.dll
                                LoadedModule[25]=C:\Windows\system32\api-ms-win-core-synch-l1-2-0.DLL
                                LoadedModule[26]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\SciLexer.dll
                                LoadedModule[27]=C:\Windows\system32\OLEAUT32.dll
                                LoadedModule[28]=C:\Windows\system32\Msimg32.DLL
                                LoadedModule[29]=C:\Windows\system32\uxtheme.dll
                                LoadedModule[30]=C:\Windows\system32\dwmapi.dll
                                LoadedModule[31]=C:\Windows\system32\CRYPTBASE.dll
                                LoadedModule[32]=C:\Windows\system32\WindowsCodecs.dll
                                LoadedModule[33]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\ComparePlugin\ComparePlugin.dll
                                LoadedModule[34]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\DSpellCheck\DSpellCheck.dll
                                LoadedModule[35]=C:\Windows\system32\WININET.dll
                                LoadedModule[36]=C:\Windows\system32\api-ms-win-downlevel-user32-l1-1-0.dll
                                LoadedModule[37]=C:\Windows\system32\api-ms-win-downlevel-shlwapi-l1-1-0.dll
                                LoadedModule[38]=C:\Windows\system32\api-ms-win-downlevel-version-l1-1-0.dll
                                LoadedModule[39]=C:\Windows\system32\api-ms-win-downlevel-normaliz-l1-1-0.dll
                                LoadedModule[40]=C:\Windows\system32\normaliz.DLL
                                LoadedModule[41]=C:\Windows\system32\iertutil.dll
                                LoadedModule[42]=C:\Windows\system32\api-ms-win-downlevel-advapi32-l1-1-0.dll
                                LoadedModule[43]=C:\Windows\system32\USERENV.dll
                                LoadedModule[44]=C:\Windows\system32\profapi.dll
                                LoadedModule[45]=C:\Windows\system32\WS2_32.dll
                                LoadedModule[46]=C:\Windows\system32\NSI.dll
                                LoadedModule[47]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\HTMLTag\HTMLTag.dll
                                LoadedModule[48]=C:\Windows\system32\netapi32.dll
                                LoadedModule[49]=C:\Windows\system32\netutils.dll
                                LoadedModule[50]=C:\Windows\system32\srvcli.dll
                                LoadedModule[51]=C:\Windows\system32\wkscli.dll
                                LoadedModule[52]=C:\Windows\system32\SHFolder.dll
                                LoadedModule[53]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\JSMinNPP\JSMinNPP.dll
                                LoadedModule[54]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\MarkdownViewerPlusPlus\MarkdownViewerPlusPlus.dll
                                LoadedModule[55]=C:\Windows\SYSTEM32\MSCOREE.DLL
                                LoadedModule[56]=C:\Windows\Microsoft.NET\Framework64\v4.0.30319\mscoreei.dll
                                LoadedModule[57]=C:\Windows\Microsoft.NET\Framework64\v4.0.30319\clr.dll
                                LoadedModule[58]=C:\Windows\system32\MSVCR120_CLR0400.dll
                                LoadedModule[59]=C:\Windows\assembly\NativeImages_v4.0.30319_64\mscorlib\b308b9c61f65cf2dfd876031ee385ba4\mscorlib.ni.dll
                                LoadedModule[60]=C:\Windows\system32\api-ms-win-core-xstate-l2-1-0.dll
                                LoadedModule[61]=C:\Windows\Microsoft.NET\Framework64\v4.0.30319\clrjit.dll
                                LoadedModule[62]=C:\Windows\Microsoft.NET\Framework64\v4.0.30319\diasymreader.dll
                                LoadedModule[63]=C:\Windows\assembly\NativeImages_v4.0.30319_64\System\095a3392942c3d4eb888e6a32036acd8\System.ni.dll
                                LoadedModule[64]=C:\Windows\assembly\NativeImages_v4.0.30319_64\System.Drawing\dcbadb02f6000b436f1cb0fb736df3ee\System.Drawing.ni.dll
                                LoadedModule[65]=C:\Windows\assembly\NativeImages_v4.0.30319_64\System.Windows.Forms\fb9f08a1fa8e62ae099d80c57ace90d2\System.Windows.Forms.ni.dll
                                LoadedModule[66]=C:\Windows\assembly\NativeImages_v4.0.30319_64\System.Core\ccc9e0855af638ecf77291cf01c10b59\System.Core.ni.dll
                                LoadedModule[67]=C:\Windows\Microsoft.NET\Framework64\v4.0.30319\nlssorting.dll
                                LoadedModule[68]=C:\Windows\assembly\NativeImages_v4.0.30319_64\System.Configuration\7d75083427584fe395779e2da37e26b0\System.Configuration.ni.dll
                                LoadedModule[69]=C:\Windows\assembly\NativeImages_v4.0.30319_64\System.Xml\8821b72d5d51079acf96e90c4af19a96\System.Xml.ni.dll
                                LoadedModule[70]=C:\Windows\system32\bcrypt.dll
                                LoadedModule[71]=C:\Windows\system32\CRYPTSP.dll
                                LoadedModule[72]=C:\Windows\system32\rsaenh.dll
                                LoadedModule[73]=C:\Windows\WinSxS\amd64_microsoft.windows.gdiplus_6595b64144ccf1df_1.1.7601.17514_none_2b24536c71ed437a\gdiplus.dll
                                LoadedModule[74]=C:\Windows\system32\CLBCatQ.DLL
                                LoadedModule[75]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\mimeTools\mimeTools.dll
                                LoadedModule[76]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\NppConverter\NppConverter.dll
                                LoadedModule[77]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\NppExport\NppExport.dll
                                LoadedModule[78]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\NppMarkdownPanel\NppMarkdownPanel.dll
                                LoadedModule[79]=C:\Windows\system32\RpcRtRemote.dll
                                LoadedModule[80]=C:\Windows\System32\ieframe.dll
                                LoadedModule[81]=C:\Windows\System32\api-ms-win-downlevel-shell32-l1-1-0.dll
                                LoadedModule[82]=C:\Windows\system32\SXS.DLL
                                LoadedModule[83]=C:\Windows\system32\api-ms-win-downlevel-shlwapi-l2-1-0.dll
                                LoadedModule[84]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\PluginManager\PluginManager.dll
                                LoadedModule[85]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\VisualStudioLineCopy\VisualStudioLineCopy.dll
                                LoadedModule[86]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\XMLTools\XMLTools.dll
                                LoadedModule[87]=C:\Windows\system32\OLEACC.dll
                                LoadedModule[88]=C:\Windows\system32\WINMM.dll
                                LoadedModule[89]=C:\Windows\system32\WINSPOOL.DRV
                                LoadedModule[90]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\XMLTools\libs\libiconv-2.dll
                                LoadedModule[91]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\XMLTools\libs\zlib1.dll
                                LoadedModule[92]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\XMLTools\libs\libwinpthread-1.dll
                                LoadedModule[93]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\XMLTools\libs\libxml2-2.dll
                                LoadedModule[94]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\XMLTools\libs\libxslt-1.dll
                                LoadedModule[95]=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\plugins\_CustomizeToolbar\_CustomizeToolbar.dll
                                LoadedModule[96]=C:\Windows\system32\PROPSYS.dll
                                FriendlyEventName=Не отвечает и была закрыта
                                ConsentKey=AppHangXProcB1
                                AppName=Notepad++ : a free (GNU) source code editor
                                AppPath=C:\Users\Uzeer\Desktop\npp.7.6.6\x64\notepad++.exe
                                ReportDescription=Ошибка привела к остановке взаимодействия программы с Windows.
                                
                                1 Reply Last reply Reply Quote 0
                                • pnedevP
                                  pnedev
                                  last edited by pnedev

                                  Hello all,

                                  Thank you for the feedback, I appreciate it.

                                  @Meta-Chuh ,

                                  will you make two separately developed projects …

                                  No, I just linked here a state of the development before the transition to the new name. It is to ease the manual installation and reduce the possibility for conflicts if one has both ComparePlugin and ComparePlus installed.
                                  Beside that, ComparePlus current development state is not quite stable because of the ongoing changes.

                                  @andrecool-68 ,

                                  This is just a development version but nevertheless it shouldn’t hang.
                                  I’m kind-of confused because you are saying it is faster than ComparePlus (meaning it works) but then you say it hangs.
                                  Does it hang every time you compare the same files?
                                  Could you please try removing the other plugins and keep just the development ComparePlugin (v3 RC) and test again?
                                  I don’t usually test x64 build myself as I don’t have such setup.
                                  Thanks.

                                  Just FYI, the development compare (no matter if v3 RC or ComparePlus) is considerably slower than Compare v2 when comparing files with lots of replacement lines because it tries to “intelligently” find the changed lines (which brings more accuracy on the price of slower compare). As I said, the compare is perceived to be slower only in the case there are lots of replacements and lines that “look” similar.
                                  To get an idea, look at the following compare excerpt screenshots (first Compare v2, followed by ComparePlus):

                                  Compare v2

                                  ComparePlus

                                  As you can see from the images, Styler and Prefix mode sections are with changed order and ComparePlus tries to match the commands IDs as well (not yet perfect but at least better compare results than Compare v2).

                                  I’m still in the process of developing the smart change detection and I will try to make a good compromise between accuracy and compare speed.

                                  BR

                                  andrecool-68A 1 Reply Last reply Reply Quote 4
                                  • pnedevP
                                    pnedev
                                    last edited by

                                    Seems like image link sharing failed.

                                    How can I do this?
                                    Thanks.

                                    Meta ChuhM Jeff MillerJ 2 Replies Last reply Reply Quote 2
                                    • andrecool-68A
                                      andrecool-68 @pnedev
                                      last edited by

                                      @pnedev
                                      Removed all plugins except ComparePlugin 3.0, and periodically Notepad ++ hangs.

                                      Imgur

                                      1 Reply Last reply Reply Quote 1
                                      • Meta ChuhM
                                        Meta Chuh moderator @pnedev
                                        last edited by

                                        @pnedev

                                        i think you can not embed google drive images, as they don’t provide a static image url to e.g. ComparePlus.png.

                                        best regards

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

                                          @Meta-Chuh said:

                                          google drive

                                          Plus google drive is simply bad because so many corporations block it; you may not get the best answers if the best answerers can’t see it.

                                          1 Reply Last reply Reply Quote 3
                                          • Jeff MillerJ
                                            Jeff Miller @pnedev
                                            last edited by

                                            The Compare 3.0 looks like it will work.

                                            The only issue I think is on the Notepad++ Side.

                                            The Selecting the Sections requires some extra work, unless I am missing something.

                                            So now I open Both Files and “Move/Clone Current Document” -> “Move to Other View”

                                            Then on the Left View Do a Find for the
                                            Beginning of what I want to Compare.
                                            Then do the
                                            “Edit” -> “Begin/End Select” – Start Selection

                                            Then Scroll Down to the End of the Section in Question.
                                            “Edit” -> “Begin/End Select”. – End Selection

                                            Then repeat on the Right View Do a Find for the
                                            Beginning of what I want to Compare.
                                            Then do the
                                            “Edit” -> “Begin/End Select” – Start Selection

                                            Then Scroll Down to the End of the Section in Question.
                                            “Edit” -> “Begin/End Select” – End Selection

                                            Then “Plugins” -> “Compare” -> “Compare Selections”

                                            So once in this mode, it works well.

                                            It is just a case of additional steps that have to be accomplished if the Stanza’s Don’t Layout the Same.

                                            Also someone had a question about recomparing when breaking and re-establishing the Sync.
                                            Essentially the first Compare pass would mark up the Text in the Various Colors. Then when moving the two sides Separately, we did not want it to run a compare again, just keep the Color Markup that was alread processed.

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