IC验证——perl脚本file_assistant——批量修改文件

news2024/11/15 15:43:10

1 脚本名称

file_assistant

2 脚本路径

scripts/bin/file_assistant

3 脚本参数说明

次序

参数名

说明

1

file_type

(v;sv;c;all)

指定脚本要修改的文件类型,目前支持 .v;.sv;.c(后续可以增加其他);

2

word_dir

指定脚本执行路径(可以为脚本所在路径的任意相对路径)。

3

substitude_list

指定脚本查找替换参考的文件列表,默认为file_assistant_list,遵循perl正则表达式规则

示例

命令:file_assistant  all  ./rfdig/rfdig_m33_tc017  file_assistant_list

对当前路径下的rfdig/rfdig_m33_tc017文件夹及其子文件夹下所有的.c/.v/.sv文件进行修改,修改列表为file_assistant_list,遵循perl正则表达式标准;

命令:file_assistant  v  ./rfdig  file_assistant_list

对当前路径下的rfdig文件夹及其子文件夹下的所有.v文件进行修改,修改列表为file_assistant_list,遵循perl正则表达式标准;

命令:file_assistant  c  ../ccom  user_define_list

对上层目录的ccom目录下的所有.c文件进行修改,修改列表为user_define_list,遵循perl正则表达式标准;

说明

目前该脚本可完成对文件的批量正则匹配替换、删除操作,如有其他需求,可以在此基础上继续开发。

3 脚本操作说明

该脚本用于批量替换文件中的指定内容,该脚本执行替换操作时,需要指定替换的文件类型、替换的文件路径、替换的参考列表(参考列表遵循perl正则表达式规则):

在本例中,该脚本用于解决如下问题:在ST仿真中,用于.v和.c交互的iopad信号,将其批量修改为BUCK_BANKUP信号,如下:

具体解决方式为:将rfdig_m33_tc017目录下的.v代码中的iopad_p10/01/02==’d1修改为BUCK_BACKUP==‘d10/1/2,将该目录下的.c代码中的IOMUX_REGS[gpio_ret_pd_aon_p10/01/02_config]修改为PMU_REGS[ana_buck_act_cfg1] = (10/1/2 & ana_buck_act_cfg1_buck_backup_mask) << ana_buck_act_cfg1_buck_backup_shift;

  1. 使用脚本前,首先完善file_assistant_list,以perl正则表达式为匹配替换规则,将匹配内容置于 ”>>>>” 符号左边,将替换内容置于 “>>>>” 符号右边
  2. 根据脚本存放路径,指定脚本工作目录的相对路径,如下例所示,脚本存放于case目录,对rfdig/rfdig_m33_tc017文件夹下的.c/.v/.sv文件执行批量查找替换操作,参考file_assistant_list;执行:file_assistant  all  ./rfdig/rfdig_m33_tc017  file_assistant_list
  3. 如下所示,替换成功,仿真也可以正常pass

4 脚本代码

#! /usr/bin/perl -w
 
#==========================================================
# PERL MODULE 
#==========================================================
 
use Cwd;
use File::Path;
use File::Find;

#==========================================================
# PERL FUNCTION GetOptions (get command parameters)
#==========================================================

$g_fl_type   = $ARGV[0];
$g_work_dir  = $ARGV[1];
$g_sub_fl    = $ARGV[2];

if ($g_sub_fl =~ m/^\s*$/) {
    $g_sub_fl = "file_assistant_list";
    print "g_sub_fl =$g_sub_fl\n";
}

our $g_help    = 0;

#==========================================================
# SCRIPT MAIN  
#==========================================================

our @old;
our @new;
our @ref_num;
our @ref_context;
our @AoA = (\@old,\@new,\@ref_num);

Main();

