Top Qs
Timeline
Chat
Perspective
Comparison of text editors
From Wikipedia, the free encyclopedia
Remove ads
This article provides basic comparisons for notable text editors. More feature details for text editors are available from the Category of text editor features and from the individual products' articles. This article may not be up-to-date or necessarily all-inclusive.
Feature comparisons are made between stable versions of software, not the upcoming versions or beta releases – and are exclusive of any add-ons, extensions or external programs (unless specified in footnotes).
Remove ads
Overview
Remove ads
Operating system support
Summarize
Perspective
This section lists the operating systems that different editors can run on. Some editors run on additional operating systems that are not listed.
Cross-platform
Remove ads
Natural language (localization)
Remove ads
Document interface
Notes
- Multiple instances: multiple instances of the program can be opened simultaneously for editing multiple files. Applies both for single document interface (SDI) and multiple document interface (MDI) programs. Also applies for program that has a user interface that looks like multiple instances of the same program (such as some versions of Microsoft Word).
- Single document window splitting: window can be split to simultaneously view different areas of a file.
- MDI: Overlappable windows: each opened document gets its own fully movable window inside the editor environment.
- MDI: Tabbed document interface: multiple documents can be viewed as tabs in a single window.
- MDI: Window splitting: splitting application window to show multiple documents (non-overlapping windows).
Remove ads
Basic features
Remove ads
Programming features
Notes
- Syntax highlighting: Displays text in different colors and fonts according to the category of terms.
- Function list: Lists all functions from current file in a window or sidebar and allows user to jump directly to the definition of that function for example by double-clicking on the function name in the list. More or less realtime (does not require creating a symbol database, see below).
- Symbol database: Database of functions, variable and type definitions, macro definitions etc. in all the files belonging to the software being developed. The database can be created by the editor itself or by an external program such as ctags. The database can be used to instantly locate the definition even if it is in another file.
- Bracket matching: Find matching parenthesis or bracket, taking into account nesting.
- Auto indentation: May refer to just simple indenting to the same level as the line above, or intelligent indenting that is language specific, e.g., ensuring a given indent style.
- Compiler integration: Allows running compilers/linkers/debuggers from within editor, capturing the compiler output and stepping through errors, automatically moving cursor to corresponding location in the source file.
Remove ads
Extra features
Summarize
Perspective
Large file support:
![]() |
= Larger than 4 GiB (LFS) | ![]() |
= Larger than 1 GB, not limited by memory |
memory | = Limited by available memory | ![]() |
= Some limit less than available memory (give max size if known) |
In general, most text editors do not support large text files. Some restrict themselves to available in-core RAM while others use sophisticated virtual memory management techniques and paging algorithms.[96]
Search in files: Perform search (and possibly replace) in multiple files on disk, for example on a sub-directory and recursively all the directories below it. Similar to grep.
Remove ads
Key bindings
Summarize
Perspective
Support for custom key bindings.
Notes, bugs
- Vim: custom maps of Ctrl-1 .. Ctrl-9, Ctrl-0 cannot be set, nor is Control-Shift-<char> distinguished from Ctrl-<char>.[116][117]
- Notepad++: custom shortcuts of Shift-<char> cannot be set, they need an added modifier such as Ctrl or Alt. i.e. SCI_LINESCROLLUP cannot be bound to "Shift-I"as the "Add"button is greyed out.
- Emacs and Pico: pico uses most of Emacs's motion and deletion commands: ^F ^B ^P ^N ^D etc.
Remove ads
Protocol support
Summarize
Perspective
Support for editing files over a network or the Internet.
Remove ads
Unicode and other character encodings
Summarize
Perspective
To support specified character encoding, the editor must be able to load, save, view and edit text in the specific encoding and not destroy any characters. For UTF-8 and UTF-16, this requires internal 16-bit character support.
Partial support is indicated if: 1) the editor can only convert the character encoding to internal (8-bit) format for editing. 2) If some encodings are supported only in some platforms. 3) If the editor can only display specific character set (such as OEM) by loading corresponding font, but does not support keyboard entry for that character set.
Remove ads
Right-to-left and bidirectional text
Summarize
Perspective
Support for Right-To-Left (RTL) texts is necessary for editing some languages like Arabic, Persian, Hebrew, and Yiddish and the mixture of left to right (LTR) and RTL known as bi-directional (BiDi) support.
Depending on the algorithm used in the programs it might only render the bidirectional text correctly but may not be able to edit them. (e.g. Notepad++ 5.1.3 shows bidirectional texts correctly but cannot edit it and user should change the text direction to RTL to be able to edit RTL texts correctly.)
Remove ads
Newline support
See also
Notes
- Requires Cygwin or the Windows Subsystem for Linux to run on Windows.
- GEdit, when installed from MacPorts, runs in X11 and, therefore, does not have a native look and feel. However, precompiled native macOS binaries for GEdit may be downloaded from the GEdit project page, or from the GEdit FTP download server.
- gedit supports single document window splitting via plug‑ins. Archived 2011-12-14 at the Wayback Machine.
- gedit supports multiple document window splitting via plug‑ins. Archived 2011-12-14 at the Wayback Machine.
- GNU Emacs can support a tabbed document interface modelled after GNU Screen using the elscreen Archived 2008-01-17 at the Wayback Machine package.
- JOE supports editing multiple files but only seeing one of them, and switching to others via Ctrl+K+N, which is functionally equivalent to having tabs but no visible tab bar.
- mined supports Copy/Paste between multiple documents in separate windows, when these documents are in separate terminal windows
- SciTE_max_buffers
- Vim Provided GVim is used.
- Acme can invoke external commands and display their return values in order to integrate additional functionality.
- ConTEXT does not support regular expression backreferences in its search and replace function. Archived 2007-12-18 at archive.today
- Geany supports spell checking via a plug‑in
- gedit supports spell checking via a plug‑in, which is distributed with gedit.
- gedit supports Regex-based find & replace via plug‑ins ( Archived 2011-12-14 at the Wayback Machine).
- jEdit supports spell checking via an external plug‑in.
- JOE uses a non-standard regular expression syntax.
- JOE can easily pipe text through the GNU recode(1) utility; it detects locale settings and allows editing in any encoding set up by the environment.
- LE can pipe text through the GNU recode(1) utility
- Metapad spell checking by calling external program Aspell.
- mined supports multiple lines in search and replacement expressions.
- mined can convert the encoding format when using the Copy & Paste feature between multiple documents (that have different encodings).
- mined supports new-line conversion via a command-line option or from the menu. Files with mixed newline types can be edited transparently; different kinds of new-line have different visual indications.
- It is possible to start external applications from inside Sam and display their return values.
- Scintilla-based editors such as SciTE, Notepad2 and Notepad++ do not support alternation (
- UltraEdit uses the Boost C++ regex library. While Boost supports backreferences past \9 with \g{10}, UltraEdit has not yet implemented this feature.
- Visual Studio Code does not support virtual space, and rectangular selection beyond line endings is not possible.
- Acme's auto-completion only works on file names.
- bluefish: Configurable via the outputbox feature.
- ed can invoke external commands, like a compiler.
- gedit-folding: Folding plug‑in for Gedit
- gedit: Compiler integration: Functionality in plug‑ins installed with gedit.
- make can be launched from the LE text editor, but the output is not captured
- Evaluates expressions in some dynamic languages such as Clojure, Python and Javascript in realtime
- mined: Syntax highlighting: HTML/XML, Javascript, JSP.
- Notepad++ comes with Function List support, and it can be enhanced via plugins.
- Notepad++ installs with auto complete list for multiple programming languages. Has user option to add additional personalized auto complete list(s).
- Function list (and stuff) available in Ru-Board build, ver 1.79.66Ru and later
- TextMate: Auto complete: Supported language bundles
- TextWrangler can integrate with a compiler if you write a shell script that takes flag input of the code and compiles it. You place this in ~/Library/Application Support/TextWrangler/Unix Support/Unix Filters/. It should show in the #! menu.
- The Semware Editor: Auto complete: Supported via supplied/user-created lists.
- The Semware Editor: Text folding: Compressed view possible.
- Not in the Linux version.
- Vedit: Auto complete: Template editing, plus 3rd party macro for expanding symbols from tags database.
- Multi-line regex support Support for expressions spanning several lines (e.g. "\n\n(.+)\n\n")
- Alpha Macro support via AppleScript, Tcl or text factories.
- Coda offers macros via AppleScript, text "clips,"or plug‑ins (Cocoa apps or any installed scripting language).
- name
- LE text editor locks the file and warns if someone else has changed the file
- 2GB with 32 Bits, on a 64 Bit system it depends on the available virtual memory.
- The JED base release comes with a basic CUA emulation, but it doesn't bother to bind lots of useful editor features. Also, like some other editors, 1 side of a region must be at the cursor. The main extension collections jedmodes/jed-extra and the "Red Project" have improved versions, tackling the former problem in particular.
- In SciTE, custom keystrokes may be assigned to Lua scripts, external programs or lexers (highlighters).
- SlickEdit provides emulation of Visual Studio, Visual C++ 6, CodeWright, Epsilon and ISPF key bindings in addition to those given in the table.
- SlickEdit supports CodeWarrior, Xcode and BBEdit key binding emulation.
- SlickEdit includes support of vi key bindings, the ex command line and some, but not all Vim extensions.
- Vim emulates vi keys fully when in 'compatible' mode
- when choosing e.g. Terminal font
- GNU Emacs: While GNU Emacs supports the UTF-8 encoding, it doesn't fully support the Unicode standard, since it doesn't fully support the Unicode Bidirectional Algorithm (see comment in the 'Right-to-left and bidirectional text' section below).
- GNU Emacs: While GNU Emacs supports the UTF-16 encoding, it doesn't fully support the Unicode standard, since it doesn't fully support the Unicode Bidirectional Algorithm (see comment in the 'Right-to-left and bidirectional text' section below).
- JEDs Windows version comes with a pair of scripts that can convert UTF-16 text files (actually anything iconv can convert) to and from JED's internal UTF-8. The Red Project releases include an enhanced version of these scripts.
- nvi Gentoo
- SciTE can open files in UTF or one single-byte encoding specified in a configuration file.
- when choosing e.g. New Courier font
- Vedit can convert UTF-8 and UTF-16 files to Windows character set and back. Characters not included in Windows charset can be preserved.
- Vim supports EBCDIC when compiled on a system that uses the EBCDIC character set.
- from version 21.5.29
- GNU Emacs
(1) According to a comment in the source file where the bidi support is implemented (http://git.savannah.gnu.org/cgit/emacs.git/tree/src/bidi.c accessed August 15, 2017), GNU Emacs doesn't fully conform to the Unicode Bidirectional Algorithm (Unicode Annex #9, a.k.a. UAX #9) in the way it wraps the lines of a bidi paragraph: "we are violating paragraph 3.4 of UAX#9. which mandates that line breaking shall be done before reordering each screen line separately."
(2) According to the online GNU Emacs manual (section 22.19 Bidirectional Editing, accessed August 15, 2017), for the purpose of changing paragraph direction, "Paragraph boundaries are empty lines, i.e., lines consisting entirely of whitespace character". This contrasts with the otherwise ubiquitous convention of regarding the newline marker (LF on Unix derivatives, including macOS, and CR+LF on Windows) as the paragraph separator in plain text documents. However starting with version 26.0.50, the bidi paragraph separator can be customized. - mined: supports bidi in cooperation with bidi terminal (mlterm, mintty); also supports "poor man's bidi mode"(automatic visual text order right-to-left input) in normal terminal
- Notepadpp: Scintilla (Notepad++'s Engine) does not really support bidirectional editing ... Some bidirectional text support added in 4.1.0. https://sourceforge.net/p/scintilla/bugs/757/#01c9
- GNU Emacs: GNU Emacs doesn't regard the newline marker as a paragraph separator in bidi texts. See comment in the 'Right-to-left and bidirectional text' section.
References
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads