玛氪宕·梦魔(Markdown Memo),使用Markdown的云端备忘录,百度IFE的RIA启航班的不合格的作业,才……才没有什么阴谋呢!
源gitee链接https://gitee.com/arathi/MarkdownMemo?_from=gitee_search
				
			
			
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							429 lines
						
					
					
						
							13 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							429 lines
						
					
					
						
							13 KiB
						
					
					
				| <!doctype html> | |
| 
 | |
| <title>CodeMirror: Eiffel mode</title> | |
| <meta charset="utf-8"/> | |
| <link rel=stylesheet href="../../doc/docs.css"> | |
| 
 | |
| <link rel="stylesheet" href="../../lib/codemirror.css"> | |
| <link rel="stylesheet" href="../../theme/neat.css"> | |
| <script src="../../lib/codemirror.js"></script> | |
| <script src="eiffel.js"></script> | |
| <style> | |
|       .CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;} | |
|       .cm-s-default span.cm-arrow { color: red; } | |
|     </style> | |
| <div id=nav> | |
|   <a href="http://codemirror.net"><h1>CodeMirror</h1><img id=logo src="../../doc/logo.png"></a> | |
| 
 | |
|   <ul> | |
|     <li><a href="../../index.html">Home</a> | |
|     <li><a href="../../doc/manual.html">Manual</a> | |
|     <li><a href="https://github.com/codemirror/codemirror">Code</a> | |
|   </ul> | |
|   <ul> | |
|     <li><a href="../index.html">Language modes</a> | |
|     <li><a class=active href="#">Eiffel</a> | |
|   </ul> | |
| </div> | |
| 
 | |
| <article> | |
| <h2>Eiffel mode</h2> | |
| <form><textarea id="code" name="code"> | |
| note | |
|     description: "[ | |
|         Project-wide universal properties. | |
|         This class is an ancestor to all developer-written classes. | |
|         ANY may be customized for individual projects or teams. | |
|         ]" | |
| 
 | |
|     library: "Free implementation of ELKS library" | |
|     status: "See notice at end of class." | |
|     legal: "See notice at end of class." | |
|     date: "$Date: 2013-01-25 11:49:00 -0800 (Fri, 25 Jan 2013) $" | |
|     revision: "$Revision: 712 $" | |
| 
 | |
| class | |
|     ANY | |
| 
 | |
| feature -- Customization | |
| 
 | |
| feature -- Access | |
| 
 | |
|     generator: STRING | |
|             -- Name of current object's generating class | |
|             -- (base class of the type of which it is a direct instance) | |
|         external | |
|             "built_in" | |
|         ensure | |
|             generator_not_void: Result /= Void | |
|             generator_not_empty: not Result.is_empty | |
|         end | |
| 
 | |
|     generating_type: TYPE [detachable like Current] | |
|             -- Type of current object | |
|             -- (type of which it is a direct instance) | |
|         do | |
|             Result := {detachable like Current} | |
|         ensure | |
|             generating_type_not_void: Result /= Void | |
|         end | |
| 
 | |
| feature -- Status report | |
| 
 | |
|     conforms_to (other: ANY): BOOLEAN | |
|             -- Does type of current object conform to type | |
|             -- of `other' (as per Eiffel: The Language, chapter 13)? | |
|         require | |
|             other_not_void: other /= Void | |
|         external | |
|             "built_in" | |
|         end | |
| 
 | |
|     same_type (other: ANY): BOOLEAN | |
|             -- Is type of current object identical to type of `other'? | |
|         require | |
|             other_not_void: other /= Void | |
|         external | |
|             "built_in" | |
|         ensure | |
|             definition: Result = (conforms_to (other) and | |
|                                         other.conforms_to (Current)) | |
|         end | |
| 
 | |
| feature -- Comparison | |
| 
 | |
|     is_equal (other: like Current): BOOLEAN | |
|             -- Is `other' attached to an object considered | |
|             -- equal to current object? | |
|         require | |
|             other_not_void: other /= Void | |
|         external | |
|             "built_in" | |
|         ensure | |
|             symmetric: Result implies other ~ Current | |
|             consistent: standard_is_equal (other) implies Result | |
|         end | |
| 
 | |
|     frozen standard_is_equal (other: like Current): BOOLEAN | |
|             -- Is `other' attached to an object of the same type | |
|             -- as current object, and field-by-field identical to it? | |
|         require | |
|             other_not_void: other /= Void | |
|         external | |
|             "built_in" | |
|         ensure | |
|             same_type: Result implies same_type (other) | |
|             symmetric: Result implies other.standard_is_equal (Current) | |
|         end | |
| 
 | |
|     frozen equal (a: detachable ANY; b: like a): BOOLEAN | |
|             -- Are `a' and `b' either both void or attached | |
|             -- to objects considered equal? | |
|         do | |
|             if a = Void then | |
|                 Result := b = Void | |
|             else | |
|                 Result := b /= Void and then | |
|                             a.is_equal (b) | |
|             end | |
|         ensure | |
|             definition: Result = (a = Void and b = Void) or else | |
|                         ((a /= Void and b /= Void) and then | |
|                         a.is_equal (b)) | |
|         end | |
| 
 | |
