lib/rouge/lexers/fortran.rb in rouge-2.0.7 vs lib/rouge/lexers/fortran.rb in rouge-2.1.0
- old
+ new
@@ -5,67 +5,91 @@
module Rouge
module Lexers
class Fortran < RegexLexer
title "Fortran"
- desc "Fortran 95 Programming Language"
+ desc "Fortran 2008 (free-form)"
tag 'fortran'
- filenames '*.f90', '*.f95',
- '*.F90', '*.F95'
+ filenames '*.f90', '*.f95', '*.f03', '*.f08',
+ '*.F90', '*.F95', '*.F03', '*.F08'
mimetypes 'text/x-fortran'
name = /[A-Z][_A-Z0-9]*/i
kind_param = /(\d+|#{name})/
exponent = /[ED][+-]?\d+/i
def self.keywords
# Fortran allows to omit whitespace between certain keywords...
@keywords ||= Set.new %w(
- allocatable allocate assignment backspace block blockdata call case
- close common contains continue cycle data deallocate default
- dimension do elemental else elseif elsewhere end endblockdata enddo
- endfile endforall endfunction endif endinterface endmodule endprogram
- endselect endsubroutine endtype endwhere entry equivalence exit
- external forall format function go goto if implicit in include inout
- inquire intent interface intrinsic module namelist none nullify only
- open operator optional out parameter pointer print private procedure
- program public pure read recursive result return rewind save select
- selectcase sequence stop subroutine target then to type use where
- while write
+ abstract all allocatable allocate assign assignment asynchronous
+ backspace bind block blockdata close common concurrent contiguous call
+ case class codimension contains continue cycle data deallocate
+ deferred dimension do elemental else elseif elsewhere end endblock
+ endblockdata enddo endenum endfile endforall endfunction endif
+ endinterface endmodule endprogram endselect endsubmodule endsubroutine
+ endtype endwhere endwhile entry enum enumerator equivalence error exit
+ external final flush forall format function generic go goto if
+ implicit import in include inout inquire intent interface intrinsic is
+ module namelist non_overridable none nopass nullify only open operator
+ optional out parameter pass pause pointer print private procedure
+ program protected public pure read recursive result return rewind save
+ select selectcase sequence stop submodule subroutine target then to
+ type use value volatile wait where while write
)
end
def self.types
+ # There is a separate rule for "double precision" (two words) below
@types ||= Set.new %w(
- character complex double precision doubleprecision integer logical real
+ character complex doubleprecision integer logical real
)
end
def self.intrinsics
@intrinsics ||= Set.new %w(
- abs achar acos adjustl adjustr aimag aint all allocated anint any
- asin associated atan atan2 bit_size btest ceiling char cmplx conjg
- cos cosh count cpu_time cshift date_and_time dble digits dim
- dot_product dprod eoshift epsilon exp exponent floor fraction huge
- iachar iand ibclr ibits ibset ichar ieor index int ior ishift ishiftc
- kind lbound len len_trim lge lgt lle llt log log10 logical matmul max
- maxexponent maxloc maxval merge min minexponent minloc minval mod
- modulo mvbits nearest nint not null pack precision present product
- radix random_number random_seed range real repeat reshape rrspacing
- scale scan selected_int_kind selected_real_kind set_exponent shape
- sign sin sinh size spacing spread sqrt sum system_clock tan tanh tiny
- transfer transpose trim ubound unpack verify
+ abs achar acos acosh adjustl adjustr aimag aint all allocated anint
+ any asin asinh associated atan atan2 atanh bessel_j0 bessel_j1
+ bessel_jn bessel_y0 bessel_y1 bessel_yn bge bgt bit_size ble blt btest
+ c_associated c_f_pointer c_f_procpointer c_funloc c_loc c_sizeof
+ ceiling char cmplx command_argument_count compiler_options
+ compiler_version conjg cos cosh count cpu_time cshift date_and_time
+ dble digits dim dot_product dprod dshiftl dshiftr eoshift epsilon erf
+ erfc_scaled erfc execute_command_line exp exponent extends_type_of
+ findloc floor fraction gamma get_command_argument get_command
+ get_environment_variable huge hypot iachar iall iand iany ibclr ibits
+ ibset ichar ieee_class ieee_copy_sign ieee_get_flag
+ ieee_get_halting_mode ieee_get_rounding_mode ieee_get_status
+ ieee_get_underflow_mode ieee_is_finite ieee_is_nan ieee_is_normal
+ ieee_logb ieee_next_after ieee_rem ieee_rint ieee_scalb
+ ieee_selected_real_kind ieee_set_flag ieee_set_halting_mode
+ ieee_set_rounding_mode ieee_set_status ieee_set_underflow_mode
+ ieee_support_datatype ieee_support_denormal ieee_support_divide
+ ieee_support_flag ieee_support_halting ieee_support_inf
+ ieee_support_io ieee_support_nan ieee_support_rounding
+ ieee_support_sqrt ieee_support_standard ieee_support_underflow_control
+ ieee_unordered ieee_value ieor image_index index int ior iparity
+ is_contiguous is_iostat_end is_iostat_eor ishft ishftc kind lbound
+ lcobound leadz len_trim len lge lgt lle llt log_gamma log log10
+ logical maskl maskr matmul max maxexponent maxloc maxval merge_bits
+ merge min minexponent minloc minval mod modulo move_alloc mvbits
+ nearest new_line nint norm2 not null num_images pack parity popcnt
+ poppar present product radix random_number random_seed range real
+ repeat reshape rrspacing same_type_as scale scan selected_char_kind
+ selected_int_kind selected_real_kind set_exponent shape shifta shiftl
+ shiftr sign sin sinh size spacing spread sqrt storage_size sum
+ system_clock tan tanh this_image tiny trailz transfer transpose trim
+ ubound ucobound unpack verify
)
end
state :root do
rule /[\s\n]+/, Text::Whitespace
rule /!.*$/, Comment::Single
rule /^#.*$/, Comment::Preproc
- rule /::|[()\/;,:&]/, Punctuation
+ rule /::|[()\/;,:&\[\]]/, Punctuation
# TODO: This does not take into account line continuation.
rule /^(\s*)([0-9]+)\b/m do |m|
token Text::Whitespace, m[1]
token Name::Label, m[2]
@@ -97,9 +121,13 @@
rule /(#{kind_param}_)?"/, Str::Double, :string_double
rule /[.](TRUE|FALSE)[.](_#{kind_param})?/i, Keyword::Constant
rule %r{\*\*|//|==|/=|<=|>=|=>|[-+*/<>=%]}, Operator
rule /\.(?:EQ|NE|LT|LE|GT|GE|NOT|AND|OR|EQV|NEQV|[A-Z]+)\./i, Operator::Word
+
+ # To make sure "double precision" written as two words is highlighted
+ # properly. "doubleprecision" is covered by a different rule.
+ rule /double\s+precision\b/i, Keyword::Type
rule /#{name}/m do |m|
match = m[0].downcase
if self.class.keywords.include? match
token Keyword