sub SubContent{
    if (open(SUBSTITUTE_ID,"file_assistant_list") or die "cannot open file_assistant_list, no such file") {
        @substitudecontent = <SUBSTITUTE_ID>;
        my $i   = 0;
    
        foreach $substitude (@substitudecontent) {
            $substitude =~ s/[\n\r]*//g;
            if ($substitude =~ m/\s*>>>>\s*/) {
                print "before match string: $`\n";
                print "match string       : $&\n";
                print "after  match string: $'\n";
                $old[$i] = "$`";
                $new[$i] = "$'";
                #my $ref_pattern_all = ($new[$i] =~ s/(\$\d+)/$1/g);
                #my $ref_pattern_nc  = ($new[$i] =~ s/(\\\$\d+)/$1/g);
                my $ref_pattern_all = ($old[$i] =~ s/(\()/$1/g);
                my $ref_pattern_nc  = ($old[$i] =~ s/(\\\()/$1/g);
                my $ref_pattern_num = $ref_pattern_all - $ref_pattern_nc;
                $ref_num[$i]        = $ref_pattern_num;
                print "ref_pattern_all    : $ref_pattern_all\n";
                print "ref_pattern_nc     : $ref_pattern_nc\n";
                print "ref_pattern_num    : $ref_num[$i]\n";

                for( $j = 0; $j < @AoA; $j=$j+1 ){
                    print "AoA[$j][$i]: $AoA[$j][$i] \n";
                }
                $i = $i+1;
            }
        }
    }
}

sub CopyFile{
    $fl_name = scalar(@_);
    print "source file name is $_[0]\n";
    print "orien  file name is $_[1]\n";
    open(ORIEN_FILE,">$_[1]");
        if (open(SOURCE_FILE,"$_[0]")) {
            @context = <SOURCE_FILE>;
            foreach $line (@context) {
                print ORIEN_FILE "$line";
            }
            close SOURCE_FILE;
        }
    close ORIEN_FILE
}

sub SubFile{
    $fl_name = scalar(@_);
    print "source file name is $_[0]\n";
    print "orien  file name is $_[1]\n";
    $sub_ready = 0;
    open(ORIEN_FILE,">$_[1]");
    if (open(SOURCE_FILE,"$_[0]")) {
        @context = <SOURCE_FILE>;
        foreach $line (@context) {
            for($m = 0; $m < @old; $m=$m+1 ){
                if ($line =~ m/$AoA[0][$m]/) {
                    $pre_match   = $`;
                    $post_match  = $';
                    $sub_pattern = $AoA[1][$m];
                    print "sub_pattern is $sub_pattern \n";
                    if ($ref_num[$m] > 0) {
                        for($k = 0; $k < $ref_num[$m]; $k = $k+1 ){
                            $j = $k+1;
                            $ref_context[$k] = $$j;
                            print "ref pattern is $$j \n";
                            print "ref_context[$k] is $ref_context[$k]\n";
                        }
                        $sub_pattern =~ s/\\\$(\d+)/\[\,\,\,\[\.\.\.\[\!\!\!\[$1/g;
                        print "111111sub_pattern is $sub_pattern \n";
                        $sub_pattern =~ s/\$(\d+)/$ref_context[$1-1]/g;
                        print "222222sub_pattern is $sub_pattern \n";
                        $sub_pattern =~ s/\[\,\,\,\[\.\.\.\[\!\!\!\[(\d+)/\$$1/g;
                        print "333333sub_pattern is $sub_pattern \n";
                    }
                    print ORIEN_FILE "$pre_match"."$sub_pattern"."$post_match";
                    $sub_ready = 1;
                }
            }
            if($sub_ready eq 0) {
                print ORIEN_FILE "$line";
            }
            $sub_ready  = 0;
        }
        close SOURCE_FILE;
    }
    close ORIEN_FILE
}

sub FindWanted{
    if(-f $File::Find::name) {
        if (($g_fl_type eq "v" ) or ($g_fl_type eq "all") and ($File::Find::name =~ /\.v$/)) {
            print "copy .v  file begin ...... \n";
            CopyFile("$_","$_"."\.old");
            print "sub  .v  file begin ...... \n";
            SubFile("$_"."\.old","$_");
            print "del  .v  file begin ...... \n";
        }
        if (($g_fl_type eq "sv") or ($g_fl_type eq "all") and ($File::Find::name =~ /\.sv$/)) {
            print "copy .sv file begin ...... \n";
            CopyFile("$_","$_"."\.old");
            print "sub  .sv file begin ...... \n";
            SubFile("$_"."\.old","$_");
            print "del  .sv file begin ...... \n";
        }
        if (($g_fl_type eq "c" ) or ($g_fl_type eq "all") and ($File::Find::name =~ /\.c$/)) {
            print "copy .c  file begin ...... \n";
            CopyFile("$_","$_"."\.old");
            print "sub  .c  file begin ...... \n";
            SubFile("$_"."\.old","$_");
            print "del  .c  file begin ...... \n";
        }
    }
}

sub Main{
    SubContent();

    my $cur_dir = getcwd;
    chdir($cur_dir) or die "$cur_dir does not exist!!!";
    print "cur_dir is $cur_dir\n";
    find(\&FindWanted,"$cur_dir/$g_work_dir");
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1380791.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MISGAN

MISGAN:通过生成对抗网络从不完整数据中学习 代码、论文、会议发表: ICLR 2019 摘要: 生成对抗网络(GAN)已被证明提供了一种对复杂分布进行建模的有效方法,并在各种具有挑战性的任务上取得了令人印象深刻的结果。然而,典型的 GAN 需要在训练期间充分观察数据。在本文中…

mac上部署单体hbase

1. 简介 HBase 是一个开源的、分布式的、版本化的典型非关系型数据库。它是 Google BigTable 的开源实现&#xff0c;并且是 Apache 基金会的 Hadoop 项目的一部分1。HBase 在 Hadoop Distributed File System (HDFS) 上运行&#xff0c;作为一个列式存储非关系数据库管理系统…

[zabbix] 分布式应用之监控平台zabbix的认识与搭建

一、监控系统的相关知识 1.1 监控系统运用的原因 当我们需要实时关注与其相关的各项指标是否正常&#xff0c;往往存在着很多的服务器、网络设备等硬件资源&#xff0c;如果我们想要能够更加方便的、集中的监控他们&#xff0c;zabix可以实现集中监控管理的应用程序 监控的初…

每日算法打卡:蚂蚁感冒 day 13

文章目录 原题链接题目描述输入格式输出格式数据范围输入样例1&#xff1a;输出样例1&#xff1a;输入样例2&#xff1a;输出样例2&#xff1a; 题目分析示例代码 原题链接 1211. 蚂蚁感冒 题目难度&#xff1a;简单 题目来源&#xff1a;第五届蓝桥杯省赛C A/B组 题目描述…

python中的Quene使用方法,包含多线程和多进程

在Python中&#xff0c;队列&#xff08;Queue&#xff09;是一种抽象的数据类型&#xff0c;它遵循先进先出&#xff08;FIFO&#xff09;的原则。队列是一种特殊的线性表&#xff0c;只允许在表的前端&#xff08;front&#xff09;进行删除操作&#xff0c;而在表的后端&…

Web前端 ---- 【Vue3】ref和reactive实现响应式的区别和联系

目录 前言 setup ref 基本数据类型 对象形式 reactive ref和reactive的区别与联系 前言 本文介绍函数ref和函数reactive实现响应式 setup 在介绍ref和reactive之前&#xff0c;先介绍setup,vue3新引入的配置项。在该配置项中&#xff0c;在vue2中的data、methods、comput…

DNS 正/反向解析 主从复制 分离解析

一 DNS概念它作为将域名和IP地址相互映射的一个分布式数据库&#xff0c;能够使人更方便地访问互联网 每一台 DNS 服务器都只负责管理一个有限范围 根域: 全球根服务器节点只有13个,10个在美国&#xff0c;1个荷兰&#xff0c;1个瑞典&#xff0c;1个日本 一级域名&#xff…

stm32学习笔记:DMA

每个DMA通道硬件触发源是不一样的&#xff0c;要使用某个外设的硬件触发源&#xff0c;就必须使用它连接的那个通道 12个独立可配置的通道&#xff1a;DMA1(7个通道)&#xff0c;DMA2(5个通道) 每个通道都支持软件触发和特定的硬件触发 C8T6 DMA资源&#xff1a;DMA1 &#xff…

MSF流量加密

1、背景介绍 在MSF中生成shell&#xff0c;并上线运行时。都是通过http https tcp等协议传输。虽然MSF本身会对流量进行加密&#xff0c;但MSF太出名以致于其加密特征容易被IPS&#xff0c;WAF等可以检测带有攻击的特征的设备拦截或记录。 2、生成 SSL 证书 openssl req -x50…

vue前端开发自学,借助KeepAlive标签保持组件的存活

vue前端开发自学,借助KeepAlive标签保持组件的存活&#xff01;如果不想让组件在切换的时候&#xff0c;被默认操作&#xff08;卸载掉了&#xff09;。他们需要使用这个这个表情哦。 下面给大家看看代码情况。 <template><h3>ComA</h3><p>{{ messag…

Arduino开发实例-AS608光学指纹传感器驱动

AS608光学指纹传感器驱动 文章目录 AS608光学指纹传感器驱动1、AS608光学指纹传感器介绍2、硬件准备及接线3、代码实现3.1 指纹录入3.2 指纹匹配验证1、AS608光学指纹传感器介绍 AS608 光学指纹传感器可用于扫描指纹,它也可以通过串行通信将处理后的数据发送到微控制器。 所有…

浏览器深色模式

1、Edge强制深色模式 1、先在edge里设定成深色模式 设置浏览器中的深色设置 但这种方式设置后很多网站仍是白色的背景 2、实验室设置强制深色 网址栏 输入 edge://flags搜索 dark 选择 enabled 重启 2、Chrome强制深色模式 浏览器输入 Chrome深色设置 chrome://flags/#…

基于WebSocket双向通信技术实现-下单提醒和催单(后端)

学习复盘和总结项目亮点。 扩展&#xff1a;该功能能应用在&#xff0c;各种服务类项目中。&#xff08;例如&#xff1a;酒店、洗脚城等系ERP系中提醒类服务&#xff09; 4. 来单提醒 4.1 需求分析和设计 用户下单并且支付成功后&#xff0c;需要第一时间通知外卖商家。通…

Deit:知识蒸馏与vit的结合 学习笔记(附代码)

论文地址&#xff1a;https://arxiv.org/abs/2012.12877 代码地址&#xff1a;GitHub - facebookresearch/deit: Official DeiT repository 1.是什么&#xff1f; DeiT&#xff08;Data-efficient Image Transformer&#xff09;是一种用于图像分类任务的神经网络模型&#…

软件测试|教你使用Python绘制正多边形

简介 绘制正多边形是Python图形编程的基本任务之一。在本文中&#xff0c;我将为你提供一个使用Python绘制正多边形的详细教程&#xff0c;并提供一个示例代码。我们将使用Python的Turtle库来进行绘制。 步骤1&#xff1a;导入Turtle库 我们需要先安装好Python环境&#xff…

PyTorch Tutorial

本文作为博客“Transformer - Attention is all you need 论文阅读”的补充内容&#xff0c;阅读的内容来自于 https://pytorch.org/tutorials/intermediate/char_rnn_classification_tutorial.html#recommended-preparation 建议的准备流程。 Deep Learning with PyTorch: …

Linux第21步_取消鼠标中键的复制粘贴功能

在ubuntu18.04操作系统中&#xff0c;选中文本后&#xff0c;若按下鼠标中键&#xff0c;就可以执行复制粘贴&#xff0c;相当于 CtrlshiftC 后又按了 CtrlshiftV。在Linux系统中&#xff0c;基本上都是这么配置的。在windows系统中&#xff0c;我们习惯用Ctrl-C复制&#xff0…

POSTGRESQL中ETL、fdw的平行替换

POSTGRESQL中ETL、fdw的平行替换 01、简介 “ 在我前两次的文章中&#xff0c;说到postgresql对于python的支持&#xff0c;其实很多功能也就可以封装进入的postgresql数据库中去。比如fdw、etl等&#xff0c;本文将以此为叙述点&#xff0c;进行演示展示” 在postgresql数据…

好用的便签有哪些?windows便签工具在哪打开?

每当我8点准时上班&#xff0c;在等待电脑开机的过程&#xff0c;我都会习惯性地思考整理今天要晚上的任务&#xff0c;列出所要完成的待办事项。随着每一项任务的清晰呈现&#xff0c;我的心情也逐渐明朗起来。当然了&#xff0c;这个时候&#xff0c;我迫切需要一款好用的便签…

大数据赋能电竞出海企业发展

近几年电竞行业发展迅速&#xff0c;我国单2022年新增近4万家电竞相关企业&#xff0c;竞争十分激烈。中国电竞市场规模在全球占比19%左右&#xff0c;海外有巨大的增量市场&#xff0c;特别是东南亚、中南亚和拉丁美洲是电竞市场增长最快的地区&#xff0c;在2020至2025年期间…