|     frozen standard_equal (a: detachable ANY; b: like a): BOOLEAN | |
|             -- Are `a' and `b' either both void or attached to | |
|             -- field-by-field identical objects of the same type? | |
|             -- Always uses default object comparison criterion. | |
|         do | |
|             if a = Void then | |
|                 Result := b = Void | |
|             else | |
|                 Result := b /= Void and then | |
|                             a.standard_is_equal (b) | |
|             end | |
|         ensure | |
|             definition: Result = (a = Void and b = Void) or else | |
|                         ((a /= Void and b /= Void) and then | |
|                         a.standard_is_equal (b)) | |
|         end | |
| 
 | |
|     frozen is_deep_equal (other: like Current): BOOLEAN | |
|             -- Are `Current' and `other' attached to isomorphic object structures? | |
|         require | |
|             other_not_void: other /= Void | |
|         external | |
|             "built_in" | |
|         ensure | |
|             shallow_implies_deep: standard_is_equal (other) implies Result | |
|             same_type: Result implies same_type (other) | |
|             symmetric: Result implies other.is_deep_equal (Current) | |
|         end | |
| 
 | |
|     frozen deep_equal (a: detachable ANY; b: like a): BOOLEAN | |
|             -- Are `a' and `b' either both void | |
|             -- or attached to isomorphic object structures? | |
|         do | |
|             if a = Void then | |
|                 Result := b = Void | |
|             else | |
|                 Result := b /= Void and then a.is_deep_equal (b) | |
|             end | |
|         ensure | |
|             shallow_implies_deep: standard_equal (a, b) implies Result | |
|             both_or_none_void: (a = Void) implies (Result = (b = Void)) | |
|             same_type: (Result and (a /= Void)) implies (b /= Void and then a.same_type (b)) | |
|             symmetric: Result implies deep_equal (b, a) | |
|         end | |
| 
 | |
| feature -- Duplication | |
| 
 | |
|     frozen twin: like Current | |
|             -- New object equal to `Current' | |
|             -- `twin' calls `copy'; to change copying/twinning semantics, redefine `copy'. | |
|         external | |
|             "built_in" | |
|         ensure | |
|             twin_not_void: Result /= Void | |
|             is_equal: Result ~ Current | |
|         end | |
| 
 | |
|     copy (other: like Current) | |
|             -- Update current object using fields of object attached | |
|             -- to `other', so as to yield equal objects. | |
|         require | |
|             other_not_void: other /= Void | |
|             type_identity: same_type (other) | |
|         external | |
|             "built_in" | |
|         ensure | |
|             is_equal: Current ~ other | |
|         end | |
| 
 | |
|     frozen standard_copy (other: like Current) | |
|             -- Copy every field of `other' onto corresponding field | |
|             -- of current object. | |
|         require | |
|             other_not_void: other /= Void | |
|             type_identity: same_type (other) | |
|         external | |
|             "built_in" | |
|         ensure | |
|             is_standard_equal: standard_is_equal (other) | |
|         end | |
| 
 | |
|     frozen clone (other: detachable ANY): like other | |
|             -- Void if `other' is void; otherwise new object | |
|             -- equal to `other' | |
|             -- | |
|             -- For non-void `other', `clone' calls `copy'; | |
|             -- to change copying/cloning semantics, redefine `copy'. | |
|         obsolete | |
|             "Use `twin' instead." | |
|         do | |
|             if other /= Void then | |
|                 Result := other.twin | |
|             end | |
|         ensure | |
|             equal: Result ~ other | |
|         end | |
| 
 | |
|     frozen standard_clone (other: detachable ANY): like other | |
|             -- Void if `other' is void; otherwise new object | |
|             -- field-by-field identical to `other'. | |
|             -- Always uses default copying semantics. | |
|         obsolete | |
|             "Use `standard_twin' instead." | |
|         do | |
|             if other /= Void then | |
|                 Result := other.standard_twin | |
|             end | |
|         ensure | |
|             equal: standard_equal (Result, other) | |
|         end | |
| 
 | |
|     frozen standard_twin: like Current | |
|             -- New object field-by-field identical to `other'. | |
|             -- Always uses default copying semantics. | |
|         external | |
|             "built_in" | |
|         ensure | |
|             standard_twin_not_void: Result /= Void | |
|             equal: standard_equal (Result, Current) | |
|         end | |
| 
 | |
|     frozen deep_twin: like Current | |
|             -- New object structure recursively duplicated from Current. | |
|         external | |
|             "built_in" | |
|         ensure | |
|             deep_twin_not_void: Result /= Void | |
|             deep_equal: deep_equal (Current, Result) | |
|         end | |
| 
 | |
|     frozen deep_clone (other: detachable ANY): like other | |
|             -- Void if `other' is void: otherwise, new object structure | |
|             -- recursively duplicated from the one attached to `other' | |
|         obsolete | |
|             "Use `deep_twin' instead." | |
|         do | |
|             if other /= Void then | |
|                 Result := other.deep_twin | |
|             end | |
|         ensure | |
|             deep_equal: deep_equal (other, Result) | |
|         end | |
| 
 | |
