A warning or an error

Introduced properties

private var _level: Int

nitc :: Message :: _level

The severity level
private var _location: nullable Location

nitc :: Message :: _location

The origin of the message in the source code, if any.
private var _tag: nullable String

nitc :: Message :: _tag

The category of the message.
private var _text: String

nitc :: Message :: _text

The human-readable description of the message.
init defaultinit(location: nullable Location, tag: nullable String, text: String, level: Int)

nitc :: Message :: defaultinit

fun level: Int

nitc :: Message :: level

The severity level
protected fun level=(level: Int)

nitc :: Message :: level=

The severity level
fun location: nullable Location

nitc :: Message :: location

The origin of the message in the source code, if any.
protected fun location=(location: nullable Location)

nitc :: Message :: location=

The origin of the message in the source code, if any.
fun tag: nullable String

nitc :: Message :: tag

The category of the message.
protected fun tag=(tag: nullable String)

nitc :: Message :: tag=

The category of the message.
fun text: String

nitc :: Message :: text

The human-readable description of the message.
protected fun text=(text: String)

nitc :: Message :: text=

The human-readable description of the message.
fun to_color_string: String

nitc :: Message :: to_color_string

A colored version of the message including the original source line

Redefined properties

redef fun <(other: OTHER): Bool

nitc $ Message :: <

Comparisons are made on message locations.
redef fun ==(other: nullable Object): Bool

nitc $ Message :: ==

Have self and other the same value?
redef type OTHER: Message

nitc $ Message :: OTHER

What self can be compared to?
redef type SELF: Message

nitc $ Message :: SELF

Type of this instance, automatically specialized in every class
redef fun to_s: String

nitc $ Message :: to_s

User readable representation of self.

All properties

fun !=(other: nullable Object): Bool

core :: Object :: !=

Have self and other different values?
abstract fun <(other: OTHER): Bool

core :: Comparable :: <

Is self lesser than other?
fun <=(other: OTHER): Bool

core :: Comparable :: <=

not other < self
fun <=>(other: OTHER): Int

core :: Comparable :: <=>

-1 if <, +1 if > and 0 otherwise
fun ==(other: nullable Object): Bool

core :: Object :: ==

Have self and other the same value?
fun >(other: OTHER): Bool

core :: Comparable :: >

other < self
fun >=(other: OTHER): Bool

core :: Comparable :: >=

not self < other
type CLASS: Class[SELF]

core :: Object :: CLASS

The type of the class of self.
type OTHER: Comparable

core :: Comparable :: OTHER

What self can be compared to?
type SELF: Object

core :: Object :: SELF

Type of this instance, automatically specialized in every class
private var _level: Int

nitc :: Message :: _level

The severity level
private var _location: nullable Location

nitc :: Message :: _location

The origin of the message in the source code, if any.
private var _tag: nullable String

nitc :: Message :: _tag

The category of the message.
private var _text: String

nitc :: Message :: _text

The human-readable description of the message.
fun clamp(min: OTHER, max: OTHER): OTHER

core :: Comparable :: clamp

Constraint self within [min..max]
protected fun class_factory(name: String): CLASS

core :: Object :: class_factory

Implementation used by get_class to create the specific class.
fun class_name: String

core :: Object :: class_name

The class name of the object.
init defaultinit(location: nullable Location, tag: nullable String, text: String, level: Int)

nitc :: Message :: defaultinit

fun get_class: CLASS

core :: Object :: get_class

The meta-object representing the dynamic type of self.
fun hash: Int

core :: Object :: hash

The hash code of the object.
init init

core :: Object :: init

fun inspect: String

core :: Object :: inspect

Developer readable representation of self.
protected fun inspect_head: String

core :: Object :: inspect_head

Return "CLASSNAME:#OBJECTID".
fun is_between(c: OTHER, d: OTHER): Bool

core :: Comparable :: is_between

c <= self <= d
intern fun is_same_instance(other: nullable Object): Bool

core :: Object :: is_same_instance

Return true if self and other are the same instance (i.e. same identity).
fun is_same_serialized(other: nullable Object): Bool

core :: Object :: is_same_serialized

Is self the same as other in a serialization context?
intern fun is_same_type(other: Object): Bool

core :: Object :: is_same_type

Return true if self and other have the same dynamic type.
fun level: Int

