| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 | <html xmlns="http://www.w3.org/1999/xhtml">  <head>    <title>CodeMirror: In-browser code editing</title>    <link rel="stylesheet" type="text/css" href="css/docs.css"/>    <style type="text/css">      div.top {text-align: center;}      div.top h1 {margin-bottom: 0;}      div.top h2 {margin-top: 0; margin-bottom: 1.5em;}      div.donate span {cursor: pointer; text-decoration: underline;}      div.donate {font-size: 70%; margin-top: 1em; width: 155px; padding: 10px; border: 1px solid #c44;}    </style>    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>  </head>  <body><div class="top">  <h1>CodeMirror</h1>  <h2 class="underline">In-browser code editing made almost bearable</h2></div><div style="float: right; padding-left: 10px;">  <form action="https://www.paypal.com/cgi-bin/webscr" method="post" id="paypal">    <input type="hidden" name="cmd" value="_s-xclick"/>    <input type="hidden" name="hosted_button_id" value="3FVHS5FGUY7CC"/>  </form>  <img src="css/people.jpg" alt=""/><br/>  <div class="donate">    Make a donation:    <ul style="margin: 0 2em; padding: 0">      <li><span onclick="document.getElementById('paypal').submit();">Paypal</span></li>      <li><span onclick="document.getElementById('bankinfo').style.display = 'block';">Bank</span></li>    </ul>    <div id="bankinfo" style="display: none; font-size: 80%;">      Bank: <i>Rabobank</i><br/>      Country: <i>Netherlands</i><br/>      SWIFT: <i>RABONL2U</i><br/>      Account: <i>147850770</i><br/>      Name: <i>Marijn Haverbeke</i><br/>      IBAN: <i>NL26 RABO 0147 8507 70</i>    </div>  </div></div><p>CodeMirror is a JavaScript library that can be used to create arelatively pleasant editor interface for code-like content ―computer programs, HTML markup, and similar. If a parser has beenwritten for the language you are editing (see below for a list ofsupported languages), the code will be coloured, and the editor willhelp you with indentation.</p><p>To get a look at CodeMirror, see the test pages for the variousparsers...</p><ul>  <li><a href="jstest.html">JavaScript</a></li>  <li><a href="htmltest.html">XML/HTML</a></li>  <li><a href="csstest.html">CSS</a></li>  <li><a href="sparqltest.html">SPARQL</a></li>  <li><a href="mixedtest.html">HTML mixed-mode</a></li>  <li><a href="contrib/php/index.html">HTML+PHP mixed-mode</a> (courtesy of <a href="contrib/php/LICENSE">Yahoo!</a>)</li>  <li><a href="contrib/python/index.html">Python</a> (courtesy of <a href="contrib/python/LICENSE">Timothy Farrell</a>)</li>  <li><a href="contrib/lua/index.html">Lua</a> (courtesy of <a href="http://francio.pl/">Franciszek Wawrzak</a>)</li>  <li><a href="http://github.com/hakunin/ruby-in-codemirror/tree/master">Ruby</a> (by Michal Hantl, unfinished)</li>  <li><a href="contrib/sql/index.html">SQL</a> (courtesy of John Benediktsson)</li>  <li><a href="contrib/plsql/index.html">PLSQL</a> (courtesy of <a href="http://www.oracle-and-apex.com/">Peter Raganitsch</a>)</li>  <li><a href="http://www.liranuna.com/diff-parser-for-codemirror/">diff</a> (courtesy of <a href="http://www.liranuna.com">Liran Nuna</a>)</li>  <li><a href="contrib/groovy/index.html">Groovy</a> (by <a href="http://exoplatform.org/">eXo Platform</a>)</li>  <li><a href="contrib/csharp/index.html">C#</a> (by <a href="http://skilltesting.com/">Boris Gaber and Christopher Buchino</a>)</li></ul><p>Or take a look at some real-world uses of the system...</p><ul>  <li><a href="http://kml-samples.googlecode.com/svn/trunk/interactive/index.html">Google Earth KML sampler</a></li>  <li><a href="http://eloquentjavascript.net/chapter1.html">Eloquent JavaScript's console</a></li>  <li><a href="http://demo.qooxdoo.org/current/playground/#Hello_World">The qooxdoo playground</a></li>  <li><a href="http://billmill.org/static/canvastutorial/index.html">A cool tutorial about the <canvas> element</a></li>  <li><a href="http://orc.csres.utexas.edu/tryorc.shtml">An online IDE for the Orc programming language</a></li>  <li><a href="http://code.google.com/apis/ajax/playground">Google's API playground</a></li>  <li><a href="http://craic.com/tutorials/javascript/raphael_live/raphael_live.html">Raphaël Live</a></li>  <li><a href="http://dev.freebaseapps.com/">Freebase's Acre IDE</a></li>  <li><a href="http://jsbin.com/">JS Bin</a></li>  <li><a href="http://www.rockettheme.com/extensions-joomla/rokpad">The RokPad plugin for Joomla</a></li>  <li><a href="http://scraperwiki.com/editor/">The scraperwiki editor</a></li></ul><h2>Releases</h2><p class="rel"><em>22-07-2010</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.8.zip">Version0.8</a>:</p><ul class="rel">  <li>Add a <code>cursorCoords</code> method to find the screen  coordinates of the cursor.</li>  <li>A number of fixes and support for more syntax in the PHP parser.</li>  <li>Fix indentation problem with JSON-mode JS parser in Webkit.</li>  <li>Add a <a href="compress.html">minification</a> UI.</li>  <li>Support a <code>height: dynamic</code> mode, where the editor's  height will adjust to the size of its content.</li>  <li>Better support for IME input mode.</li>  <li>Fix JavaScript parser getting confused when seeing a no-argument  function call.</li>  <li>Have CSS parser see the difference between selectors and other  identifiers.</li>  <li>Fix scrolling bug when pasting in a horizontally-scrolled  editor.</li>  <li>Support <code>toTextArea</code> method in instances created with  <code>fromTextArea</code>.</li>  <li>Work around new Opera cursor bug that causes the cursor to jump  when pressing backspace at the end of a line.</li></ul><p class="rel"><em>21-06-2010</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.7.zip">Version0.7</a>:</p><ul class="rel">  <li>Fixes issue where calling <code>.submit()</code> on a form with  a <code>fromTextArea</code> CodeMirror failed to submit the  edited content.</li>  <li>Add <a href="contrib/groovy/index.html">Groovy</a> parser (hosted externally).</li>  <li>Make line-numbering much, much faster.</li>  <li>Fix occasional buggy behaviour of the enter key in Opera.</li>  <li>Add a <a href="faq.html">FAQ</a> document.</li>  <li>Make search use do-what-I-mean Emacs-like behaviour to determine  case-sensitivitiy is not explicitly specified.</li>  <li>Add a C# parser contrib module.</li>  <li>A number of bugfixes and extensions to the PHP parser (lambdas,  abstract classes, configurable opening tags).</li>  <li>Fix multiline comments in the Lua parser.</li></ul><p class="rel"><em>27-04-2010</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.67.zip">Version0.67</a>: More consistent page-up/page-down behaviour across browsers.Fix some issues with hidden editors looping forever when line-numberswere enabled. Make PHP parser parse <code>"\\"</code> correctly. Have<code>jumpToLine</code> work on line handles, and add<code>cursorLine</code> function to fetch the line handle where thecursor currently is. Add new <code>setStylesheet</code> function toswitch style-sheets in a running editor.</p><p class="rel"><em>01-03-2010</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.66.zip">Version0.66</a>: Adds <code>removeLine</code> method to API. Introduces the<a href="contrib/plsql/index.html">PLSQL parser</a>. Marks XML errorsby adding (rather than replacing) a CSS class, so that they can bedisabled by modifying their style. Fixes several selection bugs, and anumber of small glitches.</p><p class="rel"><em>12-11-2009</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.65.zip">Version0.65</a>: Add support for having both line-wrapping and line-numbersturned on, make paren-highlighting style customisable(<code>markParen</code> and <code>unmarkParen</code> config options),work around a selection bug that Opera <em>re</em>introduced inversion 10.</p><p class="rel"><em>23-10-2009</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.64.zip">Version0.64</a>: Solves some issues introduced by the paste-handling changesfrom the previous release. Adds <code>setSpellcheck</code>,<code>setTextWrapping</code>, <code>setIndentUnit</code>,<code>setUndoDepth</code>, <code>setTabMode</code>, and<code>setLineNumbers</code> to customise a running editor. Introducesan <a href="contrib/sql/index.html">SQL</a> parser. Fixes a few smallproblems in the <a href="contrib/python/index.html">Python</a> parser.And, as usual, add workarounds for various newly discovered browserincompatibilities.</p><p class="rel"><em>31-08-2009</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.63.zip">Version0.63</a>: Overhaul of paste-handling (less fragile), fixes for severalserious IE8 issues (cursor jumping, end-of-document bugs) and a numberof small problems.</p><p class="rel"><em>30-05-2009</em>: <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-0.62.zip">Version0.62</a>: Introduces <a href="contrib/python/index.html">Python</a>and <a href="contrib/lua/index.html">Lua</a> parsers. Add<code>setParser</code> (on-the-fly mode changing) and<code>clearHistory</code> methods. Make parsing passes time-basedinstead of lines-based (see the <code>passTime</code> option).</p><h2 id="supported">Supported browsers</h2><p>At this time, the following browsers are supported:</p><ul>  <li>Firefox 1.5 or higher</li>  <li>Internet Explorer 6 or higher</li>  <li>Safari 3 or higher</li>  <li>Opera 9.52 or higher</li>  <li>Chrome</li></ul><p>Making it work on other browsers that have decent support for theW3C DOM model should not be too hard, but I am not actively testingagainst those.</p><h2>Getting the code</h2><p>All of CodeMirror is released under a <ahref="LICENSE">zlib-style</a> license. To get it, you can download the<a href="http://marijn.haverbeke.nl/codemirror/codemirror.zip">latestrelease</a> or the current <ahref="http://marijn.haverbeke.nl/codemirror/codemirror-latest.zip">developmentsnapshot</a> as zip files, try the <a href="compress.html">compressionAPI</a> to create a compressed version, or use <ahref="http://git-scm.com/">git</a> to get the repository:</p><pre class="code">git clone http://marijn.haverbeke.nl/codemirror/.git</pre><p>This second method is recommended if you are planning to hack onCodeMirror ― it makes it easy to record your patches and sharethem with me. CodeMirror can also be found on GitHub: <ahref="http://github.com/marijnh/CodeMirror">http://github.com/marijnh/CodeMirror</a>.</p><h2>Support</h2><p>There is a <ahref="http://groups.google.com/group/codemirror">Google group</a> (asort of mailing list/newsgroup thingy) for discussion and news relatedto CodeMirror. Please check the <a href="faq.html">FAQ</a> beforeasking a questoin. You can also e-mail me directly: <ahref="mailto:marijnh@gmail.com">Marijn Haverbeke</a>.</p><h2>Documentation</h2><ul>  <li>The <a href="manual.html">manual</a> is all most users will need  to read (or skim).</li>  <li>If you're interested in working on the code, <a  href="story.html">this document</a> about CodeMirror's architecture  will be useful.</li>  <li>The <a href="http://github.com/marijnh/CodeMirror">source  code</a> is, for the most part, rather well commented, so if all  else fails, you can try reading it.</li></ul>  </body></html>
 |