in reply to Regular Expressions with varialbe with "[]"
use 5.010; use warnings; use strict; my $port_name = quotemeta 'sdm_yout_i[1]'; while (<DATA>) { if (/\.([0-9a-z_]*?) \(.*?${port_name} .*?,/ ) { print '$port_name = '; say $port_name; print 'cell name = '; say $1; } } __DATA__ .dout_sar ( dout_sar ) , .dcoc_status ( dcoc_status ) , .sdm_yout +_i ( {sdm_yout_i[1] , n145 } ) , .sdm_yout_q ( sdm_yout_q ) ,
Outputs:
$port_name = sdm_yout_i\[1\] cell name = dout_sar
If you plan on parsing Verilog code, consider Verilog-Perl
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: Regular Expressions with varialbe with "[]" (Verilog)
by herman4016 (Acolyte) on Mar 12, 2015 at 02:27 UTC |