GCC Middle and Back End API Reference
sarif_ice_notification Class Reference
Inheritance diagram for sarif_ice_notification:
Collaboration diagram for sarif_ice_notification:

Public Member Functions

 sarif_ice_notification (diagnostic_context *context, const diagnostic_info &diagnostic, sarif_builder *builder)
 
sarif_property_bagget_or_create_properties ()
 
enum kind get_kind () const final override
 
void print (pretty_printer *pp, bool formatted) const final override
 
void set (const char *key, value *v)
 
valueget (const char *key) const
 
void set_string (const char *key, const char *utf8_value)
 
void set_integer (const char *key, long v)
 
void set_float (const char *key, double v)
 
void set_bool (const char *key, bool v)
 
void dump (FILE *, bool formatted) const
 

Private Types

typedef hash_map< char *, value *, simple_hashmap_traits< nofree_string_hash, value * > > map_t
 

Private Attributes

map_t m_map
 
auto_vec< const char * > m_keys
 

Detailed Description

Subclass of sarif_object for SARIF notification objects
(SARIF v2.1.0 section 3.58).

This subclass is specifically for notifying when an
internal compiler error occurs.   

Member Typedef Documentation

◆ map_t

Constructor & Destructor Documentation

◆ sarif_ice_notification()

sarif_ice_notification::sarif_ice_notification ( diagnostic_context * context,
const diagnostic_info & diagnostic,
sarif_builder * builder )
class sarif_ice_notification : public sarif_object.   
sarif_ice_notification's ctor.
DIAGNOSTIC is an internal compiler error.   

References ggc_alloc(), pp_clear_output_area(), pp_formatted_text(), diagnostic_context::printer, json::object::set(), and json::object::set_string().

Member Function Documentation

◆ dump()

void value::dump ( FILE * outf,
bool formatted ) const
inherited
class json::value.   
Dump this json::value tree to OUTF.

The key/value pairs of json::objects are printed in the order
in which the keys were originally inserted.   

References ggc_alloc(), pp_buffer, pp_flush(), and json::value::print().

Referenced by json_output_format::flush_to_file(), and generate_results().

◆ get()

value * object::get ( const char * key) const
inherited
Get the json::value * for KEY.

The object retains ownership of the value.   

References gcc_assert, json::object::get(), json::object::m_map, and NULL.

Referenced by json::object::get(), and sarif_object::get_or_create_properties().

◆ get_kind()

enum kind json::object::get_kind ( ) const
inlinefinaloverridevirtualinherited

Implements json::value.

References json::JSON_OBJECT.

◆ get_or_create_properties()

sarif_property_bag & sarif_object::get_or_create_properties ( )
inherited
class sarif_object : public json::object.   

References json::object::get(), ggc_alloc(), json::JSON_OBJECT, and json::object::set().

◆ print()

void object::print ( pretty_printer * pp,
bool formatted ) const
finaloverridevirtualinherited

◆ set()

◆ set_bool()

void object::set_bool ( const char * key,
bool v )
inherited
Set value of KEY within this object to the JSON
literal true or false, based on V.   

References json::object::set().

Referenced by sarif_invocation::prepare_to_flush().

◆ set_float()

void object::set_float ( const char * key,
double v )
inherited
Set value of KEY within this object to a JSON
floating point value based on V.   

References json::object::set().

Referenced by make_json_for_timevar_time_def().

◆ set_integer()

◆ set_string()

Field Documentation

◆ m_keys

auto_vec<const char *> json::object::m_keys
privateinherited

◆ m_map

map_t json::object::m_map
privateinherited

The documentation for this class was generated from the following file: