HISE Logo Forum
    • Categories
    • Register
    • Login

    Develop instabilities

    Scheduled Pinned Locked Moved General Questions
    19 Posts 3 Posters 580 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.
    • LindonL
      Lindon
      last edited by

      Sigh, I - as you may have seen - have been trying to get my large project to work - whilst trying to get develop to compile with IPP.

      Recently Dave Healey had a run at this and sent me a "working" version - that is now crashing badly (again) like this on project load:

      00e81493-6719-49ee-b9c8-659cee8c0f9b-image.png

      So I'm opening this new thread with the hope of documenting whats happening (at the very least)..so expect more posts from me here....

      HISE Development for hire.
      www.channelrobot.com

      d.healeyD 1 Reply Last reply Reply Quote 0
      • d.healeyD
        d.healey @Lindon
        last edited by

        @lindon You're not alone - https://forum.hise.audio/topic/5203/how-do-i-debug-project-crashes

        Libre Wave - Freedom respecting instruments and effects
        My Patreon - HISE tutorials
        YouTube Channel - Public HISE tutorials

        LindonL 1 Reply Last reply Reply Quote 0
        • LindonL
          Lindon @d.healey
          last edited by

          Okay a fair bit of progress....I can make HISE Develop crash absolutely repeatably....with what I think is a segmentation error, (malloc failing) - but dont trust the non-C++ programmer... - I'm currently on the Mac but I think this is true on Windows too....

          The change I make is to add a single line of code, any line of code....

          It's a big project with a lot of components....theres a bunch of samples and synths (for a total of 7 "voices") and each of these inside a synthesiser container and each of them has a number of Script Processors.

          In each "voice" theres a script called mono (well mono1, mono2, mono3, mono4 etc.)

          I added each of these in turn and mono3 started to crash HISE Develop when I loaded the project - ocassionaly the Mac offers me a dump report with the malloc error in it...

          So I emptied mono3 (removing all the code) and slowly added it back in. When I put this (and only this) in the init section of mono3

          var lastNote;
          

          HISE develop will load and run.

          but if I say this:

          var lastNote;
          var myVal;
          

          It really doesn't matter what this variable is (or a reg variable ) HISE will crash on loading the project

          take out the second variable and it will load and run again

          @Christoph-Hart - this looks way above my pay grade - I can wrap up the project and send it to you.

          HISE Development for hire.
          www.channelrobot.com

          d.healeyD ustkU 2 Replies Last reply Reply Quote 0
          • d.healeyD
            d.healey @Lindon
            last edited by

            @lindon Try splitting your code into separate files, each with their own namespace, and avoid using var wherever possible, especially in on init as these pollute the script-wide namespace. I don't know if this will solve the problem but it will make it easier to navigate your code and "bypass" sections for testing.

            Libre Wave - Freedom respecting instruments and effects
            My Patreon - HISE tutorials
            YouTube Channel - Public HISE tutorials

            ustkU 1 Reply Last reply Reply Quote 0
            • ustkU
              ustk @Lindon
              last edited by

              @lindon said in Develop instabilities:

              It really doesn't matter what this variable is

              Do you mean name wise too or always with that myVal name?
              Because it reminds me of an old issue I had where some namings aren't "allowed" because they are competing against the source. But it might not be the case here...

              Can't help pressing F5 in the forum...

              1 Reply Last reply Reply Quote 0
              • ustkU
                ustk @d.healey
                last edited by

                @d-healey said in Develop instabilities:

                avoid using var wherever possible, especially in on init as these pollute the script-wide namespace

                What do you want to use instead? A reg pollutes the same way, right?

                Can't help pressing F5 in the forum...

                d.healeyD 1 Reply Last reply Reply Quote 0
                • d.healeyD
                  d.healey @ustk
                  last edited by d.healey

                  @ustk No reg doesn't pollute the script-wide namespace.

                  namespace test
                  {
                  	var myVar = 10;
                  	reg myReg = 50;
                  }
                  
                  Console.print(myVar);
                  Console.print(myReg);
                  

                  Somebody documentented this stuff and nobody reads it :p - https://docs.hise.audio/scripting/scripting-in-hise/hise-script-coding-standards.html

                  Libre Wave - Freedom respecting instruments and effects
                  My Patreon - HISE tutorials
                  YouTube Channel - Public HISE tutorials

                  LindonL ustkU 2 Replies Last reply Reply Quote 1
                  • LindonL
                    Lindon @d.healey
                    last edited by

                    @d-healey - these were reg to start with so that's not it, and @ustk ANY name myVar thisVar, myThis, SOmething, Anything

                    HISE Development for hire.
                    www.channelrobot.com

                    d.healeyD 1 Reply Last reply Reply Quote 0
                    • ustkU
                      ustk @d.healey
                      last edited by

                      @d-healey Oh gosh I never ever noticed that! But I generally use var only in functions that are not inline

                      Can't help pressing F5 in the forum...

                      1 Reply Last reply Reply Quote 0
                      • d.healeyD
                        d.healey @Lindon
                        last edited by d.healey

                        @lindon said in Develop instabilities:

                        these were reg to start with so that's not it

                        How many did you have? The limit is 32 per namespace. But I don't think this is the issue. I was just suggesting you use namespaces and separate files to make your code more manageable.

                        Libre Wave - Freedom respecting instruments and effects
                        My Patreon - HISE tutorials
                        YouTube Channel - Public HISE tutorials

                        LindonL 2 Replies Last reply Reply Quote 0
                        • LindonL
                          Lindon @d.healey
                          last edited by

                          OKay - confirmed - exactly the same behaviour on Windows as MacOS.

                          HISE Development for hire.
                          www.channelrobot.com

                          1 Reply Last reply Reply Quote 0
                          • LindonL
                            Lindon @d.healey
                            last edited by

                            @d-healey - so tell me this about namespaces -

                            I have (say) a Script processor with code in init, onNoteOn and onNoteOff

                            where am I putting this namespace ? in the Init? Does that work? Will I need to prepend the namespace name in onNoteOn and onNoteOff?

                            HISE Development for hire.
                            www.channelrobot.com

                            d.healeyD 1 Reply Last reply Reply Quote 0
                            • d.healeyD
                              d.healey @Lindon
                              last edited by

                              @lindon said in Develop instabilities:

                              so tell me this about namespaces

                              Here's what I wrote about namespaces in the doc I posted above

                              • There is no performance penalty for using namespaces.
                              • Namespaces should be written in Pascal case .
                              • If the namespace resides in a dedicated external file the file should have the same name as the namespace, e.g. PageHandler.js .
                              • Namespaces cannot be nested.
                              • Don't declare var variables inside a namespace. Use reg instead.
                              • Each namespace can have up to 32 reg variables

                              A namespace is a bit like a singleton class.

                              Here's a screenshot of the on init section from a largish project I'm working on. Every single one of those include lines you see refers to a separate file. So all my LAF code (and some related paint routines and theming stuff) goes inside my LookAndFeel.js.

                              Everything related to presets and the preset browser goes inside Presets.js.

                              It makes it really easy to organise the code, and when you're debugging you can comment out a whole file's worth of code just by commenting out the include line.

                              All the other default callbacks are unaffected but you can call code from your external files in those callbacks.

                              So if you had a namespace for handling keyswitches; in the on note on callback you could call something like Keyswitches.changeArticulation().

                              dbe7f8bc-78c7-4c2f-b84b-5622809d01e7-image.png

                              Libre Wave - Freedom respecting instruments and effects
                              My Patreon - HISE tutorials
                              YouTube Channel - Public HISE tutorials

                              LindonL 1 Reply Last reply Reply Quote 0
                              • LindonL
                                Lindon @d.healey
                                last edited by

                                @d-healey - well thats pretty much how I use them... maybe not as well or as often but really I'm asking about whats not in the documentation:

                                having a name space declared in the on init section of a script processor...

                                namspace myThing
                                {
                                    reg myVar;
                                }
                                

                                means in the onNoteOn callback I have to say this:

                                Console.print(myThing.myVar);
                                

                                Correct?

                                HISE Development for hire.
                                www.channelrobot.com

                                ustkU 1 Reply Last reply Reply Quote 0
                                • ustkU
                                  ustk @Lindon
                                  last edited by

                                  @lindon exact

                                  Can't help pressing F5 in the forum...

                                  LindonL 1 Reply Last reply Reply Quote 0
                                  • LindonL
                                    Lindon @ustk
                                    last edited by

                                    @ustk @d-healey well I've created a whole swag of namespaces, and its still crashing....its just massively unreliable at large project scales...

                                    HISE Development for hire.
                                    www.channelrobot.com

                                    LindonL 1 Reply Last reply Reply Quote 0
                                    • LindonL
                                      Lindon @Lindon
                                      last edited by

                                      @lindon - and when it does run it runs like a dog...its incredibly slow - and yes this is NOT the debug HISE...

                                      HISE Development for hire.
                                      www.channelrobot.com

                                      d.healeyD 1 Reply Last reply Reply Quote 0
                                      • d.healeyD
                                        d.healey @Lindon
                                        last edited by

                                        @lindon said in Develop instabilities:

                                        and when it does run it runs like a dog

                                        Was this the same in the master branch?

                                        Libre Wave - Freedom respecting instruments and effects
                                        My Patreon - HISE tutorials
                                        YouTube Channel - Public HISE tutorials

                                        LindonL 1 Reply Last reply Reply Quote 0
                                        • LindonL
                                          Lindon @d.healey
                                          last edited by

                                          @d-healey nope master runs OK.

                                          HISE Development for hire.
                                          www.channelrobot.com

                                          1 Reply Last reply Reply Quote 0
                                          • First post
                                            Last post

                                          22

                                          Online

                                          1.8k

                                          Users

                                          12.0k

                                          Topics

                                          104.1k

                                          Posts