sketchucation logo sketchucation
    • Login
    ℹ️ Licensed Extensions | FredoBatch, ElevationProfile, FredoSketch, LayOps, MatSim and Pic2Shape will require license from Sept 1st More Info

    [plugin] Ruby Code Editor - UPDATED to v3.0 3/4/2013

    Scheduled Pinned Locked Moved Plugins
    56 Posts 11 Posters 39.8k Views 11 Watching
    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.
    • alexschreyerA Offline
      alexschreyer Extension Creator
      last edited by alexschreyer

      Hi All,

      http://www.alexschreyer.net/blog/wp-content/uploads/2010/02/sketchup-ruby-editor-1-530x302.jpg

      EDIT (3/4/2013): This plugin has been updated to version 3.0. The plugin got a major update! Some of the new features are: better environment stability (editor, scrolling, results, etc.), code completion for SketchUp classes and methods and a variety of other minor updates.

      This code editor plugin offers an easy-to-use and visually appealing way to create and modify Ruby scripts directly within SketchUp. These scripts can then be used to create geometry, add functionality or add data within the SketchUp 3D modeling environment. The SketchUp Ruby API provides an extensive set of functions to automatize SketchUp in many ways or create scripted, computational geometry.

      I created this editor mainly for two reasons: One is that when I write code, I permanently need to look up documentation. To make this easier, I added a bunch of reference webpages to a browser in a tab. Also, a dropdown above the editor contains some common code snippets that can be inserted at the current cursor position. Version 3.0 also introduces a code-completion feature that you can invoke at any point by clicking CTRL-SHIFT. It contains SketchUp’s classes and methods.

      The other reason I wrote this as a plugin that works right inside of SketchUp is that I wanted it to give easy access to the Ruby coding environment and behave a bit more like a real code editor. To accomplish this, I added a bit of jQuery magic to make it look good and have some additional features. I also added the excellent CodeMirror 3.1 syntax highlighting engine. This provides the editor with multi-language code highlighting, correct TAB control, bracket matching and many more features. Just load the plugin and give it a try to see for yourself!

      The following video gives a brief overview of the current version:

      You can get this editor from my website (and see a changelog) at:
      http://www.alexschreyer.net/projects/sketchup-ruby-code-editor/

      For more on what you can do with it, check out my book "Architectural Design with SketchUp" (especially chapter 6):

      Link Preview Image
      SketchUp for Design

      Tutorials and news about architectural design, 3D modeling, rendering, drawing, extensions/plugins, making, and scripting with Trimble's SketchUp and LayOut.

      favicon

      SketchUp for Design (sketchupfordesign.com)

      Cheers,
      Alex

      Author of "Architectural Design with SketchUp":
      http://sketchupfordesign.com/

      1 Reply Last reply Reply Quote 0
      • R Offline
        remus
        last edited by

        😲 thank you! this is awesome!

        http://remusrendering.wordpress.com/

        1 Reply Last reply Reply Quote 0
        • thomthomT Offline
          thomthom
          last edited by

          Looking very nice.

          got a couple of questions though:

          console.png

          The Ruby Console reports no error - but does output the puts statements.

          Thomas Thomassen — SketchUp Monkey & Coding addict
          List of my plugins and link to the CookieWare fund

          1 Reply Last reply Reply Quote 0
          • Chris FullmerC Offline
            Chris Fullmer
            last edited by

            Ooh I'm excited to test this out. i'm a huge believer in Jim's web console. The thought of anything to improve it make me giddy.

            Chris

            Lately you've been tan, suspicious for the winter.
            All my Plugins I've written

            1 Reply Last reply Reply Quote 0
            • alexschreyerA Offline
              alexschreyer Extension Creator
              last edited by

              @thomthom: The bottom of the page disappears when the window width gets so small that the file name breaks into the next row. I wanted to keep the layout fluid so that elements adjust on resize, but maybe I can find a better way to arrange the page more reliably.

              Not sure why there is no output. I didn't touch Jim's code that deals with capturing the Ruby response - does this also happen with the original Web Console?

              Cheers, Alex

              Author of "Architectural Design with SketchUp":
              http://sketchupfordesign.com/

              1 Reply Last reply Reply Quote 0
              • J Offline
                Jim
                last edited by

                A most excellent update Alex!

                Hi

                1 Reply Last reply Reply Quote 0
                • Chris FullmerC Offline
                  Chris Fullmer
                  last edited by

                  As far as the bottom output goes, I see it behaving exactly as Jim's does. What ever the script returns is output below. All puts statements get output in the Ruby Console.

                  Lately you've been tan, suspicious for the winter.
                  All my Plugins I've written

                  1 Reply Last reply Reply Quote 0
                  • Chris FullmerC Offline
                    Chris Fullmer
                    last edited by

                    So one thought, if its possible to clean this up I don't know - but the ruby console errors that get output are trying to display a lot of html markup now. A simple spelling error in model.selection returned this:

                    model = Sketchup.active_model
                    <br/>ent = model.active_entities
                    <br/>sel = modqerel.selection
                    <br/>
                    <br/>dist = 100
                    <br/>
                    <br/>sel.to_a.each do |e|
                    <br/>  if e.is_a? Sketchup;;Face
                    <br/>    e.pushpull dist
                    <br/>  end
                    <br/>
                    <br/>
                    <br/>end
                    "(eval);3;in&nbsp;&lsquo;initialize&rsquo;;&nbsp;undefined&nbsp;local&nbsp;variable&nbsp;or&nbsp;method&nbsp;&lsquo;modqerel&rsquo;&nbsp;for&nbsp;#&lt;RubyEditor;0x9912568>"
                    
                    

                    I added an image since I think it shows the error more clearly than the code block above.
                    error.png

                    I have no clue how that would be fixed.

                    Also, I am a little torn on the undo button. You set it so that it automatically wraps everything into a single undo command, which is nice so that a single press of "undo" will undo everything that was done in the script. But at the same time, I kind of don't like that because I'm worried I might forget to to write in my own start and commit operation methods. Don't know if that makes sense? I also don't know if I really would want it back how it was. Maybe this is a better workflow that I just need to adapt to.

                    Still though, I am liking it a lot!

                    Chris

                    Lately you've been tan, suspicious for the winter.
                    All my Plugins I've written

                    1 Reply Last reply Reply Quote 0
                    • chrisglasierC Offline
                      chrisglasier
                      last edited by

                      I know it is common for researchers to do their own thing but surely in this technically connected world we few should work together for the benefit of others.

                      A link and a pic ...

                      SU API.png

                      For my part I would like to incorporate these things into one interface.

                      Whatthink?

                      Chris

                      With TBA interfaces we can analyse what is to be achieved so that IT can help with automation to achieve it.

                      1 Reply Last reply Reply Quote 0
                      • alexschreyerA Offline
                        alexschreyer Extension Creator
                        last edited by

                        Thanks for the feedback, everybody! Keep it coming...

                        @Chris Fullmer: Looking at the result capture code, it appears to convert characters such as the newline into HTML characters before sending it to the dialog. I tried to find a way around this - to no avail. Sending a newline \n to the execute_script doesn't work for me. Apparently that's why Jim put these conversions in there. I'll try later if there is an easier way to "encode" these before sending and "decode" them in Javascript in the dialog.

                        @chrisglasier: I remember your nameset approach from earlier. It can very well work with my editor. At some point, it would be great to have a code completion available, which could be your method. I am thinking of the user placing the caret, then clicking a key combination and then having a window pop up (like yours), where the method can be selected. How is your window implemented? I can easily incorporate something that resides in a DIV with Javascript.

                        Cheers,
                        Alex

                        Author of "Architectural Design with SketchUp":
                        http://sketchupfordesign.com/

                        1 Reply Last reply Reply Quote 0
                        • Dan RathbunD Offline
                          Dan Rathbun
                          last edited by

                          @alexschreyer said:

                          I have also not tested this on a mac.

                          For the PC, put the following META tag in the HEAD section, so the browser displays Themed Controls instead of those old ugly plain Win 3.x style controls (ie buttons, scrollbars, etc.)

                          The Mac (Safari) should just ignore the tag.

                          HTML

                          
                          	<!-- Use MS Common Controls ver 6+ if available -->
                          	<!--  (also known as XP style themed controls.)  -->
                          	<META HTTP-EQUIV="MSThemeCompatible" CONTENT="Yes">
                          
                          

                          _

                          I'm not here much anymore.

                          1 Reply Last reply Reply Quote 0
                          • Dan RathbunD Offline
                            Dan Rathbun
                            last edited by

                            @alexschreyer said:

                            @thomthom: The bottom of the page disappears when the window width gets so small that the file name breaks into the next row. I wanted to keep the layout fluid so that elements adjust on resize, but maybe I can find a better way to arrange the page more reliably.

                            I'd like to see the rb filename on the line below the toolbar (as a step towards future tabbed multi-snippet interface where the filename would be on the tabs anyway.)

                            I'm not here much anymore.

                            1 Reply Last reply Reply Quote 0
                            • Dan RathbunD Offline
                              Dan Rathbun
                              last edited by

                              @unknownuser said:

                              (No output?) The Ruby Console reports no error - but does output the puts statements.
                              @alexschreyer said:

                              @thomthom: Not sure why there is no output. I didn't touch Jim's code that deals with capturing the Ruby response - does this also happen with the original Web Console?

                              Yes it happens with the original WebConsole.

                              (1) Keep in mind that the output pane in the WebConsole (currently) displays the result of the eval method, NOT the output stream of STDERR and/or STDOUT as the SUConsole does. (This is why for multiple statements you see only the result from the LAST statement.)

                              (2) The puts method returns nil so you won't see anything if Jim's code stripped textstring "nil" out.

                              I'm not here much anymore.

                              1 Reply Last reply Reply Quote 0
                              • Dan RathbunD Offline
                                Dan Rathbun
                                last edited by

                                @alexschreyer said:

                                @Chris Fullmer: Looking at the result capture code, it appears to convert characters such as the newline into HTML characters before sending it to the dialog. I tried to find a way around this - to no avail. Sending a newline \n to the execute_script doesn't work for me. Apparently that's why Jim put these conversions in there. I'll try later if there is an easier way to "encode" these before sending and "decode" them in Javascript in the dialog.

                                Yes the HTML conversion may be necessary for the WebDialog side but not for the STDOUT.

                                Alex YOU caused the HTML tags to also go to STDOUT by inserting the line "p r" AFTER the conversion gsub! statements. IF "p r" is needed, move it up before the conversion statements.

                                I'm not here much anymore.

                                1 Reply Last reply Reply Quote 0
                                • Dan RathbunD Offline
                                  Dan Rathbun
                                  last edited by

                                  @dan rathbun said:

                                  (2) The puts method returns nil so you won't see anything if Jim's code stripped textstring "nil" out.

                                  OK if a var evaluates to nil, and then you convert it to a String with .to_s, the result is an empty length String.

                                  So line 73 needs a nil test, thus:

                                  r!=nil ? r=r.to_s : r='nil'

                                  (Don't just have "r" as the boolean expression, because false values would get set to 'nil' instead of 'false'.)

                                  I'm not here much anymore.

                                  1 Reply Last reply Reply Quote 0
                                  • alexschreyerA Offline
                                    alexschreyer Extension Creator
                                    last edited by

                                    Thanks, Dan, for going through this so thoroughly. Everyone, please feel free to suggest code improvements. I would like to make this as useful as possible. Of course, I'll mention every help on the "About" tab.

                                    @Dan: I'll incorporate your revisions into the output code. That is really the part here that I had looked at the least.

                                    I like the idea of having tabbed multiple files. With the current tab support that should be relatively easy to implement.

                                    And thanks for the hint on the Windows UI look for IE. I didn't even know about the tag.

                                    Cheers,
                                    Alex

                                    Author of "Architectural Design with SketchUp":
                                    http://sketchupfordesign.com/

                                    1 Reply Last reply Reply Quote 0
                                    • Dan RathbunD Offline
                                      Dan Rathbun
                                      last edited by

                                      I think I see another problem. If an error occurs don't you need to abort the operation instead of committing it?

                                      Try something like this:

                                      
                                        add_action_callback("exec") do |webconsole_dialog, p|
                                          v = webconsole_dialog.get_element_value('console').strip
                                          # puts v    # what's this for -- testing ??
                                          r = nil
                                          begin
                                            Sketchup.active_model.start_operation "RubyEditor"
                                            begin # evaluation
                                              r = eval v
                                            rescue => e
                                              r = e
                                              raise # pass to outer rescue clause
                                            end # eval
                                          rescue
                                            Sketchup.active_model.abort_operation 
                                          else # only do if NO errors
                                            Sketchup.active_model.commit_operation
                                          ensure # always do this
                                            r!=nil ? r = r.to_s ; r='nil'
                                            p r
                                            r.gsub!(/ /, "&nbsp;")
                                            r.gsub!(/\n/, "<br>")
                                            r.gsub!(/'/, "&rsquo;")
                                            r.gsub!(/`/, "&lsquo;")
                                            r.gsub!(/</, "&lt;")
                                            webconsole_dialog.execute_script("document.getElementById('results').innerHTML='#{r}'")
                                          end
                                        end # callback
                                      
                                      

                                      I'm not here much anymore.

                                      1 Reply Last reply Reply Quote 0
                                      • Dan RathbunD Offline
                                        Dan Rathbun
                                        last edited by

                                        Alex.. you did not change the Name of the DefaultSettings Key ('WebCon'), so your plugin is overwriting the values for Jim's standard WebConsole in the registry.

                                        There is always the possibilty that some people may still wish to use Jim's "plain Jane" version from time to time, even with yours installed.

                                        You should setup a unique Keyname for your defaults.

                                        I'm not here much anymore.

                                        1 Reply Last reply Reply Quote 0
                                        • alexschreyerA Offline
                                          alexschreyer Extension Creator
                                          last edited by

                                          I'll change the dialog name. Must have overlooked that one. I changed the class name.

                                          In the meantime, I figured out how to get linebreaks from a file into a dialog.

                                          filename = UI.openpanel
                                          f = File.new(filename,"r")
                                          text = f.readlines.join.gsub!(/\n/, '<KghBr31sD>')
                                          
                                          ndlg = UI;;WebDialog.new("Ruby Web Console", true, "WebCon123", 600, 400, 100, 100, true)
                                          ndlg.set_html ("<html><head></head><body><textarea style='width;100%;height;100%' name='mybox' id='mybox'></textarea></body></html>")
                                          ndlg.show {
                                            ndlg.execute_script("var text = '#{text}';var asddsa = text.replace(/<KghBr31sD>/g,String.fromCharCode(13));document.getElementById('mybox').value = asddsa")
                                          }
                                          

                                          I think I saw the method (i.e. using a gibberish tag) discussed recently in the developers forum. I'll give that a try soon.

                                          Cheers,
                                          Alex

                                          Author of "Architectural Design with SketchUp":
                                          http://sketchupfordesign.com/

                                          1 Reply Last reply Reply Quote 0
                                          • chrisglasierC Offline
                                            chrisglasier
                                            last edited by

                                            @alexschreyer said:

                                            @chrisglasier: ... It can very well work with my editor.

                                            It is not your editor it belongs to Jim; what you did, as I did, was to dress it up. But I don't want to focus on individual efforts but more on why the cognoscenti allow software companies to fob us off with metaphors for paperwork rather than providing digital machines.

                                            Take for example your original cheat sheets and my/Jim's Sketchup API digital device which provided an opportunity to link up many other devices like the console. The style is not an issue and you are more adept at implementing the links than an amateur and reluctant coder like me; the code is freely available here.

                                            I am very disappointed that you ignored this opportunity to exploit a way to link up data (that belongs to objects that have names) and digital devices (that can automate common tasks).

                                            With TBA interfaces we can analyse what is to be achieved so that IT can help with automation to achieve it.

                                            1 Reply Last reply Reply Quote 0
                                            • 1
                                            • 2
                                            • 3
                                            • 1 / 3
                                            • First post
                                              Last post
                                            Buy SketchPlus
                                            Buy SUbD
                                            Buy WrapR
                                            Buy eBook
                                            Buy Modelur
                                            Buy Vertex Tools
                                            Buy SketchCuisine
                                            Buy FormFonts

                                            Advertisement