Top Qs
Timeline
Chat
Perspective
Comparison of text editors
From Wikipedia, the free encyclopedia
Remove ads
This article compares notable text editors. It may not be up-to-date or all-inclusive. Comparisons are between stable versions (not upcoming or beta releases) and are exclusive of any add-ons, extensions or external programs unless otherwise noted.
Other features can be listed via the Category of text editor features.
General attributes
Remove ads
Operating system support
Remove ads
Natural language (localization)
Remove ads
Document interface
Summarize
Perspective
The following table identifies the following attributes of an editor that describe its user experience with respect to multiple documents:
- Multiple instances
- Whether multiple instances of the program can be open at the same time for editing multiple files (one in each instance). Applies both for single-document interface (SDI) and multiple-document interface (MDI). Also, applies for a program that has a user interface that looks like multiple instances of the same program (such as some versions of Word).
- Single document window splitting
- Whether a window can be split to simultaneously view different areas of a file.
- MDI overlappable windows
- Whether each open document gets its own fully movable window inside the editor environment.
- MDI tabbed document interface
- Whether multiple documents can be viewed as tabs in a single window.
- MDI window splitting
- Whether supports splitting the application window to show multiple documents (non-overlapping windows).
Remove ads
Basic features
Remove ads
Programming features
Remove ads
Additional programming features
Remove ads
Key bindings
Summarize
Perspective
Notes:
- Vim
- Custom maps of Ctrl-1 .. Ctrl-9, Ctrl-0 cannot be set, nor is Control-Shift-<char> distinguished from Ctrl-<char>.[114][115]
- 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.
- Pico
- Pico uses most of Emacs's motion and deletion commands: ^F ^B ^P ^N ^D etc.
Remove ads
Protocol support
Remove ads
Character encoding support
Summarize
Perspective
The following table identifies notable character encodings that an editor supports – can load, save, view and edit text in the encoding without changing any characters. Partial implies that the editor can only convert the character encoding to internal (8-bit) format for editing, some encodings are supported only in some platforms or the editor can only display a 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) text is necessary for editing some languages like Arabic, Persian, Hebrew, and Yiddish and the mixture of left-to-right (LTR) and RTL known as bidirectional (BiDi). The following table indicates whether an editor supports RTL and BiDi text. Some editors (e.g. Notepad++ 5.1.3) can render bidirectional text but does not support editing it.
Remove ads
Newline support
Summarize
Perspective
The following table identifies newline support of editors. The three options are:
- CR/LF
- Generally, used on Windows.
- LF
- Generally, used on Unix-like systems (including macOS).[125]
- CR
- Generally, used on Classic Mac OS.
See also
- Editor war
- Comparison of word processors
- Comparison of integrated development environments
- Comparison of HTML editors
- Comparison of TeX editors
- Comparison of hex editors
- Comparison of notetaking software
- Comparison of wiki software
- List of text editors
- List of wiki software
- List of personal information managers
- Outliner
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.
- 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