|     frozen deep_copy (other: like Current) | |
|             -- Effect equivalent to that of: | |
|             --      `copy' (`other' . `deep_twin') | |
|         require | |
|             other_not_void: other /= Void | |
|         do | |
|             copy (other.deep_twin) | |
|         ensure | |
|             deep_equal: deep_equal (Current, other) | |
|         end | |
| 
 | |
| feature {NONE} -- Retrieval | |
| 
 | |
|     frozen internal_correct_mismatch | |
|             -- Called from runtime to perform a proper dynamic dispatch on `correct_mismatch' | |
|             -- from MISMATCH_CORRECTOR. | |
|         local | |
|             l_msg: STRING | |
|             l_exc: EXCEPTIONS | |
|         do | |
|             if attached {MISMATCH_CORRECTOR} Current as l_corrector then | |
|                 l_corrector.correct_mismatch | |
|             else | |
|                 create l_msg.make_from_string ("Mismatch: ") | |
|                 create l_exc | |
|                 l_msg.append (generating_type.name) | |
|                 l_exc.raise_retrieval_exception (l_msg) | |
|             end | |
|         end | |
| 
 | |
| feature -- Output | |
| 
 | |
|     io: STD_FILES | |
|             -- Handle to standard file setup | |
|         once | |
|             create Result | |
|             Result.set_output_default | |
|         ensure | |
|             io_not_void: Result /= Void | |
|         end | |
| 
 | |
|     out: STRING | |
|             -- New string containing terse printable representation | |
|             -- of current object | |
|         do | |
|             Result := tagged_out | |
|         ensure | |
|             out_not_void: Result /= Void | |
|         end | |
| 
 | |
|     frozen tagged_out: STRING | |
|             -- New string containing terse printable representation | |
|             -- of current object | |
|         external | |
|             "built_in" | |
|         ensure | |
|             tagged_out_not_void: Result /= Void | |
|         end | |
| 
 | |
|     print (o: detachable ANY) | |
|             -- Write terse external representation of `o' | |
|             -- on standard output. | |
|         do | |
|             if o /= Void then | |
|                 io.put_string (o.out) | |
|             end | |
|         end | |
| 
 | |
| feature -- Platform | |
| 
 | |
|     Operating_environment: OPERATING_ENVIRONMENT | |
|             -- Objects available from the operating system | |
|         once | |
|             create Result | |
|         ensure | |
|             operating_environment_not_void: Result /= Void | |
|         end | |
| 
 | |
| feature {NONE} -- Initialization | |
| 
 | |
|     default_create | |
|             -- Process instances of classes with no creation clause. | |
|             -- (Default: do nothing.) | |
|         do | |
|         end | |
| 
 | |
| feature -- Basic operations | |
| 
 | |
|     default_rescue | |
|             -- Process exception for routines with no Rescue clause. | |
|             -- (Default: do nothing.) | |
|         do | |
|         end | |
| 
 | |
|     frozen do_nothing | |
|             -- Execute a null action. | |
|         do | |
|         end | |
| 
 | |
|     frozen default: detachable like Current | |
|             -- Default value of object's type | |
|         do | |
|         end | |
| 
 | |
|     frozen default_pointer: POINTER | |
|             -- Default value of type `POINTER' | |
|             -- (Avoid the need to write `p'.`default' for | |
|             -- some `p' of type `POINTER'.) | |
|         do | |
|         ensure | |
|             -- Result = Result.default | |
|         end | |
| 
 | |
|     frozen as_attached: attached like Current | |
|             -- Attached version of Current | |
|             -- (Can be used during transitional period to convert | |
|             -- non-void-safe classes to void-safe ones.) | |
|         do | |
|             Result := Current | |
|         end | |
| 
 | |
| invariant | |
|     reflexive_equality: standard_is_equal (Current) | |
|     reflexive_conformance: conforms_to (Current) | |
| 
 | |
| note | |
|     copyright: "Copyright (c) 1984-2012, Eiffel Software and others" | |
|     license:   "Eiffel Forum License v2 (see http://www.eiffel.com/licensing/forum.txt)" | |
|     source: "[ | |
|             Eiffel Software | |
|             5949 Hollister Ave., Goleta, CA 93117 USA | |
|             Telephone 805-685-1006, Fax 805-685-6869 | |
|             Website http://www.eiffel.com | |
|             Customer support http://support.eiffel.com | |
|         ]" | |
| 
 | |
| end | |
| 
 | |
| </textarea></form> | |
|     <script> | |
|       var editor = CodeMirror.fromTextArea(document.getElementById("code"), { | |
|         mode: "text/x-eiffel", | |
|         indentUnit: 4, | |
|         lineNumbers: true, | |
|         theme: "neat" | |
|       }); | |
|     </script> | |
| 
 | |
|     <p><strong>MIME types defined:</strong> <code>text/x-eiffel</code>.</p> | |
|   | |
|  <p> Created by <a href="https://github.com/ynh">YNH</a>.</p> | |
|   </article>
 |