當前位置: 首頁>>代碼示例>>Python>>正文


Python VHDLDesignFile.parse方法代碼示例

本文整理匯總了Python中vunit.vhdl_parser.VHDLDesignFile.parse方法的典型用法代碼示例。如果您正苦於以下問題:Python VHDLDesignFile.parse方法的具體用法?Python VHDLDesignFile.parse怎麽用?Python VHDLDesignFile.parse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在vunit.vhdl_parser.VHDLDesignFile的用法示例。


在下文中一共展示了VHDLDesignFile.parse方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: parse_single_context

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
 def parse_single_context(self, code):
     """
     Helper function to parse a single context
     """
     design_file = VHDLDesignFile.parse(code)
     self.assertEqual(len(design_file.contexts), 1)
     return design_file.contexts[0]
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:9,代碼來源:test_vhdl_parser.py

示例2: parse_single_package_body

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
 def parse_single_package_body(self, code):
     """
     Helper function to parse a single package body
     """
     design_file = VHDLDesignFile.parse(code)
     self.assertEqual(len(design_file.package_bodies), 1)
     return design_file.package_bodies[0]
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:9,代碼來源:test_vhdl_parser.py

示例3: test_getting_component_instantiations_from_design_file

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
    def test_getting_component_instantiations_from_design_file(self):
        design_file = VHDLDesignFile.parse("""
entity top is
end entity;

architecture arch of top is
begin
    labelFoo : component foo
    generic map(WIDTH => 16)
    port map(clk => '1',
             rst => '0',
             in_vec => record_reg.input_signal,
             output => some_signal(UPPER_CONSTANT-1 downto LOWER_CONSTANT+1));

    label2Foo : foo2
    port map(clk => '1',
             rst => '0',
             output => "00");

    label3Foo : foo3 port map (clk, rst, X"A");

end architecture;

""")
        component_instantiations = design_file.component_instantiations
        self.assertEqual(len(component_instantiations), 3)
        self.assertEqual(component_instantiations[0], "foo")
        self.assertEqual(component_instantiations[1], "foo2")
        self.assertEqual(component_instantiations[2], "foo3")
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:31,代碼來源:test_vhdl_parser.py

示例4: parse_single_entity

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
 def parse_single_entity(self, code):
     """
     Helper function to parse a single entity
     """
     design_file = VHDLDesignFile.parse(code)
     self.assertEqual(len(design_file.entities), 1)
     return design_file.entities[0]
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:9,代碼來源:test_vhdl_parser.py

示例5: test_parsing_references

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
    def test_parsing_references(self):
        design_file = VHDLDesignFile.parse(
            """
library name1;
 use name1.foo.all;

library ieee ;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;

use name1.bla.all;

library lib1,lib2, lib3;
use lib1.foo, lib2.bar,lib3.xyz;

context name1.is_identifier;

entity work1.foo1
entity work1.foo1(a1)
for all : bar use entity work2.foo2
for all : bar use entity work2.foo2 (a2)
for foo : bar use configuration work.cfg

entity foo is -- False
configuration bar of ent -- False

package new_pkg is new lib.pkg;
"""
        )
        self.assertEqual(len(design_file.references), 14)
        self.assertEqual(
            sorted(design_file.references, key=repr),
            sorted(
                [
                    VHDLReference("configuration", "work", "cfg", None),
                    VHDLReference("context", "name1", "is_identifier", None),
                    VHDLReference("entity", "work1", "foo1", "a1"),
                    VHDLReference("entity", "work1", "foo1", None),
                    VHDLReference("entity", "work2", "foo2", "a2"),
                    VHDLReference("entity", "work2", "foo2", None),
                    VHDLReference("package", "ieee", "numeric_std", "all"),
                    VHDLReference("package", "ieee", "std_logic_1164", "all"),
                    VHDLReference("package", "lib1", "foo", None),
                    VHDLReference("package", "lib2", "bar", None),
                    VHDLReference("package", "lib3", "xyz", None),
                    VHDLReference("package", "name1", "bla", "all"),
                    VHDLReference("package", "name1", "foo", "all"),
                    VHDLReference("package", "lib", "pkg", None),
                ],
                key=repr,
            ),
        )
開發者ID:chiggs,項目名稱:vunit,代碼行數:54,代碼來源:test_vhdl_parser.py

