rggen-veryl 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (73) hide show
  1. checksums.yaml +7 -0
  2. data/CODE_OF_CONDUCT.md +84 -0
  3. data/LICENSE +21 -0
  4. data/README.md +65 -0
  5. data/lib/rggen/veryl/bit_field/common.erb +8 -0
  6. data/lib/rggen/veryl/bit_field/type/custom.erb +25 -0
  7. data/lib/rggen/veryl/bit_field/type/custom.rb +121 -0
  8. data/lib/rggen/veryl/bit_field/type/rc_w0c_w1c_wc_woc.erb +21 -0
  9. data/lib/rggen/veryl/bit_field/type/rc_w0c_w1c_wc_woc.rb +46 -0
  10. data/lib/rggen/veryl/bit_field/type/ro_rotrg.erb +21 -0
  11. data/lib/rggen/veryl/bit_field/type/ro_rotrg.rb +40 -0
  12. data/lib/rggen/veryl/bit_field/type/rof.erb +20 -0
  13. data/lib/rggen/veryl/bit_field/type/rof.rb +7 -0
  14. data/lib/rggen/veryl/bit_field/type/rohw.erb +20 -0
  15. data/lib/rggen/veryl/bit_field/type/rohw.rb +28 -0
  16. data/lib/rggen/veryl/bit_field/type/row0trg_row1trg.erb +10 -0
  17. data/lib/rggen/veryl/bit_field/type/row0trg_row1trg.rb +30 -0
  18. data/lib/rggen/veryl/bit_field/type/rowo_rowotrg.erb +21 -0
  19. data/lib/rggen/veryl/bit_field/type/rowo_rowotrg.rb +52 -0
  20. data/lib/rggen/veryl/bit_field/type/rs_w0s_w1s_ws_wos.erb +21 -0
  21. data/lib/rggen/veryl/bit_field/type/rs_w0s_w1s_ws_wos.rb +36 -0
  22. data/lib/rggen/veryl/bit_field/type/rw_rwtrg_w1.erb +21 -0
  23. data/lib/rggen/veryl/bit_field/type/rw_rwtrg_w1.rb +46 -0
  24. data/lib/rggen/veryl/bit_field/type/rwc.erb +20 -0
  25. data/lib/rggen/veryl/bit_field/type/rwc.rb +26 -0
  26. data/lib/rggen/veryl/bit_field/type/rwe_rwl.erb +20 -0
  27. data/lib/rggen/veryl/bit_field/type/rwe_rwl.rb +34 -0
  28. data/lib/rggen/veryl/bit_field/type/rwhw.erb +19 -0
  29. data/lib/rggen/veryl/bit_field/type/rwhw.rb +30 -0
  30. data/lib/rggen/veryl/bit_field/type/rws.erb +20 -0
  31. data/lib/rggen/veryl/bit_field/type/rws.rb +26 -0
  32. data/lib/rggen/veryl/bit_field/type/w0crs_w0src_w1crs_w1src_wcrs_wsrc.erb +21 -0
  33. data/lib/rggen/veryl/bit_field/type/w0crs_w0src_w1crs_w1src_wcrs_wsrc.rb +35 -0
  34. data/lib/rggen/veryl/bit_field/type/w0t_w1t.erb +20 -0
  35. data/lib/rggen/veryl/bit_field/type/w0t_w1t.rb +23 -0
  36. data/lib/rggen/veryl/bit_field/type/w0trg_w1trg.erb +10 -0
  37. data/lib/rggen/veryl/bit_field/type/w0trg_w1trg.rb +20 -0
  38. data/lib/rggen/veryl/bit_field/type/wo_wo1_wotrg.erb +22 -0
  39. data/lib/rggen/veryl/bit_field/type/wo_wo1_wotrg.rb +38 -0
  40. data/lib/rggen/veryl/bit_field/type/wrc_wrs.erb +20 -0
  41. data/lib/rggen/veryl/bit_field/type/wrc_wrs.rb +20 -0
  42. data/lib/rggen/veryl/bit_field/type.rb +70 -0
  43. data/lib/rggen/veryl/bit_field/veryl_top.rb +102 -0
  44. data/lib/rggen/veryl/component.rb +8 -0
  45. data/lib/rggen/veryl/factories.rb +11 -0
  46. data/lib/rggen/veryl/feature.rb +46 -0
  47. data/lib/rggen/veryl/register/type/default.erb +15 -0
  48. data/lib/rggen/veryl/register/type/external.erb +13 -0
  49. data/lib/rggen/veryl/register/type/external.rb +28 -0
  50. data/lib/rggen/veryl/register/type/indirect.erb +17 -0
  51. data/lib/rggen/veryl/register/type/indirect.rb +22 -0
  52. data/lib/rggen/veryl/register/type/rw.erb +15 -0
  53. data/lib/rggen/veryl/register/type/rw.rb +7 -0
  54. data/lib/rggen/veryl/register/type.rb +34 -0
  55. data/lib/rggen/veryl/register/veryl_top.rb +43 -0
  56. data/lib/rggen/veryl/register_block/protocol/apb.erb +17 -0
  57. data/lib/rggen/veryl/register_block/protocol/apb.rb +14 -0
  58. data/lib/rggen/veryl/register_block/protocol/axi4lite.erb +19 -0
  59. data/lib/rggen/veryl/register_block/protocol/axi4lite.rb +20 -0
  60. data/lib/rggen/veryl/register_block/protocol/wishbone.erb +18 -0
  61. data/lib/rggen/veryl/register_block/protocol/wishbone.rb +17 -0
  62. data/lib/rggen/veryl/register_block/protocol.rb +54 -0
  63. data/lib/rggen/veryl/register_block/veryl_top.rb +71 -0
  64. data/lib/rggen/veryl/register_file/veryl_top.rb +26 -0
  65. data/lib/rggen/veryl/utility/data_object.rb +79 -0
  66. data/lib/rggen/veryl/utility/interface_instance.rb +43 -0
  67. data/lib/rggen/veryl/utility/local_scope.rb +48 -0
  68. data/lib/rggen/veryl/utility/modport.rb +29 -0
  69. data/lib/rggen/veryl/utility/module_definition.rb +63 -0
  70. data/lib/rggen/veryl/utility.rb +37 -0
  71. data/lib/rggen/veryl/version.rb +7 -0
  72. data/lib/rggen/veryl.rb +57 -0
  73. metadata +133 -0
