| <!DOCTYPE html> |
| <html lang="en"> |
| <head> |
| <meta charset="UTF-8"> |
| <!--[if IE]><meta http-equiv="X-UA-Compatible" content="IE=edge"><![endif]--> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <meta name="generator" content="Asciidoctor 1.5.4"> |
| <title>Eclipse Neon New and Noteworthy</title> |
| <style> |
| |
| </style> |
| <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.5.0/css/font-awesome.min.css"> |
| </head> |
| <body class="article"> |
| <div id="header"> |
| <h1>Eclipse Neon New and Noteworthy</h1> |
| <div id="toc" class="toc"> |
| <div id="toctitle">Table of Contents</div> |
| <ul class="sectlevel1"> |
| <li><a href="#platform">Platform</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_general">General</a></li> |
| <li><a href="#_look_and_feel">Look and Feel</a></li> |
| <li><a href="#_other_changes_and_improvements">Other Changes and Improvements</a></li> |
| </ul> |
| </li> |
| <li><a href="#java">Java™</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_java_9">Java 9</a></li> |
| <li><a href="#_java_editor">Java Editor</a></li> |
| <li><a href="#_java_views_wizards_and_other_ui">Java Views, Wizards, and Other UI</a></li> |
| <li><a href="#_debug">Debug</a></li> |
| <li><a href="#_null_analysis">Null Analysis</a></li> |
| </ul> |
| </li> |
| <li><a href="#cdt">C/C++</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_general_2">General</a></li> |
| <li><a href="#_debug_2">Debug</a></li> |
| <li><a href="#_other_change_and_improvements">Other Change and Improvements</a></li> |
| </ul> |
| </li> |
| <li><a href="#docker-tools">Docker Tools</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_general_3">General</a></li> |
| </ul> |
| </li> |
| <li><a href="#pdt">PHP</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_php_language">PHP Language</a></li> |
| <li><a href="#_editors">Editors</a></li> |
| <li><a href="#pdt-debugging">PHP Debugging</a></li> |
| </ul> |
| </li> |
| <li><a href="#js">JavaScript and JSON</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_javascript_development">JavaScript Development</a></li> |
| <li><a href="#_json_development">JSON Development</a></li> |
| </ul> |
| </li> |
| <li><a href="#modeling">Modeling</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_code_generation">Code Generation</a></li> |
| <li><a href="#_model_editors">Model Editors</a></li> |
| <li><a href="#_model_comparison">Model Comparison</a></li> |
| <li><a href="#_custom_graphical_editors">Custom Graphical Editors</a></li> |
| </ul> |
| </li> |
| <li><a href="#mylyn">Lifecycle Tools</a> |
| <ul class="sectlevel2"> |
| <li><a href="#_gerrit_connector">Gerrit Connector</a></li> |
| </ul> |
| </li> |
| <li><a href="#sources">Sources</a></li> |
| </ul> |
| </div> |
| </div> |
| <div id="content"> |
| <div id="preamble"> |
| <div class="sectionbody"> |
| <div class="videoblock"> |
| <div class="content"> |
| <iframe width="640" height="480" src="https://www.youtube.com/embed/hW0ENpGcP34?rel=0" frameborder="0" allowfullscreen></iframe> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="platform">Platform</h2> |
| <div class="sectionbody"> |
| <div class="sect2"> |
| <h3 id="_general">General</h3> |
| <div class="sect3"> |
| <h4 id="_import_projects">Import Projects</h4> |
| <div class="paragraph"> |
| <p>A new <strong>Import Projects</strong> wizard is available via the <code>File > Open Projects…​</code> |
| menu and via the general <code>Import…​</code> command under <code>General > Projects</code> from Folder |
| or Archive.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Compared to other ways to import or create projects, this wizard aims at being |
| a universal wizard that, from a source directory or archive, can detect and |
| configure various kinds of projects.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/import-projects.png" alt="import projects"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>This wizard relies on an extensible set of strategies that look at the content |
| of the import source to detect file types, project layout patterns, or even |
| look into some files in order to deduct which folders should be turned into |
| projects and how those should be configured. Configuration usually involves |
| setting up project natures and preferences.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The import strategies are contributed via the new extension point |
| org.eclipse.ui.ide.projectConfigurator, so that other IDE components can contribute |
| detection and configuration specific to the technology they’re supporting.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_search_in_binary_files">Search in binary files</h4> |
| <div class="paragraph"> |
| <p>The Search > File... dialog has a new option to search in binary files as well.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/search-binary-files.png" alt="search binary files"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>By default, the option is disabled, and matches are only reported in files that |
| have the <strong>Text</strong> content type, or in files that have no content type and don’t |
| contain the null character (\u0000).</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_automatic_save_of_dirty_editors">Automatic Save of dirty editors</h4> |
| <div class="paragraph"> |
| <p>Auto-save of dirty editors is now available in Eclipse. The autosave option is disabled by default. A new autosave preference page (Preferences > General > Editors > Autosave) is available and allows to enable/disable the autosave and change the interval of autosave. The countdown is reset on keyboard activity, mouse click, or when a popup is displayed (e.g. content assist, preference page, …​).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/autosave-preference-page.png" alt="autosave preference page"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_look_and_feel">Look and Feel</h3> |
| <div class="sect3"> |
| <h4 id="_resolution_based_image_auto_scaling">Resolution-based image auto-scaling</h4> |
| <div class="paragraph"> |
| <p>Images now automatically scale on high-DPI monitors on Windows and Linux, |
| similar to the Mac’s Retina support on OS X. In the absence of high-resolution |
| images, available images are automatically scaled proportionately to the |
| resolution of the monitor.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/swt-high-dpi.png" alt="swt high dpi"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_preference_setting_to_disable_css_based_theming">Preference setting to disable CSS based theming</h4> |
| <div class="paragraph"> |
| <p>You can disable the CSS-based styling of the Eclipse IDE via |
| Preferences > General > Appearance > Enable theming. This will prevent the Eclipse |
| Workbench from rendering custom colors, shades, and borders, and may result in better |
| performance.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/enable-disable-theming.png" alt="enable disable theming"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_full_screen">Full Screen</h4> |
| <div class="paragraph"> |
| <p>The Full Screen feature is now also available on Windows and Linux. You can toggle |
| the mode via shortcut (Alt+F11) or menu (Window > Appearance > Toggle Full Screen).</p> |
| </div> |
| <div class="paragraph"> |
| <p>When Full Screen is activated, you’ll see a dialog which tells you how to turn it off again.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_hide_the_window_toolbars">Hide the window toolbars</h4> |
| <div class="paragraph"> |
| <p>You can use the Toggle Visibility of all Toolbars command (via Quick Access: |
| Ctrl+3 or Command+3) to hide all currently visible toolbars of the currently |
| window. Selecting the command again, reveals these toolbars again. This allows |
| the developer to maximize the space available for editors and views. If you |
| minimize a stack after you selected this command, the minimized stack will be |
| visible until you trigger the command to hide the toolbars again. This allows |
| you to decide which minimized stacks are currently useful for you.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The following is a screenshot of the IDE with a maximized Java editor |
| and several toolbars visible.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/ide-with-toolbars.png" alt="ide with toolbars"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>The next screenshot shows the same maximized editor but with hidden toolbars.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/ide-full-screen.png" alt="ide full screen"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_word_wrap_in_text_editors">Word wrap in text editors</h4> |
| <div class="paragraph"> |
| <p>A Toggle Word Wrap button has been added to the workbench toolbar. |
| Shortcut: Alt+Shift+Y.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/word-wrap.png" alt="word wrap"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>By default, text editors are opened with word wrap disabled.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_commands_and_shortcuts_to_zoom_in_text_editors">Commands and shortcuts to zoom in text editors</h4> |
| <div class="paragraph"> |
| <p>In text editors, you can now use Zoom In (Ctrl++ or Ctrl+=) |
| and Zoom Out (Ctrl+-) commands to increase and decrease the font size.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Like a change in the General > Appearance > Colors and Fonts preference page, |
| the commands persistently change the font size in all editors of the same type. |
| If the editor type’s font is configured to use a default font, then that |
| default font will be zoomed.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_pinch_to_zoom_in_text_editors">Pinch to zoom in text editors</h4> |
| <div class="paragraph"> |
| <p>To temporarily zoom the editor font in text editors, use a "pinch" gesture on a |
| touchpad. Put two fingers on the touchpad and move them apart or together.</p> |
| </div> |
| <div class="paragraph"> |
| <p>To reset the original font size, rotate two fingers by at least 45°, or close |
| and reopen the editor (Navigate > Back).</p> |
| </div> |
| <div class="paragraph"> |
| <p>Those gestures only affect the current editor. Changes are neither propagated |
| to other editors nor persisted.</p> |
| </div> |
| <div class="admonitionblock note"> |
| <table> |
| <tr> |
| <td class="icon"> |
| <i class="fa icon-note" title="Note"></i> |
| </td> |
| <td class="content"> |
| SWT currently only supports these gestures on OS X and on Windows systems |
| that use the native multi-touch support. Touchpads that emulate mouse move/scroll |
| events don’t support gestures. Gesture support on GTK is not implemented yet. |
| </td> |
| </tr> |
| </table> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_directly_start_previously_selected_workspaces_in_the_launcher">Directly start previously selected workspaces in the launcher</h4> |
| <div class="paragraph"> |
| <p>The workspace selection dialog now allows you to start a previously selected |
| workspace directly via a link. The path to the workspace is shortened. The full |
| path is available if you hover over the link.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/recent-workspace-launcher.png" alt="recent workspace launcher"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You can remove existing entries via the context menu.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_selecting_the_text_editor_for_unassociated_file_types">Selecting the text editor for unassociated file types</h4> |
| <div class="paragraph"> |
| <p>On the Preferences > General > Editors > File Association page, you can now |
| define an editor selection strategy for unassociated file types. Three strategies |
| are provided out-of-the-box:</p> |
| </div> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p><em>Search Marketplace</em> (default) will use the Eclipse Marketplace Client to |
| search the <a href="http://marketplace.eclipse.org">Eclipse Marketplace</a> for plug-ins that |
| support the file type;</p> |
| </li> |
| <li> |
| <p><em>System Editor; if none: Text Editor</em> will open the system editor |
| associated with the file, if available. If no system editor is associated with |
| the given file, fall back to the Eclipse Text Editor;</p> |
| </li> |
| <li> |
| <p><em>Text Editor</em> will always open Eclipse’s Text Editor on unassociated file types; |
| and</p> |
| </li> |
| <li> |
| <p><em>Ask via pop-up</em> will open the same dialog as using Open With > Other... on a |
| file and let you choose which editor to use (inside or outside the IDE).</p> |
| </li> |
| </ul> |
| </div> |
| <div class="admonitionblock note"> |
| <table> |
| <tr> |
| <td class="icon"> |
| <i class="fa icon-note" title="Note"></i> |
| </td> |
| <td class="content"> |
| It’s possible to assign an editor for an <em>unassociated</em> |
| file type either via this same preference page, or via the Open With > Other... |
| context-menu on the file. |
| </td> |
| </tr> |
| </table> |
| </div> |
| <div class="paragraph"> |
| <p>The implementation comes with a new extension-point org.eclipse.ui.ide.unknownEditorStrategy |
| that allows external contributions of additional strategies.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_quick_access_improvements">Quick Access improvements</h4> |
| <div class="paragraph"> |
| <p>Quick Access (Ctrl+3) is a small text field in the toolbar. You can use it to |
| trigger any command in the Eclipse Workbench.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/eclipse-quick-access-improved-search.png" alt="eclipse quick access improved search"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You can now restrict the search to Views, Commands, etc. by typing the category name |
| followed by a colon. For example, to filter the list of all the views, start typing |
| "Views: " in the search-box.</p> |
| </div> |
| <div class="paragraph"> |
| <p>A few usability bugs have been fixed: The tooltip shows the keyboard shortcut, the |
| number of search results per category is independent of the size of the proposals |
| window, and the list with previous choices already opens when you click the field |
| with the mouse.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_new_welcome_screen">New Welcome Screen</h4> |
| <div class="paragraph"> |
| <p>The Welcome/Intro introduces a new <em>Solstice</em> theme that provides a new modern |
| appearance and enhanced functionality.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/eclipse-welcome-solstice.png" alt="eclipse welcome solstice"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>In Eclipse 3.x, the <em>Go to Workbench</em> button on the Welcome page would minimize |
| the Welcome page to the window status bar. This behavior has been restored.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/eclipse-welcome-launchbar.png" alt="eclipse welcome launchbar"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_other_changes_and_improvements">Other Changes and Improvements</h3> |
| <div class="sect3"> |
| <h4 id="_more">More</h4> |
| <div class="paragraph"> |
| <p>The look of the toolbar in the MacOS default theme was adjusted to align with |
| other MacOS applications.</p> |
| </div> |
| <div class="paragraph"> |
| <p>To save space in the toolbar, the perspective switcher has been changed to show |
| only the icons of perspectives by default. You can show the text again via the |
| context menu.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The 'date' variable, supported in editor and code templates, now allows you to |
| specify which format to use when inserting the current date (or time).</p> |
| </div> |
| <div class="paragraph"> |
| <p>The 'word_selection' and 'line_selection' variables, supported in editor and |
| code templates, now allow you to specify a default value to use if the current |
| text selection is empty.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The workspace name is now shown at the beginning of the window title by default. |
| The initial name is the name of the workspace directory.</p> |
| </div> |
| <div class="paragraph"> |
| <p>When you export your preference settings via <code>File > Export…​ > Preferences</code>, |
| the preferences are now sorted alphabetically in the resulting file.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Eclipse has been updated to include improved support for the Wayland display manager.</p> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="java">Java™</h2> |
| <div class="sectionbody"> |
| <div class="paragraph"> |
| <p>Eclipse Neon includes numerous bug fixes and improvements in the Java 8 |
| support, along with a lot of other useful features.</p> |
| </div> |
| <div class="sect2"> |
| <h3 id="_java_9">Java 9</h3> |
| <div class="sect3"> |
| <h4 id="_launching_on_java_9">Launching on Java 9</h4> |
| <div class="paragraph"> |
| <p>Launching Eclipse with recent Java 9 previews fails with <code>NoClassDefFoundErrors</code> for |
| <code>javax/annotation/PostConstruct</code> and similar types.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The workaround is to add the VM arguments</p> |
| </div> |
| <div class="literalblock"> |
| <div class="content"> |
| <pre>-addmods java.se.ee</pre> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>either on the command line after <code>-vmargs</code>, or at the end of the eclipse.ini file on |
| two separate lines.</p> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_java_editor">Java Editor</h3> |
| <div class="sect3"> |
| <h4 id="_ifnotnull_ifnull_templates">ifNotNull/ifNull templates</h4> |
| <div class="paragraph"> |
| <p>The Java editor now offers default templates for creating "== null" and "!= null" checks.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/if-null-template.png" alt="if null template"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_new_info_severity_level">New Info severity level</h4> |
| <div class="paragraph"> |
| <p>You can now specify <em>Info</em> as a severity level for the problems detected by the Eclipse |
| Java compiler.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/info-severity.png" alt="info severity"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>A new decorator has been added to indicate information severity problems detected by the |
| Eclipse Java Compiler.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/info-problem-decorator.png" alt="info problem decorator"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You can now configure the severity of a compiler problem by invoking the new <em>Quick Fix</em> |
| (<code>Ctrl+1</code>) which opens the <code>Java > Compiler > Errors/Warnings</code> preference page and |
| highlights the configurable problem.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/configure-problem-severity.png" alt="configure problem severity"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_substring_code_completion">Substring code completion</h4> |
| <div class="paragraph"> |
| <p>Content Assist now supports substring patterns. Enter any part of the desired proposal’s |
| text, and Content Assist will find it! For example, completing on <code>selection</code> proposes |
| all results containing <code>selection</code> as a substring.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/substring-code-completion.png" alt="substring code completion"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>This feature can be disabled using the <code>Show substring matches</code> option on the |
| <code>Java > Editor > Content Assist</code> preference page.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_clean_up_to_remove_redundant_type_arguments">Clean Up to remove redundant type arguments</h4> |
| <div class="paragraph"> |
| <p>A new option to remove redundant type arguments has been added under the |
| <em>Unnecessary Code</em> group of the Clean Up profile.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/remove-redundant-type-arguments.png" alt="remove redundant type arguments"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_new_options_in_code_formatter">New options in code formatter</h4> |
| <div class="paragraph"> |
| <p>In the new <em>Parentheses</em> tab, you can order the formatter to keep |
| parentheses of various Java elements on separate lines, i.e. put a |
| line break after the opening parenthesis and before the closing |
| parenthesis. This can be done always, only when parentheses are |
| not empty, or when their content is wrapped. There’s also an option |
| to preserve existing positions, if you want to manually manage parentheses |
| positions on a case-by-case basis.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/formatter-parentheses.png" alt="formatter parentheses"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>In the <em>Line Wrapping</em> tab, you can set the wrapping policy for parameterized |
| types, you can decide to wrap before or after operators in assignments and |
| conditional expressions, and you can control the wrapping policy of |
| <code>'for' loop headers</code>.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/formatter-wrap-for.png" alt="formatter wrap for"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>The <em>Align fields in columns</em> feature in the <em>Indentation</em> section can now |
| be configured to <em>recognize groups separated by empty lines</em> and align them |
| independently.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/formatter-align-groups.png" alt="formatter align groups"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>In the <em>New lines</em> section, you can control if new lines should be added |
| after annotations on <code>enum</code> constants.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/formatter-enum-constants.png" alt="formatter enum constants"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_create_new_fields_from_method_parameters">Create new fields from method parameters</h4> |
| <div class="paragraph"> |
| <p>You can now assign all parameters of a method or constructor to new fields |
| at once using the new <em>Quick Assist</em> (<code>Ctrl+1</code>):</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/assign-all-params-to-new-fields.png" alt="assign all params to new fields"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_java_views_wizards_and_other_ui">Java Views, Wizards, and Other UI</h3> |
| <div class="sect3"> |
| <h4 id="_project_explorer_improvements">Project Explorer Improvements</h4> |
| <div class="paragraph"> |
| <p>The <em>Project Explorer</em> view now groups referenced libraries in a new container node.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/show-referenced-libraries-node-project-explorer.png" alt="show referenced libraries node project explorer"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You can now hide empty library containers in the <em>Project Explorer</em> view by selecting |
| the new filter in its <em>Customize View…​</em> dialog.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/hide-empty-library-containers-project-explorer.png" alt="hide empty library containers project explorer"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_add_meta_annotations_while_creating_a_new_java_annotation_type">Add meta-annotations while creating a new Java annotation type</h4> |
| <div class="paragraph"> |
| <p>You can now choose to add <code>@Retention</code>, <code>@Target</code> and <code>@Documented</code> meta-annotations |
| along with their applicable values while creating a new Java annotation type.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/add-meta-annotations.png" alt="add meta annotations"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_search_on_multi_selections">Search on multi-selections</h4> |
| <div class="paragraph"> |
| <p>You can now select multiple elements in views like <em>Package Explorer</em> and |
| <em>Outline</em> and then search for <em>References</em>, <em>Declarations</em>, <em>Implementors</em>, |
| and <em>Read/Write Access</em> (where applicable):</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/search-on-multi-selections.png" alt="search on multi selections"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You can even select results in the <em>Search</em> view and start a new search for those |
| elements. To follow method call chains, you’d probably use <em>Open Call Hierarchy</em>, |
| though.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_junit_support">JUnit Support</h4> |
| <div class="paragraph"> |
| <p>Assertions are now enabled by default for new JUnit launch configurations. You can |
| disable this on the <code>Preferences > Java > JUnit</code> page.</p> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_debug">Debug</h3> |
| <div class="sect3"> |
| <h4 id="_installing_breakpoints_from_unrelated_projects">Installing breakpoints from unrelated projects</h4> |
| <div class="paragraph"> |
| <p>Multiple versions of the same Java type can be available in a workspace, and |
| each version can have breakpoints configured at different source locations. When |
| debugging, JDT tries to determine the "right" set of breakpoints to install in |
| the target VM. This analysis now uses Java project dependencies by default.</p> |
| </div> |
| <div class="paragraph"> |
| <p>To always install all enabled breakpoints, you can disable the new option |
| <code>Preferences > Java > Debug > Do not install breakpoints from unrelated projects</code>.</p> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_null_analysis">Null Analysis</h3> |
| <div class="sect3"> |
| <h4 id="_multiple_sets_of_null_annotations">Multiple sets of null annotations</h4> |
| <div class="paragraph"> |
| <p>You can now configure annotation-based null analysis to use multiple sets of |
| annotation types. This is relevant if your project uses 3rd party libraries |
| that already use null annotations in their API, where the annotations used in |
| a library may be different from those used in the current project.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Please open the dialog for configuring null annotation types from the project |
| properties at <code>Java Compiler > Errors/Warnings > Null analysis</code>:</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/prefs-errors-warnings.png" alt="prefs errors warnings"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>In the dialog that opens, only one primary set of annotations is supported; |
| these are the annotations which JDT actively uses in <em>Quick Fixes</em>, error |
| messages etc. These annotations must be present on the project’s build path.</p> |
| </div> |
| <div class="paragraph"> |
| <p>You can now add an arbitrary number of secondary <code>null</code> annotation types, to |
| be evaluated when reading class files external to the project. Within the |
| configuration dialog, Content Assist is offered based on accessible annotation |
| types, but for secondary annotation types unresolved names will be tolerated. |
| This avoids the need to bloat the build path with transitive compile-time |
| dependencies.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/annotation-selection.png" alt="annotation selection"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_improved_code_null_code_analysis_with_generics">Improved <code>null</code> analysis with generics</h4> |
| <div class="paragraph"> |
| <p>The interplay of <code>null</code> annotations and generics has been improved in several |
| regards.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The basic concepts had already been documented in the online help, but not |
| all that was documented was actually checked by <code>null</code> analysis. With |
| the changes outlined below, null analysis based on type annotations is even |
| more capable than previous versions.</p> |
| </div> |
| <div class="paragraph"> |
| <p>(1) The first batch of contributed improvements implements what we call |
| <em>pessimistic analysis for free type variables</em>, which affects implementors |
| of generic types.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/pessimistic-analysis.png" alt="pessimistic analysis"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>In order to allow clients to instantiate such a generic class with either |
| a <code>@NonNull</code> or a <code>@Nullable</code> type as substitution for the "free type variable" |
| <code><T></code>, the implementation of that class must account for the worst in both |
| directions:</p> |
| </div> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p>To anticipate a <code>@NonNull</code> type, each field typed to a free type variable |
| must be initialized with a non-<code>null</code> value, and passing <code>null</code> where <code>T</code> is |
| expected is illegal; and</p> |
| </li> |
| <li> |
| <p>To anticipate a <code>@Nullable</code> type, each dereference must be preceded by a <code>null</code> check.</p> |
| </li> |
| </ul> |
| </div> |
| <div class="paragraph"> |
| <p>At the bottom of each problem hover, you will find a link to the corresponding |
| configuration option, should you like to change the severity of this diagnostic. |
| Note that configurability is mainly given for smooth migration from previous |
| JDT version; conceptually, problems detected by pessimistic analysis should be |
| treated as errors, because they invalidate the null-guarantees given by a generic |
| type.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/configure-pessimistic-analysis.png" alt="configure pessimistic analysis"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>(2) The second improvement concerns consumption of generic types from a library, |
| more specifically: invocations of library methods whose return type is given by |
| a free type variable.</p> |
| </div> |
| <div class="paragraph"> |
| <p>If the library type is instantiated with a <code>@NonNull</code> type as the type argument, |
| we generally want to interpret the mentioned return type as non-<code>null</code>, too. |
| This is problematic only for some "legacy" methods, which may return <code>null</code> |
| without declaring so. The most prominent example is <code>java.util.Map.get(K)</code>.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The analysis cannot see whether absence of a null annotation for such a return |
| type is intentional (in the above sense of "free type variables"), or an omission |
| that should be fixed. For that reason a new warning has been implemented to alert |
| about this situation.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/unsafe-nonnull-interpretation.png" alt="unsafe nonnull interpretation"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>In the above example, both fields list and map provide <code>@NonNull</code> <code>String</code> as a type |
| argument, hence the return types of both <em>get</em> methods are interpreted as non-<code>null</code>. |
| For <code>List</code> this is desired, for <code>Map</code> it is a bug.</p> |
| </div> |
| <div class="paragraph"> |
| <p>The dilemma can be resolved by adding a (possibly empty) external annotation file |
| (<code>.eea</code>) to each affected library class. By using an empty annotation file, the user |
| signals that all types in this class should be interpreted verbatim (like in the |
| <code>List</code> case - use with care). In the other case, the missing <code>@Nullable</code> annotation |
| should be added as an external annotation (like in the <code>Map</code> case).</p> |
| </div> |
| <div class="paragraph"> |
| <p>In a project that is not yet configured to use external annotations for the |
| library in question, the warning is demoted to level "information". Generally, the |
| severity of this problem is configured using the option right below the one mentioned |
| above, titled <code>Unsafe '@NonNull'</code> interpretation of free type variable from library.</p> |
| </div> |
| <div class="paragraph"> |
| <p>(3) Finally, a small utility class, <code>org.eclipse.jdt.annotation.Checks</code>, has been |
| included in the bundle <code>org.eclipse.jdt.annotation_2.1.0</code> containing helper methods |
| for typical idioms for improving and documenting <code>null</code> safety.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_quick_fix_to_add_code_nonnull_code_to_local_variable">Quick Fix to add <code>@NonNull</code> to local variable</h4> |
| <div class="paragraph"> |
| <p>When a "potential null pointer access" problem is raised against a local variable, |
| the reason is not always obvious. Perhaps <code>null</code> is assigned somewhere deep inside |
| a complex control flow. If annotation-based <code>null</code> analysis is enabled, a new |
| <em>Quick Fix</em> is offered (<code>Ctrl+1</code>), that adds a <code>@NonNull</code> annotation to the local |
| variable.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/add-nonnull1.png" alt="add nonnull1"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>While this may not produce correct code, it tells the compiler your intention to |
| not allow <code>null</code> in this variable, and subsequently the compiler will answer with more |
| helpful warnings or errors pointing to the root problem. In the given example, |
| it will alert you of subtleties about using unconstrained type variables.</p> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="cdt">C/C++</h2> |
| <div class="sectionbody"> |
| <div class="paragraph"> |
| <p>Eclipse Neon includes many improvements in stability and some new |
| functionality for C/C++ developers.</p> |
| </div> |
| <div class="sect2"> |
| <h3 id="_general_2">General</h3> |
| <div class="sect3"> |
| <h4 id="_import_projects_2">Import Projects</h4> |
| <div class="paragraph"> |
| <p>When code completion is invoked in a function call expression, appropriate |
| substitutions are suggested for each of the function parameters.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Function_call.png" alt="Function call"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_create_new_class_quick_fix">Create New Class - Quick Fix</h4> |
| <div class="paragraph"> |
| <p>In C files if "Type not found" error is detected, there is a new *Quick Fix* |
| now to create a class based on that type, which opens the *New C Class Wizard*. |
| Note: to enable quick user must enable "Type cannot be resolved" problem in |
| "Code Analysis" settings</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/CPPnewClass.png" alt="CPPnewClass"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_format_edited_lines_save_action">Format Edited Lines Save Action</h4> |
| <div class="paragraph"> |
| <p>It is now possible to format either the whole file or only the edited lines when a source or a |
| header file is saved.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Save_Actions.png" alt="Save Actions"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_suppressions_in_code">Suppressions in code</h4> |
| <div class="paragraph"> |
| <p>It is now possible to suppress code analysis errors/warnings by adding comments in the code.</p> |
| </div> |
| <div class="literalblock"> |
| <div class="content"> |
| <pre>x = x; // @suppress("assignment in condition") because I know better</pre> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>The comment is actually configurable using problem parameters (@suppress(<title>) is default).</p> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_debug_2">Debug</h3> |
| <div class="sect3"> |
| <h4 id="_gdbserver_options">Gdbserver options</h4> |
| <div class="paragraph"> |
| <p>For automatic remote debugging sessions, CDT now supports specifying extra options |
| that will be passed to gdbserver when starting it. This way, users could activate |
| debug messages (<code>--debug</code>), benefit of wrapper option (<code>--wrapper</code>) that gdbserver |
| supports or use the other available command-line options of gdbserver.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Gdbserver-settings-tab.PNG" alt="Gdbserver settings tab"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_os_resources_view_improvements">OS Resources View Improvements</h4> |
| <div class="paragraph"> |
| <p>The <em>OS Resources</em> view displays different information about the resources of the operating |
| system, such as list of all processes running on the target or files opened by processes |
| on target.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Now it is possible to attach to processes associated with selected resources directly |
| from <em>OS Resources</em> view without resorting to "Connect to a process" button from Debug View.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/OS_Resources_Attach.JPG" alt="OS Resources Attach"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>This feature requires non-stop mode support to be activated.</p> |
| </div> |
| <div class="paragraph"> |
| <p>OS Resources View lists a lot of text information. Now it is possible to copy selected lines |
| to the clipboard to save for later comparison.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_debug_ux">Debug UX</h4> |
| <div class="paragraph"> |
| <p>In an effort to reduce clutter, the Connect button was removed from the Debug toolbar. The action is still available from the Debug view context-menu as shown below. Furthermore, connecting to a process can now be done using the OS Resources view as described in this section.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/CDT_Removed_Connect_Button.png" alt="CDT Removed Connect Button"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>To streamline the UI, the "New…​" button of the Connect dialogue which was used to create a new process has been removed. This action is available instead from the Debug view context-menu as shown below.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/CDT_RemoveNewButton.png" alt="CDT RemoveNewButton"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_other_change_and_improvements">Other Change and Improvements</h3> |
| <div class="paragraph"> |
| <p>The <em>Makefile Editor</em> now provides a single key <code>Ctrl+/</code> to toggle comments rather than |
| have <code>Ctrl+/</code> to comment and <code>Ctrl+\</code> to uncomment. This is consistent with CDT and Java editors.</p> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="docker-tools">Docker Tools</h2> |
| <div class="sectionbody"> |
| <div class="sect2"> |
| <h3 id="_general_3">General</h3> |
| <div class="sect3"> |
| <h4 id="_dockerfile_editor">Dockerfile Editor</h4> |
| <div class="paragraph"> |
| <p>The 'Dockerfile Editor' provides users with content |
| assist on the commands (<code>ADD</code>, <code>COPY</code>, <code>RUN</code>, etc.) as well as a customizable |
| syntax highlighting.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Dockerfile-editor.png" alt="Dockerfile editor"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_executing_shell_in_a_container">Executing shell in a container</h4> |
| <div class="paragraph"> |
| <p>Users can be given access to a shell environment within the container |
| even if the container has a service running in the foreground. This is |
| particularly useful for examining the container, and for debugging |
| purposes.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Docker-exec-shell.png" alt="Docker exec shell"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_running_privileged_containers">Running privileged containers</h4> |
| <div class="paragraph"> |
| <p>Containers can be run with the <code>--privileged</code> flag, which gives them |
| extended privileges, such as accessing all devices, and allowing them |
| nearly all the same access to the host as regular processes running on |
| the host (i.e., not in containers).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Docker-privileged-option.png" alt="Docker privileged option"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_supporting_disconnections">Supporting disconnections</h4> |
| <div class="paragraph"> |
| <p>Sometimes the Docker instances that were configured in Eclipse are not |
| running anymore (the Docker Machine is stopped, for example). In that |
| case, the <em>Docker Explorer</em> view will display a different decorator for |
| those connections, and an "Enable connection" button in the toolbar will |
| let the user reconnect.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Docker-disabled-connection.png" alt="Docker disabled connection"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_editing_connection_settings">Editing connection settings</h4> |
| <div class="paragraph"> |
| <p>A new wizard lets the user edit the connection name, and settings. This |
| is particularly useful when the connection belongs to a Docker Machine |
| whose IP address changed upon restart.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Docker-edit-connection.png" alt="Docker edit connection"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_pushing_pulling_searching_for_authenticated_registries">Pushing/Pulling/Searching for Authenticated Registries</h4> |
| <div class="paragraph"> |
| <p>Support now exists for performing actions upon Docker registries using |
| authentication credentials. Users can simply set their credentials in |
| the workspace preference page (<em>Docker/Registry Accounts</em>).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Docker-registry-accounts.png" alt="Docker registry accounts"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>These credentials may be accessed through the <em>Registry/Account</em> combo box |
| in the <em>Push/Pull Wizards</em>. The location of a registry can also be entered |
| manually if it doesn’t require any credentials.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Docker-account-pull-image.png" alt="Docker account pull image"> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="pdt">PHP</h2> |
| <div class="sectionbody"> |
| <div class="paragraph"> |
| <p>The Eclipse Neon release includes significant improvements in |
| stability (including fixes for more than 100 bugs) and a lot of new |
| functionality for PHP developers.</p> |
| </div> |
| <div class="sect2"> |
| <h3 id="_php_language">PHP Language</h3> |
| <div class="paragraph"> |
| <p>Eclipse Neon provides better error messages for unsupported PHP |
| versions (especially for legacy versions).</p> |
| </div> |
| <div class="sect3"> |
| <h4 id="pdt-php7">PHP 7</h4> |
| <div class="paragraph"> |
| <p>PHP 7 is the default version for new workspaces.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt37_php7.jpg" alt="Pdt37 php7"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Final support for PHP 7 scalar type declarations.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_scalar.png" alt="Pdt40 scalar"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>The syntax highlighter now fully supports PHP 7 context sensitive |
| keywords.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_context_sensitive.png" alt="Pdt40 context sensitive"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_editors">Editors</h3> |
| <div class="sect3"> |
| <h4 id="_code_assist">Code Assist</h4> |
| <div class="paragraph"> |
| <p>The PHP validator identifies non abstract methods without body.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_no_body.png" alt="Pdt40 no body"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Inappropriate use of multiple access modifiers (eg. <code>public</code> <code>private</code> |
| functions)</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_multiple_access_modifiers.png" alt="Pdt40 multiple access modifiers"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>The validator no longer analyzes PHP comments (except in <em>PHPDoc</em> comments).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_use.png" alt="Pdt40 use"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Improved Code Assist for <code>@param</code>, <code>@return</code>, and <code>@throws</code> tags |
| inside <em>PHPDoc</em></p> |
| </div> |
| <div class="paragraph"> |
| <p><span class="image"><img src="images/Pdt37_ca1.png" alt="Pdt37 ca1"></span> <span class="image"><img src="images/Pdt37_ca2.png" alt="Pdt37 ca2"></span></p> |
| </div> |
| <div class="paragraph"> |
| <p>The PHP indexer is significantly faster than in previous versions. |
| The UI remains responsive when indexing is in progress.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Better task tags (e.g. <code>@todo</code>) detection</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_task_tags.png" alt="Pdt40 task tags"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Methods and functions are visible as <code>void</code> only if they do not have |
| <code>return</code> and <code>yield</code> statements. The otherwise have the declared |
| return type or <code>mixed</code>.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_return_types.png" alt="Pdt40 return types"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Simple types (<code>int</code>, <code>bool</code>, <code>string</code>, …​) are included in the |
| suggestions for for PHP >= 7 function return types.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_return_sugestion.png" alt="Pdt40 return sugestion"> |
| </div> |
| </div> |
| <div class="sect4"> |
| <h5 id="_more_code_assist">More Code Assist</h5> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p>Improved Code Assist for unfinished class and method bodies;</p> |
| </li> |
| <li> |
| <p>Improved support around <code>@inheritdoc</code> (coloring and code assist).</p> |
| </li> |
| </ul> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_highlighting">Highlighting</h4> |
| <div class="paragraph"> |
| <p>More semantic highlighters are enabled by default, including class, |
| deprecation, and constants.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_default_highlighters.png" alt="Pdt40 default highlighters"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Improved highlighting for <code>array</code> type.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_array_highlight.png" alt="Pdt40 array highlight"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Added support for <code>instanceof</code> and <code>insteadof</code> in class semantic |
| highlighter.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_class_instanceof.png" alt="Pdt40 class instanceof"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Assign to local quick assist (<code>ctrl/cmd + 2 + L</code>)</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_assign_to_local.png" alt="Pdt40 assign to local"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Function / method return types are available in Content Assist |
| proposals</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_ca_return_types.png" alt="Pdt40 ca return types"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Content Assist now supports colored labels</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_colored_labels.png" alt="Pdt40 colored labels"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_php_editor_commands">PHP Editor Commands</h4> |
| <div class="paragraph"> |
| <p>Buttons have been added to the editor toolbar to enable/disable <em>Word wrap</em>, |
| <em>Block selection</em>, and <em>Show white space characters</em>.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_editor_actions.png" alt="Pdt40 editor actions"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_more_php_editor_improvemvents">More PHP Editor Improvemvents</h4> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p>Improved code assist performance for files with many assignments;</p> |
| </li> |
| <li> |
| <p>General performance improvements for <em>PHPDoc</em> generation</p> |
| </li> |
| <li> |
| <p>Smart parenthesis works correctly inside closures</p> |
| </li> |
| <li> |
| <p><code>abstract</code> keyword is no longer proposed inside method body</p> |
| </li> |
| <li> |
| <p>Deprecated highlighting is shown even if class in same namespace</p> |
| </li> |
| <li> |
| <p>Content assist and hover tooltips shows function / method return types</p> |
| </li> |
| <li> |
| <p>Improved deprecation highlighter support for inherited members</p> |
| </li> |
| </ul> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_ide_integration">IDE Integration</h4> |
| <div class="paragraph"> |
| <p>Integration with the <em>Project Explorer</em> view has been improved, |
| including dedicated support for PHP Project elements and specific actions, |
| and support for traits when the "group by namespace" option is selected.</p> |
| </div> |
| <div class="paragraph"> |
| <p>PHP Language Libraries have PHP Version badge</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt40_php_version_badge.png" alt="Pdt40 php version badge"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>"Add PHP support…​" no longer visible in PHP-enabled projects (i.e. when |
| it is unnecessary).</p> |
| </div> |
| <div class="paragraph"> |
| <p>PHP <em>Quick Fixes</em> are available in <em>Problems View</em>.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt37_quickfix.png" alt="Pdt37 quickfix"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="pdt-debugging">PHP Debugging</h3> |
| <div class="paragraph"> |
| <p>Eclipse Neon includes numerous bug fixes and improvements in the PHP |
| Debugging.</p> |
| </div> |
| <div class="sect3"> |
| <h4 id="_exception_breakpoints">Exception Breakpoints</h4> |
| <div class="paragraph"> |
| <p>Support for PHP exception breakpoints</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/Pdt-ExceptionBP.png" alt="Pdt ExceptionBP"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_more_debugging">More Debugging</h4> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p>OSX support improvements</p> |
| </li> |
| <li> |
| <p>Improvements in debugger variables support</p> |
| </li> |
| <li> |
| <p>No longer display outdated values</p> |
| </li> |
| <li> |
| <p>Fix ignored breakpoints</p> |
| </li> |
| <li> |
| <p>Added support for class statics inside namespace</p> |
| </li> |
| <li> |
| <p>Remove PDT "Parameter Stack" view (the <em>Variables</em> view renders this outdated <em>Parameter Stack</em> view as redundant and useless).\</p> |
| </li> |
| <li> |
| <p>Breakpoints work with linked resources</p> |
| </li> |
| <li> |
| <p>Xdebug debugging via SSH tunnel</p> |
| </li> |
| </ul> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="js">JavaScript and JSON</h2> |
| <div class="sectionbody"> |
| <div class="sect2"> |
| <h3 id="_javascript_development">JavaScript Development</h3> |
| <div class="sect3"> |
| <h4 id="_new_ecmascript_2015_parser">New EcmaScript 2015 Parser</h4> |
| <div class="paragraph"> |
| <p>Significant new work has been invested in the JavaScript development tools, |
| starting with a new parser with EcmaScript 2015 (ES6) support. With this, |
| the Eclipse IDE recognizes and support ES6 language constructs and provides |
| better validation accuracy compared to the earlier parser.</p> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_libraries_and_tools">Libraries and Tools</h4> |
| <div class="paragraph"> |
| <p>Both Bower and npm are supported with creation wizards and launch shortcuts |
| for executing update and install commands. Grunt and gulp build systems are |
| accessible from within the <em>Project Explorer</em> view and can be executed via |
| launch shortcuts.</p> |
| </div> |
| <div class="paragraph"> |
| <p><code>Node.js</code> runtimes are now directly supported (<code>Eclipse Preferences > JavaScript > Runtimes</code>) |
| including a new launch configuration type can be used to run and debug |
| <code>Node.js</code> applications. <code>Node.js</code> applications can be debugged directly |
| from the editor via the Chromium V8 debugger, with full support for breakpoints |
| and inspecting JavaScript variable values in the <em>Variables</em> view (and when |
| you hover over an in-scope variable).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/v8_debugger.png" alt="v8 debugger"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_json_development">JSON Development</h3> |
| <div class="sect3"> |
| <h4 id="_json_editor">JSON Editor</h4> |
| <div class="paragraph"> |
| <p>The new <code>JSON</code> editor provides support to edit some well-known <code>JSON</code> file |
| types including package.json, bower.json, .bowerrc, and .jshintrc. This support |
| includes the following features:</p> |
| </div> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p>Syntax Coloring which can be customized with preferences;</p> |
| </li> |
| <li> |
| <p>An Outline Tree view;</p> |
| </li> |
| <li> |
| <p>Text hover on JSON Objects/Array keys and values;</p> |
| </li> |
| <li> |
| <p>Text folding on JSON Objects and Arrays; and</p> |
| </li> |
| <li> |
| <p>Editor extensions for custom hyperlinks, json schema validation, and hover help</p> |
| </li> |
| </ul> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/json_editor.png" alt="json editor"> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="modeling">Modeling</h2> |
| <div class="sectionbody"> |
| <div class="sect2"> |
| <h3 id="_code_generation">Code Generation</h3> |
| <div class="sect3"> |
| <h4 id="_builds">Builds</h4> |
| <div class="paragraph"> |
| <p><a href="http://www.eclipse.org/acceleo">Acceleo</a> introduced a new mechanism to launch code generators as part of a Maven build which is way easier and more robust by integrating with Tycho.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/acceleo-launcher.png" alt="acceleo launcher"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You will find several examples in <a href="https://github.com/cbrun/acceleo-launcher-examples/">this repository</a> ranging from launchging an UML to <code>C</code> code generation to exporting a Modeling project as a website.</p> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_model_editors">Model Editors</h3> |
| <div class="sect3"> |
| <h4 id="_amalgam">Amalgam</h4> |
| <div class="paragraph"> |
| <p>The <a href="http://www.eclipse.org/modeling/amalgam">Amalgam</a> project brings a new view to navigate and explore models. Ecore models are supported right away and the view can be extended to support your domain specific models.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/amalgam-explorer.png" alt="amalgam explorer"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_ecoretools">EcoreTools</h4> |
| <div class="paragraph"> |
| <p>When using the Ecore graphical modeler references might now be displayed directly within the class shapes if it’s target is not in the diagram.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/ecoretools-refnodes.png" alt="ecoretools refnodes"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Inherited references will also be displayed if the super types are not in the diagram.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/ecoretools-inheritedcontent.png" alt="ecoretools inheritedcontent"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_emf_parsley">EMF Parsley</h4> |
| <div class="paragraph"> |
| <p><a href="http://www.eclipse.org/emf-parsley">EMF Parsley</a> is a lightweight framework that allows |
| easy and quick UI development based upon EMF. EMF Parsley is built on top of the EMF |
| Edit framework and it implements features like Trees, Forms and Table builders with |
| standard JFace databinding, providing a complete component-based toolset. EMF Parsley |
| can be configured to use all kinds of EMF persistence implementations (XMI, Teneo, CDO).</p> |
| </div> |
| <div class="paragraph"> |
| <p>Moreover a DSL allows to easily customize several behaviors in each component.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/parsley-components.png" alt="parsley components"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_model_comparison">Model Comparison</h3> |
| <div class="sect3"> |
| <h4 id="_visual_comparison_and_merge">Visual Comparison and Merge</h4> |
| <div class="paragraph"> |
| <p>The Neon release brings experimental support for comparing diagrams of <a href="http://www.eclipse.org/sirius">Sirius</a> based modelers.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/compare-sirius-family.png" alt="compare sirius family"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>With a right-click on a model element or resource in the viewer, a new context menu now offers you to merge all <em>non-conflicting</em> differences that are <em>contained</em> in the selected model element or resource with one click.</p> |
| </div> |
| <div class="paragraph"> |
| <p>With local models (both writable):</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/compare-local.png" alt="compare local"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>With a read-only side (for example when comparing against a previous version in Git):</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/compare-readonly.png" alt="compare readonly"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>Each button now has a specific tooltip for each case depending on the selected element. It will display the best information depending on the context: which object will be affected by the merge action, and which side will be modified (or not) by the action.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/compare-context-tooltips.png" alt="compare context tooltips"> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect2"> |
| <h3 id="_custom_graphical_editors">Custom Graphical Editors</h3> |
| <div class="sect3"> |
| <h4 id="_rich_property_views">Rich Property Views</h4> |
| <div class="paragraph"> |
| <p>With the new version of <a href="http://www.eclipse.org/sirius">Sirius</a> you can now define rich property views alongside the diagram definition without having to write a line of code.</p> |
| </div> |
| <div class="paragraph"> |
| <p>This capability is introduced as an experimental feature for Eclipse Neon and will be extended in the next months based on the user community feedback.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/sirius-properties.png" alt="sirius properties"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_image_rendering">Image Rendering</h4> |
| <div class="paragraph"> |
| <p>Packs of SVG shapes can now be contributed through a plug-in to be reused in other modelers:</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/svg-stencils.png" alt="svg stencils"> |
| </div> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/svg-stencils-pick.gif" alt="svg stencils pick"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>SVG rendering has been improved and is now pixel-perfect <a href="https://bugs.eclipse.org/bugs/show_bug.cgi?id=442268">whatever the zoom level</a>.</p> |
| </div> |
| <div class="paragraph"> |
| <p>Before:</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/svg-render-before.png" alt="svg render before"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>With Sirius 4.0:</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/svg-render-after.png" alt="svg render after"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>It is now possible to define dash edge styles for both the nodes and the containers (like it was already possible for edges).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/sirius-border-styles.png" alt="sirius border styles"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>And the border node position relative to its parent can now be constrained on a specific side (NORTH, EAST, WEST or SOUTH).</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/bordernodeposition.png" alt="bordernodeposition"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_more_2">More</h4> |
| <div class="paragraph"> |
| <p>The <em>Link with editor</em> support has been improved and is now bidirectional.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/bidi-link.gif" alt="bidi link"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>You now have the possibility to configure which elements to automatically select after a tool execution, using this it is possible to streamline the user experience |
| by making sure that it is always possible to directly type right after the application of the tool.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/elements-to-select.png" alt="elements to select"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>The labels which are attached to an edge are now staying closer to it during a user modification.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/edge-stability.gif" alt="edge stability"> |
| </div> |
| </div> |
| <div class="paragraph"> |
| <p>A new mechanism is introduced to externalize the messages in a <code>.odesign</code> model.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/i18n.png" alt="i18n"> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="mylyn">Lifecycle Tools</h2> |
| <div class="sectionbody"> |
| <div class="sect2"> |
| <h3 id="_gerrit_connector">Gerrit Connector</h3> |
| <div class="sect3"> |
| <h4 id="_build_status_on_patch_sets">Build Status on Patch Sets</h4> |
| <div class="paragraph"> |
| <p>The status of builds triggered by a patch set is shown on that patch set instead of appearing as comments. If the Hudson/Jenkins connector is installed, users can open the test results in the JUnit view directly from the patch set. This may not work if the Gerrit trigger plugin is configured with custom messages.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/gerrit-builds.png" alt="gerrit builds"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_task_to_review_traceability">Task to Review Traceability</h4> |
| <div class="paragraph"> |
| <p>The task editor contains a section showing the reviews associated with the task, and indicates which reviews have unread incoming changes.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/reviews-section.png" alt="reviews section"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_comment_threads">Comment Threads</h4> |
| <div class="paragraph"> |
| <p>Inline comments are shown in threads, directly in the patch sets section in the review editor. This makes it easy to see the conversation taking place at a given line of code. Unread incoming comments are highlighed in blue.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/review-comment-threads.png" alt="review comment threads"> |
| </div> |
| </div> |
| </div> |
| <div class="sect3"> |
| <h4 id="_inline_comments">Inline Comments</h4> |
| <div class="paragraph"> |
| <p>Inline comments can now be edited and replied to inline, without opening a separate dialog.</p> |
| </div> |
| <div class="imageblock"> |
| <div class="content"> |
| <img src="images/inline-comments.png" alt="inline comments"> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div class="sect1"> |
| <h2 id="sources">Sources</h2> |
| <div class="sectionbody"> |
| <div class="paragraph"> |
| <p>Content for this document were harvested from multiple sources, including:</p> |
| </div> |
| <div class="ulist"> |
| <ul> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M1/">Eclipse Project Neon (4.6) M1 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M2/">Eclipse Project Neon (4.6) M2 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M3/">Eclipse Project Neon (4.6) M3 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M4/">Eclipse Project Neon (4.6) M4 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M5/">Eclipse Project Neon (4.6) M5 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M6/">Eclipse Project Neon (4.6) M6 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/eclipse/news/4.6/M7/">Eclipse Project Neon (4.6) M7 - New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://wiki.eclipse.org/CDT/User/NewIn90">Eclipse C/C++ Development Tools 9.0 New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://wiki.eclipse.org/Linux_Tools_Project/News/NewIn50">Eclipse Linux Tools 5.0.0 New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://wiki.eclipse.org/PDT/NewIn37">Eclipse PHP Development Tools 3.7 New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://wiki.eclipse.org/PDT/NewIn40">Eclipse PHP Development Tools 4.0 New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/mylyn/new/showVersion.php?version=new-3.17.html">Eclipse Mylyn 3.17 New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/mylyn/new/showVersion.php?version=new-3.18.html">Eclipse Mylyn 3.18 New and Noteworthy</a></p> |
| </li> |
| <li> |
| <p><a href="https://www.eclipse.org/mylyn/new/showVersion.php?version=new-3.19.html">Eclipse Mylyn 3.19 New and Noteworthy</a></p> |
| </li> |
| </ul> |
| </div> |
| </div> |
| </div> |
| </div> |
| <div id="footer"> |
| <div id="footer-text"> |
| Last updated 2016-09-28 10:30:40 EDT |
| </div> |
| </div> |
| </body> |
| </html> |