示例6: test_getting_architectures_from_design_file

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
    def test_getting_architectures_from_design_file(self):
        design_file = VHDLDesignFile.parse("""
entity foo is
end entity;

architecture rtl of foo is
begin
end architecture;
""")
        self.assertEqual(len(design_file.entities), 1)
        self.assertEqual(len(design_file.architectures), 1)
        arch = design_file.architectures
        self.assertEqual(len(arch), 1)
        self.assertEqual(arch[0].entity, "foo")
        self.assertEqual(arch[0].identifier, "rtl")
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:17,代碼來源:test_vhdl_parser.py

示例7: test_getting_entities_from_design_file

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
    def test_getting_entities_from_design_file(self):
        design_file = VHDLDesignFile.parse("""
entity entity1 is
end entity;

package package1 is
end package;

entity entity2 is
end entity;
""")
        entities = design_file.entities
        self.assertEqual(len(entities), 2)
        self.assertEqual(entities[0].identifier, "entity1")
        self.assertEqual(entities[1].identifier, "entity2")
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:17,代碼來源:test_vhdl_parser.py

示例8: test_parsing_references

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
    def test_parsing_references(self):
        design_file = VHDLDesignFile.parse("""
library name1;
 use name1.foo.all;

library ieee ;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;

use name1.bla.all;

library lib1,lib2, lib3;
use lib1.foo, lib2.bar,lib3.xyz;

context name1.is_identifier;

entity work1.foo1
entity work1.foo1(a1)
for all : bar use entity work2.foo2
for all : bar use entity work2.foo2 (a2)
for foo : bar use configuration work.cfg

entity foo is -- False
configuration bar of ent -- False

package new_pkg is new lib.pkg;
""")
        self.assertEqual(len(design_file.references), 14)
        self.assertEqual(sorted(design_file.references, key=repr), sorted([
            VHDLReference('configuration', 'work', 'cfg', None),
            VHDLReference('context', 'name1', 'is_identifier', None),
            VHDLReference('entity', 'work1', 'foo1', 'a1'),
            VHDLReference('entity', 'work1', 'foo1', None),
            VHDLReference('entity', 'work2', 'foo2', 'a2'),
            VHDLReference('entity', 'work2', 'foo2', None),
            VHDLReference('package', 'ieee', 'numeric_std', 'all'),
            VHDLReference('package', 'ieee', 'std_logic_1164', 'all'),
            VHDLReference('package', 'lib1', 'foo', None),
            VHDLReference('package', 'lib2', 'bar', None),
            VHDLReference('package', 'lib3', 'xyz', None),
            VHDLReference('package', 'name1', 'bla', 'all'),
            VHDLReference('package', 'name1', 'foo', 'all'),
            VHDLReference('package', 'lib', 'pkg', None),
        ], key=repr))
開發者ID:KevinKes,項目名稱:vunit,代碼行數:46,代碼來源:test_vhdl_parser.py

示例9: test_parsing_libraries

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
    def test_parsing_libraries(self):
        design_file = VHDLDesignFile.parse("""
library name1;
 use name1.foo.all;

library ieee ;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;

use name1.bla.all;

library lib1,lib2, lib3;
use lib1.foo, lib2.bar,lib3.xyz;

context name1.is_identifier;
""")
        self.assertEqual(len(design_file.libraries), 5)
        self.assertEqual(len(design_file.contexts), 0)
        self.assertEqual(design_file.libraries, 
                         {"ieee" : set([("numeric_std", "all"), ("std_logic_1164", "all")]),
                          "name1" : set([("foo", "all"), ("bla", "all"), ("is_identifier",)]),
                          "lib1" : set([("foo",)]),
                          "lib2" : set([("bar",)]),
                          "lib3" : set([("xyz",)])})
開發者ID:tomasnilefrost,項目名稱:vunit,代碼行數:26,代碼來源:test_vhdl_parser.py

示例10: test_parsing_empty

# 需要導入模塊: from vunit.vhdl_parser import VHDLDesignFile [as 別名]
# 或者: from vunit.vhdl_parser.VHDLDesignFile import parse [as 別名]
 def test_parsing_empty(self):
     design_file = VHDLDesignFile.parse("")
     self.assertEqual(design_file.entities, [])
     self.assertEqual(design_file.packages, [])
     self.assertEqual(design_file.architectures, [])
開發者ID:jonasalowersson,項目名稱:vunit,代碼行數:7,代碼來源:test_vhdl_parser.py


注:本文中的vunit.vhdl_parser.VHDLDesignFile.parse方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。