@@ -0,0 +1,79 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ module Utility
6
+ class DataObject
7
+ include Core::Utility::AttributeSetter
8
+
9
+ def initialize(object_type, default_attributes = {})
10
+ @object_type = object_type
11
+ apply_attributes(**default_attributes)
12
+ block_given? && yield(self)
13
+ end
14
+
15
+ define_attribute :name
16
+ define_attribute :direction
17
+ define_attribute :type, :logic
18
+ define_attribute :width
19
+ define_attribute :array_size
20
+ define_attribute :default
21
+
22
+ def declaration
23
+ declaration_snippets
24
+ .reject { _1.nil? || _1.empty? }
25
+ .join(' ')
26
+ end
27
+
28
+ def identifier
29
+ SystemVerilog::Common::Utility::Identifier.new(name) do |id|
30
+ id.__width__(width)
31
+ id.__array_size__(array_size)
32
+ end
33
+ end
34
+
35
+ private
36
+
37
+ def declaration_snippets
38
+ [
39
+ declaration_header,
40
+ "#{name}:",
41
+ direction_keyword,
42
+ type_declaration,
43
+ default_value
44
+ ]
45
+ end
46
+
47
+ def declaration_header
48
+ @object_type if @object_type in :var | :param | :const
49
+ end
50
+
51
+ def direction_keyword
52
+ @direction if @object_type == :port
53
+ end
54
+
55
+ def type_declaration
56
+ if emit_width? || array_size
57
+ "#{type}<#{array_dimensions.join(', ')}>"
58
+ else
59
+ type
60
+ end
61
+ end
62
+
63
+ def emit_width?
64
+ width && (!width.is_a?(Integer) || width >= 2)
65
+ end
66
+
67
+ def array_dimensions
68
+ dimensions = Array(array_size)
69
+ dimensions << width if emit_width?
70
+ dimensions
71
+ end
72
+
73
+ def default_value
74
+ "= #{default}" if @object_type in :param | :const
75
+ end
76
+ end
77
+ end
78
+ end
79
+ end
@@ -0,0 +1,43 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ module Utility
6
+ class InterfaceInstance < SystemVerilog::Common::Utility::InterfaceInstance
7
+ define_attribute :param_values
8
+
9
+ def instantiation
10
+ [
11
+ 'inst',
12
+ "#{name}:",
13
+ type_notation
14
+ ].join(' ')
15
+ end
16
+
17
+ alias_method :declaration, :instantiation
18
+
19
+ private
20
+
21
+ def type_notation
22
+ [
23
+ interface_type,
24
+ array_size_notation,
25
+ param_assignments
26
+ ].join
27
+ end
28
+
29
+ def array_size_notation
30
+ return if (array_size&.size || 0).zero?
31
+
32
+ "[#{array_size.join(', ')}]"
33
+ end
34
+
35
+ def param_assignments
36
+ return if (param_values&.size || 0).zero?
37
+
38
+ "#(#{param_values.map { |k, v| "#{k}: #{v}" }.join(', ')})"
39
+ end
40
+ end
41
+ end
42
+ end
43
+ end
@@ -0,0 +1,48 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ module Utility
6
+ class LocalScope < SystemVerilog::Common::Utility::StructureDefinition
7
+ define_attribute :name
8
+ define_attribute :consts
9
+ define_attribute :variables
10
+ define_attribute :loop_size
11
+
12
+ private
13
+
14
+ def header_code(code)
15
+ code << ":#{name} {" << nl
16
+ end
17
+
18
+ def footer_code(code)
19
+ code << '}'
20
+ end
21
+
22
+ def pre_body_code(code)
23
+ generate_for_header(code)
24
+ add_declarations_to_body(code, Array(consts))
25
+ add_declarations_to_body(code, Array(variables))
26
+ end
27
+
28
+ def generate_for_header(code)
29
+ loop_size&.each do |genvar, size|
30
+ code << "for #{genvar} in 0..#{size} :g {" << nl
31
+ code.indent += 2
32
+ end
33
+ end
34
+
35
+ def post_body_code(code)
36
+ generate_for_footer(code)
37
+ end
38
+
39
+ def generate_for_footer(code)
40
+ loop_size&.each do
41
+ code.indent -= 2
42
+ code << '}' << nl
43
+ end
44
+ end
45
+ end
46
+ end
47
+ end
48
+ end
@@ -0,0 +1,29 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ module Utility
6
+ class Modport < SystemVerilog::Common::Utility::InterfacePort
7
+ def declaration
8
+ [
9
+ "#{name}:",
10
+ 'modport',
11
+ port_type
12
+ ].join(' ')
13
+ end
14
+
15
+ private
16
+
17
+ def port_type
18
+ "#{@interface_type}::#{@modport_name}#{array_size_notation}"
19
+ end
20
+
21
+ def array_size_notation
22
+ return if (@array_size&.size || 0).zero?
23
+
24
+ "[#{@array_size.join(', ')}]"
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,63 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ module Utility
6
+ class ModuleDefinition < SystemVerilog::Common::Utility::StructureDefinition
7
+ define_attribute :name
8
+ define_attribute :package_imports
9
+ define_attribute :params
10
+ define_attribute :ports
11
+ define_attribute :variables
12
+
13
+ private
14
+
15
+ def header_code(code)
16
+ package_import_declaration(code)
17
+ module_header_begin(code)
18
+ param_declarations(code)
19
+ port_declarations(code)
20
+ module_header_end(code)
21
+ end
22
+
23
+ def package_import_declaration(code)
24
+ package_imports&.each do |package|
25
+ code << "import #{package}::*;" << nl
26
+ end
27
+ end
28
+
29
+ def module_header_begin(code)
30
+ code << "pub module #{name} "
31
+ end
32
+
33
+ def param_declarations(code)
34
+ return if (params&.size || 0).zero?
35
+
36
+ wrap(code, '#(', ')') do
37
+ add_declarations_to_header(code, params)
38
+ end
39
+ end
40
+
41
+ def port_declarations(code)
42
+ return if (ports&.size || 0).zero?
43
+
44
+ wrap(code, '(', ')') do
45
+ add_declarations_to_header(code, ports)
46
+ end
47
+ end
48
+
49
+ def module_header_end(code)
50
+ code << '{' << nl
51
+ end
52
+
53
+ def pre_body_code(code)
54
+ add_declarations_to_body(code, Array(variables))
55
+ end
56
+
57
+ def footer_code
58
+ '}'
59
+ end
60
+ end
61
+ end
62
+ end
63
+ end
@@ -0,0 +1,37 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ module Utility
6
+ private
7
+
8
+ def local_scope(name, attributes = {}, &block)
9
+ LocalScope
10
+ .new(attributes.merge(name: name), &block)
11
+ .to_code
12
+ end
13
+
14
+ def module_definition(name, attributes = {}, &block)
15
+ ModuleDefinition
16
+ .new(attributes.merge(name: name), &block)
17
+ .to_code
18
+ end
19
+
20
+ def width_cast(expression, width)
21
+ "(#{expression} as #{width})"
22
+ end
23
+
24
+ def repeat(count, expression)
25
+ "{#{expression} repeat #{count}}"
26
+ end
27
+
28
+ def array(expressions)
29
+ concat(expressions.reverse)
30
+ end
31
+
32
+ def unused
33
+ '_'
34
+ end
35
+ end
36
+ end
37
+ end
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RgGen
4
+ module Veryl
5
+ VERSION = '0.1.0'
6
+ end
7
+ end
@@ -0,0 +1,57 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative 'veryl/version'
4
+ require_relative 'veryl/utility/data_object'
5
+ require_relative 'veryl/utility/modport'
6
+ require_relative 'veryl/utility/interface_instance'
7
+ require_relative 'veryl/utility/local_scope'
8
+ require_relative 'veryl/utility/module_definition'
9
+ require_relative 'veryl/utility'
10
+ require_relative 'veryl/component'
11
+ require_relative 'veryl/feature'
12
+ require_relative 'veryl/factories'
13
+
14
+ RgGen.setup_plugin :'rggen-veryl' do |plugin|
15
+ plugin.version RgGen::Veryl::VERSION
16
+
17
+ plugin.register_component :veryl do
18
+ component RgGen::Veryl::Component,
19
+ RgGen::Veryl::ComponentFactory
20
+ feature RgGen::Veryl::Feature,
21
+ RgGen::Veryl::FeatureFactory
22
+ end
23
+
24
+ plugin.files [
25
+ 'veryl/register_block/veryl_top',
26
+ 'veryl/register_block/protocol',
27
+ 'veryl/register_block/protocol/apb',
28
+ 'veryl/register_block/protocol/axi4lite',
29
+ 'veryl/register_block/protocol/wishbone',
30
+ 'veryl/register_file/veryl_top',
31
+ 'veryl/register/veryl_top',
32
+ 'veryl/register/type',
33
+ 'veryl/register/type/external',
34
+ 'veryl/register/type/indirect',
35
+ 'veryl/register/type/rw',
36
+ 'veryl/bit_field/veryl_top',
37
+ 'veryl/bit_field/type',
38
+ 'veryl/bit_field/type/custom',
39
+ 'veryl/bit_field/type/rc_w0c_w1c_wc_woc',
40
+ 'veryl/bit_field/type/ro_rotrg',
41
+ 'veryl/bit_field/type/rof',
42
+ 'veryl/bit_field/type/rohw',
43
+ 'veryl/bit_field/type/row0trg_row1trg',
44
+ 'veryl/bit_field/type/rowo_rowotrg',
45
+ 'veryl/bit_field/type/rs_w0s_w1s_ws_wos',
46
+ 'veryl/bit_field/type/rw_rwtrg_w1',
47
+ 'veryl/bit_field/type/rwc',
48
+ 'veryl/bit_field/type/rwe_rwl',
49
+ 'veryl/bit_field/type/rwhw',
50
+ 'veryl/bit_field/type/rws',
51
+ 'veryl/bit_field/type/w0crs_w0src_w1crs_w1src_wcrs_wsrc',
52
+ 'veryl/bit_field/type/w0t_w1t',
53
+ 'veryl/bit_field/type/w0trg_w1trg',
54
+ 'veryl/bit_field/type/wo_wo1_wotrg',
55
+ 'veryl/bit_field/type/wrc_wrs'
56
+ ]
57
+ end
metadata ADDED
@@ -0,0 +1,133 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rggen-veryl
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Taichi Ishitani
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2024-11-28 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rggen-systemverilog
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: 0.33.1
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: 0.33.1
27
+ description: Veryl writer plugin for RgGen
28
+ email:
29
+ - rggen@googlegroups.com
30
+ executables: []
31
+ extensions: []
32
+ extra_rdoc_files: []
33
+ files:
34
+ - CODE_OF_CONDUCT.md
35
+ - LICENSE
36
+ - README.md
37
+ - lib/rggen/veryl.rb
38
+ - lib/rggen/veryl/bit_field/common.erb
39
+ - lib/rggen/veryl/bit_field/type.rb
40
+ - lib/rggen/veryl/bit_field/type/custom.erb
41
+ - lib/rggen/veryl/bit_field/type/custom.rb
42
+ - lib/rggen/veryl/bit_field/type/rc_w0c_w1c_wc_woc.erb
43
+ - lib/rggen/veryl/bit_field/type/rc_w0c_w1c_wc_woc.rb
44
+ - lib/rggen/veryl/bit_field/type/ro_rotrg.erb
45
+ - lib/rggen/veryl/bit_field/type/ro_rotrg.rb
46
+ - lib/rggen/veryl/bit_field/type/rof.erb
47
+ - lib/rggen/veryl/bit_field/type/rof.rb
48
+ - lib/rggen/veryl/bit_field/type/rohw.erb
49
+ - lib/rggen/veryl/bit_field/type/rohw.rb
50
+ - lib/rggen/veryl/bit_field/type/row0trg_row1trg.erb
51
+ - lib/rggen/veryl/bit_field/type/row0trg_row1trg.rb
52
+ - lib/rggen/veryl/bit_field/type/rowo_rowotrg.erb
53
+ - lib/rggen/veryl/bit_field/type/rowo_rowotrg.rb
54
+ - lib/rggen/veryl/bit_field/type/rs_w0s_w1s_ws_wos.erb
55
+ - lib/rggen/veryl/bit_field/type/rs_w0s_w1s_ws_wos.rb
56
+ - lib/rggen/veryl/bit_field/type/rw_rwtrg_w1.erb
57
+ - lib/rggen/veryl/bit_field/type/rw_rwtrg_w1.rb
58
+ - lib/rggen/veryl/bit_field/type/rwc.erb
59
+ - lib/rggen/veryl/bit_field/type/rwc.rb
60
+ - lib/rggen/veryl/bit_field/type/rwe_rwl.erb
61
+ - lib/rggen/veryl/bit_field/type/rwe_rwl.rb
62
+ - lib/rggen/veryl/bit_field/type/rwhw.erb
63
+ - lib/rggen/veryl/bit_field/type/rwhw.rb
64
+ - lib/rggen/veryl/bit_field/type/rws.erb
65
+ - lib/rggen/veryl/bit_field/type/rws.rb
66
+ - lib/rggen/veryl/bit_field/type/w0crs_w0src_w1crs_w1src_wcrs_wsrc.erb
67
+ - lib/rggen/veryl/bit_field/type/w0crs_w0src_w1crs_w1src_wcrs_wsrc.rb
68
+ - lib/rggen/veryl/bit_field/type/w0t_w1t.erb
69
+ - lib/rggen/veryl/bit_field/type/w0t_w1t.rb
70
+ - lib/rggen/veryl/bit_field/type/w0trg_w1trg.erb
71
+ - lib/rggen/veryl/bit_field/type/w0trg_w1trg.rb
72
+ - lib/rggen/veryl/bit_field/type/wo_wo1_wotrg.erb
73
+ - lib/rggen/veryl/bit_field/type/wo_wo1_wotrg.rb
74
+ - lib/rggen/veryl/bit_field/type/wrc_wrs.erb
75
+ - lib/rggen/veryl/bit_field/type/wrc_wrs.rb
76
+ - lib/rggen/veryl/bit_field/veryl_top.rb
77
+ - lib/rggen/veryl/component.rb
78
+ - lib/rggen/veryl/factories.rb
79
+ - lib/rggen/veryl/feature.rb
80
+ - lib/rggen/veryl/register/type.rb
81
+ - lib/rggen/veryl/register/type/default.erb
82
+ - lib/rggen/veryl/register/type/external.erb
83
+ - lib/rggen/veryl/register/type/external.rb
84
+ - lib/rggen/veryl/register/type/indirect.erb
85
+ - lib/rggen/veryl/register/type/indirect.rb
86
+ - lib/rggen/veryl/register/type/rw.erb
87
+ - lib/rggen/veryl/register/type/rw.rb
88
+ - lib/rggen/veryl/register/veryl_top.rb
89
+ - lib/rggen/veryl/register_block/protocol.rb
90
+ - lib/rggen/veryl/register_block/protocol/apb.erb
91
+ - lib/rggen/veryl/register_block/protocol/apb.rb
92
+ - lib/rggen/veryl/register_block/protocol/axi4lite.erb
93
+ - lib/rggen/veryl/register_block/protocol/axi4lite.rb
94
+ - lib/rggen/veryl/register_block/protocol/wishbone.erb
95
+ - lib/rggen/veryl/register_block/protocol/wishbone.rb
96
+ - lib/rggen/veryl/register_block/veryl_top.rb
97
+ - lib/rggen/veryl/register_file/veryl_top.rb
98
+ - lib/rggen/veryl/utility.rb
99
+ - lib/rggen/veryl/utility/data_object.rb
100
+ - lib/rggen/veryl/utility/interface_instance.rb
101
+ - lib/rggen/veryl/utility/local_scope.rb
102
+ - lib/rggen/veryl/utility/modport.rb
103
+ - lib/rggen/veryl/utility/module_definition.rb
104
+ - lib/rggen/veryl/version.rb
105
+ homepage: https://github.com/rggen/rggen-veryl
106
+ licenses:
107
+ - MIT
108
+ metadata:
109
+ bug_tracker_uri: https://github.com/rggen/rggen/issues
110
+ mailing_list_uri: https://groups.google.com/d/forum/rggen
111
+ rubygems_mfa_required: 'true'
112
+ source_code_uri: https://github.com/rggen/rggen-vhdl
113
+ wiki_uri: https://github.com/rggen/rggen/wiki
114
+ post_install_message:
115
+ rdoc_options: []
116
+ require_paths:
117
+ - lib
118
+ required_ruby_version: !ruby/object:Gem::Requirement
119
+ requirements:
120
+ - - ">="
121
+ - !ruby/object:Gem::Version
122
+ version: 3.0.0
123
+ required_rubygems_version: !ruby/object:Gem::Requirement
124
+ requirements:
125
+ - - ">="
126
+ - !ruby/object:Gem::Version
127
+ version: '0'
128
+ requirements: []
129
+ rubygems_version: 3.5.16
130
+ signing_key:
131
+ specification_version: 4
132
+ summary: rggen-veryl-0.1.0
133
+ test_files: []