亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? make_lib.pl

?? VHDL和Verilog轉換軟件
?? PL
字號:
#! /usr/local/bin/perl################################################################################## Copyright (c) 2000 - 2007 X-Tek Corporation## This script will read your VHDL or Verilog component library files and create # a database that X-HDL 4.0 can use for the component instantiations. Perform the # following steps to use a pre-defined library:## 1) cd to the directory containing the VHDL or Verilog component library: #      % cd ..../my_lib## 2) run the make_lib script on the library files: #       % make_lib -vhdl vhdl_file1.vhd vhdl_file2.vhd ....## make_lib will create a directory called .xhdl in the my_lib directory. Within the# .xhdl directory will be a database file for each component processed. These # database files are subsequently used by X-HDL when the components are instantiated.## Use make_lib -h to get help with the make_lib command line options## 3) Run X-HDL as usual. In the Translate menu, enter the information for the pre-defined# library in the 'Database Paths' list (or -db command-line option). The library # name can be whatever you want (this will be translated to a LIBRARY statement in VHDL). # The database path needs to be the path to the pre-defined VHDL, ie .../my_lib## 4) The pre-defined components will be found and instantiated. ###  Revision History#     Rev 1.6 - Mar. 19, 2007#        - Modified to generate new format X-HDL 4.0 database#     Rev 1.5 - Sep. 28, 2005#        - Modified to generate X-HDL 4.0 style database#     Rev 1.4 - May 21, 2002#        - Forced all library entry names to be lower-case for Verilog libraries#     Rev 1.3 - July 11, 2000#        - Added the command line option -l which forces all VHDL port names to be#          lower-case. In previous versions, this was the default, and only, #          operation. The default is now to leave port names as-is.#################################################################################use English;use strict;my $Revision = '1.6 Mar. 19, 2007';(my $myself = $0) =~ s/.*\/(\w+).*/$1/;# setup default optionsmy $lang = 'vhdl';my $lowercase = 0;my $lib = {};# process command line optionsmy $opt;while ($ARGV[0] =~ /^\-/) {	$opt = shift;	$lang = 'vlog' if ($opt eq '-vlog');	$lang = 'vhdl' if ($opt eq '-vhdl');   $lowercase = 1 if ($opt eq '-l');	&usage if ($opt eq '-h' || $opt !~ /^\-(h|l|vlog|vhdl)$/);}# create database directory if it does not existmkdir ".xhdl" if (!-e ".xhdl");$INPUT_RECORD_SEPARATOR = undef;# process in the specified filesmy ($text, $dirname, $file);while ($file = shift @ARGV) {	unless (open(CODE, "< $file")) {		print STDERR "Cannot open file $file for reading - skipping\n";		next;	}		# read code from file	$text = <CODE>;	close CODE;		# process a vhdl library   my $lib = {};	if ($lang eq 'vhdl') {		# strip all comments from the code		$text =~ s/\-\-.*?\n/\n/sg;		# grab the next entity		my ($name, $entity, @ports, $dir, $port, $component, $entity_name, $generic, @generics, $gen);		while ($text =~ s/^.*?\bentity\s+(\w+)\s+is//si) {			$name = "\L$1\E";			$entity_name = $1;			$text =~ s/^(.*?)end\s+(entity\s+)?${name}//si;			$entity = $component = $1;			$component =~ s/(^.*\b)(port\s*\()/$2/si;         $generic = $1;         $generic =~ s/^.*\b(generic\s*\()/$1/si;			$generic =~ s/\n//sg;         @generics = split(/\;/, $generic);			foreach my $g (@generics) {				if ($g =~ /\s*(\w+)\s*\:\s*(\w+)/) {					$gen = ($lowercase) ? "\L$1\E" : $1;					push(@{$lib->{$name}->{generics}}, {-val => $gen, -name => $gen});				}			}			$component =~ s/\battribute.*?\;//sgi;			1 while ($component =~ s/\n\s*\n/\n/s);			$component =~ s/\n\n/\n/sg;			$component = "component $entity_name " . $component . "end component;\n";			$entity =~ s/^.*?\bport\s*\(//si;			$entity =~ s/\n//sg;			@ports = split(/\;/, $entity);			foreach my $p (@ports) {				if ($p =~ /\s*(\w+)\s*\:\s*(\w+)/) {					$port = ($lowercase) ? "\L$1\E" : $1;					$dir = "\L$2\E";					$dir = ($dir =~ /^in$/) ? 'input' : ($dir =~ /^out$/) ? 'output' : ($dir =~ /^(inout|buffer)$/) ? 'inout' : '';					push(@{$lib->{$name}->{io}}, {-val => $port, -name => $port, -dir => $dir});				}			}			$lib->{$name}->{entity} = $name;			$lib->{$name}->{component} = $component;		}		# process a verilog library	} else {		# strip all comments from the code		$text =~ s/\/\/.*?\n/\n/sg;		$text =~ s/\/\*.*?\*\///sg;		# grab the next module		my ($name, @ports, $port_list, $port);		while ($text =~ s/^.*?\bmodule\s+(\w+)\s*\((.*?)\)//si) {         $name = $1;			my $lc_name = "\L$name\E";			$port_list = $2;			$port_list =~ s/\s//gs;			@ports = split(/\,/, $port_list);			foreach $port (@ports) {				push(@{$lib->{$lc_name}->{io}}, {-val => $port, -name => $port, -dir => ''});			}			$lib->{$lc_name}->{entity} = $name;		}	}   # output database   foreach my $dbname (keys %{$lib})   {      open(LIB, "> .xhdl/$dbname") || die "Cannot open .xhdl/$dbname for writing - database not created\n";            # output component data      print LIB "[Data]\n";      if ($lang eq 'vhdl') {         my $comp = $lib->{$dbname}->{component};         $comp =~ s/\n/\\n/g;         print LIB '%3Ccompdecl%3E="' . $comp . "\\n\"\n";      }      print LIB '%3CgenericOrder%3E=';      if (!defined($lib->{$dbname}->{generics})) {         print LIB '@Invalid()' . "\n";      } else {         my @generics;         foreach my $gen (@{$lib->{$dbname}->{generics}}) {            push (@generics, $gen->{-name});         }         print LIB join(", ", @generics) . "\n";      }      print LIB '%3CportOrder%3E=';      if (!defined($lib->{$dbname}->{io})) {         print LIB '@Invalid()' . "\n";      } else {         my @ports;         foreach my $io (@{$lib->{$dbname}->{io}}) {            push (@ports, $io->{-name});         }         print LIB join(", ", @ports) . "\n";      }      foreach my $gen (@{$lib->{$dbname}->{generics}}) {         my $name = $gen->{-name};         print LIB "$name\\alias=$name\n";         print LIB "$name\\category=";         print LIB (($lang eq 'vhdl') ? "109\n" : "111\n");         print LIB "$name\\port=0\n";      }      foreach my $io (@{$lib->{$dbname}->{io}}) {         my $name = $io->{-name};         print LIB "$name\\alias=$name\n";         print LIB "$name\\category=";         print LIB (($lang eq 'vhdl') ? "114\n" : "117\n");         print LIB "$name\\port=1\n";      }      print LIB "\n";            # output general information      print LIB '[%General]' . "\n";      print LIB '%3Cbasename%3E=' . "$dbname\n";      print LIB '%3Cclass%3E=108' . "\n";      print LIB '%3Cfilename%3E=' . "$file\n";      print LIB '%3Cpackage%3E=false' . "\n";      print LIB '%3Csource%3E=' . "\n";            close LIB;   }}sub usage {   print STDERR "\nThis is $myself $Revision running under Perl version $PERL_VERSION\n\n";   print STDERR "usage: $myself [-vhdl/-vlog] [-l] file [file...]\n\n";   print STDERR "       -vhdl  => create a VHDL library (default)\n";   print STDERR "       -vlog  => create a Verilog library\n";   print STDERR "       -l     => lower-case VHDL component port names. Default: Leave as-is\n";   print STDERR "       -h     => Print this message\n";   print STDERR "\n";   exit(-1);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
三级在线观看一区二区| 欧美一级高清片| 国产精品久久久久久久久动漫 | 精品国产人成亚洲区| 日韩福利电影在线观看| 日韩精品一区二区三区视频 | 激情综合网天天干| 久久无码av三级| 成人av先锋影音| 亚洲激情自拍视频| 91精品国产福利| 韩国女主播成人在线| 国产精品免费看片| 欧美视频精品在线| 韩国中文字幕2020精品| 日韩一区日韩二区| 欧美午夜精品一区二区蜜桃| 天堂精品中文字幕在线| 久久一二三国产| 在线精品视频免费观看| 美女在线一区二区| 中文字幕亚洲一区二区av在线 | 日韩午夜精品电影| 国产激情偷乱视频一区二区三区 | 一区二区三区丝袜| 日韩美女视频一区二区在线观看| 国产精品99久久久久久久女警| 国产精品国产三级国产aⅴ入口| 欧美性生活久久| 国产一区二区三区免费看| 亚洲欧美福利一区二区| 91精品国产一区二区人妖| 成人网男人的天堂| 日韩国产精品久久久| 国产精品久久久一本精品| 欧美日韩一区二区不卡| 国产成人福利片| 日韩中文字幕不卡| 国产精品国产三级国产普通话蜜臀 | 欧美亚洲禁片免费| 国产高清不卡一区二区| 亚洲国产一区二区三区 | 成人av网站在线观看| 久久精品国产一区二区三| 亚洲精品亚洲人成人网在线播放| 欧美不卡一区二区三区四区| 欧美性猛片xxxx免费看久爱| 国产精品99久| 另类专区欧美蜜桃臀第一页| 亚洲最大成人综合| 国产精品久久一级| www亚洲一区| 欧美一区二区视频在线观看| 99久久er热在这里只有精品15 | 蜜桃一区二区三区在线观看| 亚洲一区影音先锋| 亚洲色图视频免费播放| 久久久久久久网| 日韩午夜在线观看视频| 欧美日韩免费一区二区三区| 91麻豆国产香蕉久久精品| 风间由美中文字幕在线看视频国产欧美| 亚洲chinese男男1069| 一区二区三区四区亚洲| 亚洲色图在线看| 中文字幕永久在线不卡| 欧美激情一二三区| 国产欧美日韩另类一区| 精品对白一区国产伦| 精品人伦一区二区色婷婷| 欧美一区日本一区韩国一区| 欧美放荡的少妇| 欧美天堂亚洲电影院在线播放| 一本色道久久综合亚洲aⅴ蜜桃| 成人午夜电影网站| 99久久综合狠狠综合久久| 成人性色生活片| aaa国产一区| 91麻豆免费看| 欧美视频中文字幕| 91精品黄色片免费大全| 91精品午夜视频| 日韩欧美卡一卡二| 精品国产123| 国产农村妇女精品| 最新欧美精品一区二区三区| 国产精品白丝在线| 亚洲视频一区二区在线| 亚洲影视在线观看| 日韩精品亚洲一区二区三区免费| 美洲天堂一区二卡三卡四卡视频| 蜜臀av一区二区在线观看| 国产一区二区女| kk眼镜猥琐国模调教系列一区二区| av电影在线观看完整版一区二区| 91美女福利视频| 欧美一区二区高清| 久久免费午夜影院| 成人免费小视频| 日韩中文字幕不卡| 国产成人免费视频精品含羞草妖精| 成人av网址在线观看| 欧美日韩久久不卡| 久久久亚洲精品石原莉奈| 亚洲欧洲国产专区| 日韩激情在线观看| 成人免费视频caoporn| 色婷婷精品久久二区二区蜜臀av | 国内欧美视频一区二区 | 亚洲一区二区三区四区在线观看| 午夜精品久久久久久久| 国产乱子伦一区二区三区国色天香| 国产精品一区二区久激情瑜伽| 91免费观看在线| 精品久久久久99| 亚洲男人电影天堂| 韩国视频一区二区| 在线观看日韩电影| 久久久久国产精品厨房| 一区二区不卡在线播放| 激情久久五月天| 一本久久a久久精品亚洲| 欧美电视剧免费观看| 亚洲美女屁股眼交3| 国产在线播放一区三区四| 在线免费不卡视频| 日本一区二区综合亚洲| 午夜视频一区在线观看| av中文字幕亚洲| 精品国产乱码久久久久久牛牛 | 成人午夜免费av| 欧美一区日本一区韩国一区| 综合精品久久久| 激情综合色播五月| 欧美日韩中文另类| 成人欧美一区二区三区小说| 国内不卡的二区三区中文字幕 | 色综合久久久久网| 久久久久久亚洲综合| 日本在线不卡视频一二三区| 91毛片在线观看| 国产精品久久看| 国产精品一级片| 欧美成人激情免费网| 午夜精品视频一区| 在线免费精品视频| 亚洲色图欧美偷拍| 国产91精品露脸国语对白| 欧美一区二区成人| 亚洲一二三四在线| 色综合久久综合网97色综合| 国产精品天美传媒| 成人精品一区二区三区中文字幕| 精品国内片67194| 免费不卡在线观看| 日韩欧美色电影| 免费在线看成人av| 欧美一区国产二区| 蜜臀精品一区二区三区在线观看 | 白白色 亚洲乱淫| 国产精品三级视频| 成人免费视频一区| 中文字幕电影一区| 成人一级视频在线观看| 亚洲国产精品精华液2区45| 国产精品一区二区视频| 国产亚洲精品资源在线26u| 国产久卡久卡久卡久卡视频精品| 欧美成人欧美edvon| 国产最新精品免费| 国产亚洲综合在线| 成人精品国产一区二区4080 | 亚洲素人一区二区| 日本精品视频一区二区| 樱花影视一区二区| 欧美亚洲禁片免费| 视频一区欧美精品| 欧美va在线播放| 国产一区不卡视频| 国产校园另类小说区| 国产99久久久久久免费看农村| 中文字幕不卡的av| 91香蕉视频mp4| 亚洲一区二区在线免费观看视频 | 国产精品一区在线观看乱码 | 久久日一线二线三线suv| 国产河南妇女毛片精品久久久| 久久久久久日产精品| 成人黄色网址在线观看| 夜色激情一区二区| 日韩你懂的在线观看| 国产一区二区导航在线播放| 国产精品久久久久三级| 在线观看亚洲精品| 美女看a上一区| 国产精品高清亚洲| 欧美日韩国产首页在线观看| 美女脱光内衣内裤视频久久网站| 久久九九久久九九| 色婷婷综合久久久中文一区二区|