nitc :: Message :: level

The severity level
protected fun level=(level: Int)

nitc :: Message :: level=

The severity level
fun location: nullable Location

nitc :: Message :: location

The origin of the message in the source code, if any.
protected fun location=(location: nullable Location)

nitc :: Message :: location=

The origin of the message in the source code, if any.
fun max(other: OTHER): OTHER

core :: Comparable :: max

The maximum between self and other (prefers self if equals).
fun min(c: OTHER): OTHER

core :: Comparable :: min

The minimum between self and c (prefer self if equals)
private intern fun native_class_name: CString

core :: Object :: native_class_name

The class name of the object in CString format.
intern fun object_id: Int

core :: Object :: object_id

An internal hash code for the object based on its identity.
fun output

core :: Object :: output

Display self on stdout (debug only).
intern fun output_class_name

core :: Object :: output_class_name

Display class name on stdout (debug only).
fun serialization_hash: Int

core :: Object :: serialization_hash

Hash value use for serialization
intern fun sys: Sys

core :: Object :: sys

Return the global sys object, the only instance of the Sys class.
fun tag: nullable String

nitc :: Message :: tag

The category of the message.
protected fun tag=(tag: nullable String)

nitc :: Message :: tag=

The category of the message.
fun text: String

nitc :: Message :: text

The human-readable description of the message.
protected fun text=(text: String)

nitc :: Message :: text=

The human-readable description of the message.
fun to_color_string: String

nitc :: Message :: to_color_string

A colored version of the message including the original source line
abstract fun to_jvalue(env: JniEnv): JValue

core :: Object :: to_jvalue

fun to_s: String

core :: Object :: to_s

User readable representation of self.
package_diagram nitc::Message Message core::Comparable Comparable nitc::Message->core::Comparable core::Object Object core::Comparable->core::Object ...core::Object ... ...core::Object->core::Object

Ancestors

interface Object

core :: Object

The root of the class hierarchy.

Parents

interface Comparable

core :: Comparable

The ancestor of class where objects are in a total order.

Class definitions

nitc $ Message
# A warning or an error
class Message
	super Comparable
	redef type OTHER: Message

	# The origin of the message in the source code, if any.
	var location: nullable Location

	# The category of the message.
	#
	# Used by quality-control tool for statistics or to enable/disable things individually.
	var tag: nullable String

	# The human-readable description of the message.
	#
	# eg. "Error: cannot find method `foo`."
	#
	# A good message should:
	#
	# * start with a message type like "Error:", "Syntax Error:", "Warning:".
	#   The type is capitalized and terminated by a column.
	#   The rest on the message starts with a lowercase letter and is terminated with a dot.
	#
	# * be short and fit on a single line.
	#
	# * have meaningful information first.
	#   This helps the reader and remain usable
	#   when truncated, by an IDE for instance.
	#
	# * enclose identifiers, keywords and pieces of code with back-quotes.
	var text: String

	# The severity level
	#
	# * 0 is advices (see `ToolContext::advice`)
	# * 1 is warnings (see `ToolContext::warning`)
	# * 2 is errors (see `ToolContext::error`)
	var level: Int

	# Comparisons are made on message locations.
	redef fun <(other: OTHER): Bool do
		if location == null then return true
		if other.location == null then return false

		return location.as(not null) < other.location.as(not null)
	end

	redef fun ==(other): Bool do
		if not other isa Message then return false
		return location == other.location and tag == other.tag and text == other.text
	end

	redef fun to_s: String
	do
		var l = location
		if l == null then
			return text
		else
			return "{l}: {text}"
		end
	end

	# A colored version of the message including the original source line
	fun to_color_string: String
	do
		var esc = 27.code_point
		#var red = "{esc}[0;31m"
		#var bred = "{esc}[1;31m"
		#var green = "{esc}[0;32m"
		var yellow = "{esc}[0;33m"
		var def = "{esc}[0m"

		var tag = tag
		if tag != null then
			tag = " ({tag})"
		else
			tag = ""
		end
		var l = location
		if l == null then
			return "{text}{tag}"
		else if l.file == null then
			return "{yellow}{l}{def}: {text}{tag}"
		else
			return "{yellow}{l}{def}: {text}{tag}\n{l.colored_line("1;31")}"
		end
	end
end
src/toolcontext.nit:29,1--116,3