430 lines
13 KiB
HTML
430 lines
13 KiB
HTML
|
<!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>
|