<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE language SYSTEM "language.dtd">
<!--
    Copyright (C) Joseph Wenninger, 2008
    Highlighting for SystemC (www.systemc.org)
    Highlighting licensed as LGPL 2+
================================================================================
    July 17th 2008                            Initial version
-->
<language name="SystemC" version="2" kateversion="2.4" section="Hardware" extensions="*.c++;*.cxx;*.cpp;*.cc;*.C;*.h;*.hh;*.H;*.h++;*.hxx;*.hpp;*.hcc;*.moc" mimetype="text/x-c++src;text/x-c++hdr;text/x-chdr" priority="1" author="Joseph Wenninger (jowenn@kde.org)" license="LGPLv2+">

<highlighting>
<list name="systemc_keywords">
    <item> sensitive </item>
</list>
<list name="systemc_functions">
    <item> dont_initialize </item>
    <item> gen_unique_name </item>
    <item> name </item>
    <item> next_trigger </item>
    <item> sc_assert_fail </item>
    <item> sc_copyright </item>
    <item> sc_cycle </item>
    <item> sc_initialize </item>
    <item> sc_simulation_time </item>
    <item> sc_start </item>
    <item> sc_stop </item>
    <item> sc_get_default_time_unit </item>
    <item> sc_get_default_time_resolution </item>
    <item> sc_time_stamp </item>
    <item> sc_version </item>
    <item> timed_out </item>
    <item> wait </item>
    <item> sc_trace </item>
    <item> sc_create_vcd_trace_file </item>
    <item> sc_close_vcd_trace_file </item>
    
</list>
<list name="systemc_macros">
    <item> SC_MODULE </item>
    <item> SC_CTOR </item>
    <item> SC_METHOD </item>
    <item> SC_THREAD </item>
</list>
<list name="systemc_datatypes">
    <item> sc_time_unit </item>
    <item> sc_clock </item>
    <item> sc_int </item>
    <item> sc_uint </item>
    <item> sc_bigint </item>
    <item> sc_biguint </item>
    <item> sc_logic </item>
    <item> sc_lv </item>
    <item> sc_bit </item>
    <item> sc_bv </item>
    <item> sc_fixed </item>
    <item> sc_ufixed </item>
    <item> sc_fixed_fast </item>
    <item> sc_ufixed_fast </item>
    <item> sc_fix </item>
    <item> sc_ufix </item>
    <item> sc_buffer </item>
    <item> sc_fifo </item>
    <item> sc_mutex </item>
    <item> sc_semaphore </item>
    <item> sc_signal </item>
    <item> sc_signal_resolved </item>
    <item> sc_signal_rv </item>
    <item> sc_fifo_in_if </item>
    <item> sc_fifo_out_if </item>
    <item> sc_mutex_if </item>
    <item> sc_semaphore_if </item>
    <item> sc_signal_in_if </item>
    <item> sc_signal_inout_if </item>
    <item> sc_master </item>
    <item> sc_inmaster </item>
    <item> sc_outmaster </item>
    <item> sc_inout_master </item>
    <item> sc_indexed </item>
    <item> sc_slave </item>
    <item> sc_inslave </item>
    <item> sc_outslave </item>
    <item> sc_inoutslave </item>
    <item> sc_in </item>
    <item> sc_out </item>
    <item> sc_inout </item>
    <item> sc_noHandshake </item>
    <item> sc_fullHandshake </item>
    <item> sc_memfullHandshake </item>
    <item> sc_enable_Handshake </item>
    <item> sc_memenHandshake </item>
    <item> sc_link_mp </item>
    <item> sc_trace_file </item>
</list>
<contexts>
  <context name="Normal" attribute="Normal Text" lineEndContext="#stay">
    <Detect2Chars attribute="Comment" context="Commentar 2" char="/" char1="*" beginRegion="Comment"/> <!-- see below -->
    <keyword attribute="Extensions-Keywords" context="#stay" String="systemc_keywords" />
    <keyword attribute="Extensions-Functions" context="#stay" String="systemc_functions" />
    <keyword attribute="Extensions-Macros" context="#stay" String="systemc_macros" />
    <keyword attribute="Data Type" context="#stay" String="systemc_datatypes" />
    <IncludeRules context="##C++" />
  </context>
  
  <context attribute="Comment" lineEndContext="#stay" name="Commentar 2">
      <DetectSpaces />
      <Detect2Chars attribute="Comment" context="#pop" char="*" char1="/" endRegion="Comment"/>
      <IncludeRules context="##Alerts" />
      <DetectIdentifier />
  </context>

</contexts>

<itemDatas>
  <itemData name="Normal Text" defStyleNum="dsNormal" />
  <itemData name="Keyword"      defStyleNum="dsKeyword"/>
  <itemData name="Extensions-Macros"   defStyleNum="dsDecVal" color="#0095ff" selColor="#ffffff" bold="1" italic="0"/>
  <itemData name="Extensions-Functions"   defStyleNum="dsFunction" color="#000000" selColor="#ffffff" bold="1" italic="1"/>
  <itemData name="Extensions-Keywords"   defStyleNum="dsFloat" />
  <itemData name="Data Type"    defStyleNum="dsDataType"/>
  <itemData name="Comment"      defStyleNum="dsComment"/>
<!--   <itemData name="Comment" defStyleNum="dsComment" /> -->
</itemDatas>

</highlighting>
<general>
    <comments>
        <comment name="singleLine" start="//" />
        <!-- implement support for something like this:<comment name="multiLine" start="/*" end="*/" region="Comment##C++"/>-->
        <comment name="multiLine" start="/*" end="*/" region="Comment"/>
    </comments>
    <keywords casesensitive="1" />
  </general>
</language>