快速开始

可以直接使用vscode插件,这里使用的终端任务的比较简单的方式

原理

可以有许多种方法,这个博客使用的方法如下,可能比较原始

  1. 将需要编译的文件复制到汇编工具所在的文件夹

    • 所以这之前需要清除原来的文件
  2. 调用dosbox,并将汇编工具所在的文件夹挂载到dosbox的一个虚拟磁盘上
  3. 通过-c将汇编链接程序的命令传递给dosbox,实现编译运行

使用task.json 来配置终端运行命令的方法

下文的dosbox路径为${workspaceRoot}\\ASM\\Dosbox\\DOSBOX.exe
tasm汇编工具所在文件夹为/${workspaceRoot}\\ASM\\TASM
这两个路径需要根据实际修改

比较完备的版本

考虑到dosbox不支持长文件名 和中文文件名 我选择调用cmd来进行第一步

{// See https://go.microsoft.com/fwlink/?LinkId=733558// for the documentation about the tasks.json format"version": "2.0.0","tasks": [//以下四个任务是汇编语言的任务,建议使用编辑器的替换功能替换掉一下两个字符串,也可手动//${workspaceRoot}\\ASM\\TASM                   替换为为 汇编工具的安装目录//${workspaceRoot}\\ASM\\Dosbox\\DOSBOX.exe"   替换为为 dosbox程序的地址{"label":"deltest",//清除原来的测试文件"command":"del","type":"shell","args":[{"value": "${workspaceRoot}\\ASM\\TASM\\test.*",//第一处 汇编工具目录 删除汇编工具目录的原来汇编留下的测试程序"quoting": "strong"}]},{"label":"copytotest",//将需要汇编的源代码复制到汇编工具所在文件夹"type":"shell","command":"copy","args": [{"value": "${file}","quoting": "strong"},{"value": "${workspaceRoot}\\ASM\\TASM\\test.asm",//第二处 汇编工具目录 将需要汇编的源代码(vscode当前文件)复制到汇编工具所在目录"quoting": "strong"}],"problemMatcher": [],"dependsOn": ["deltest"]},{"label": "dosboxtasm",//调用dosbox来编译链接运行程序"type": "shell","command":"${workspaceRoot}\\ASM\\Dosbox\\DOSBOX.exe",//第一处 dosbox程序所在地址 这里填dosbox.exe的位置,${workspaceRoot}表示当前工作目录"args": ["-noautoexe","-c","mount c '${workspaceRoot}\\ASM\\TASM'",//第三处 汇编工具目录"-c","c:","-c","tasm/t/zi test","-c","tlink/v/3 test","-c","test",],"problemMatcher": [],"group": {"kind": "build","isDefault": true},"dependsOn": ["copytotest"]},{"label": "tdt",//调用dosbox来编译链接运行程序"type": "shell","command":"${workspaceRoot}\\ASM\\Dosbox\\DOSBOX.exe",//第二处 dosbox.exe的位置 ${workspaceRoot}表示当前工作目录"args": ["-noautoexe","-c","mount c '${workspaceRoot}\\ASM\\TASM'",//第四处 汇编工具目录"-c","c:","-c","tasm/t/zi test","-c","tlink/v/3 test","-c","td test",],"problemMatcher": [],"dependsOn": ["copyasm"]}]
}

简略版本

直接在dosbox中进行第一步

{// See https://go.microsoft.com/fwlink/?LinkId=733558// for the documentation about the tasks.json format"version": "2.0.0","tasks": [{"label": "dosboxtasm","type": "shell","command": "${workspaceRoot}\\tasm\\ASM\\Dosbox\\DOSBOX.exe",//这里写上dosbox软件的位置"args": ["-c","mount c \\\"${fileDirname}\\\"",//将需要汇编的文件所在目录挂载到dosbox的c盘"-c","mount d \\\"${workspaceRoot}\\tasm\\ASM\\TASM\\\"",//将汇编工具挂载到d盘"-c","copy c:${fileBasenameNoExtension}.ASM d:test.asm",//将需要汇编的代码文件复制到d盘方便处理"-c","d:",//将当前dosbox的工作目录指定到汇编工具和代码所在的目录"-c","tasm/t/zi test",//汇编程序"-c","tlink/v/3 test",//链接程序"-c","test"//运行程序],"problemMatcher": [],"group": {"kind": "build","isDefault": true}//这个大括号所在的四行代码为将这个任务制定为默认,可以不写}]
}

如果安装了code runner还可以通过添加自定义命令来实现

参考代码如下
注意路径中的\需要由\\替换,用于将带有空格的路径括起来的" "对,也要用\" \"替换
E:\\TASM为汇编工具所在目录
E:Dosbox\\DOSBox.exe为dosbox所在目录

"asm":"del E:\\TASM\\t.* && copy \"$fileName\" \"E:TASM\\t.asm\" && E:Dosbox\\DOSBox.exe -noautoexec -c \"mount c E:\\TASM\" -c \"c:\" -c \"tasm/t/zi t.asm\" -c \"tlink/v/3 t.obj\" -c \"t.exe\" "]

具体步骤

  1. 在终端中选择配置任务就会在.vscode文件夹中自动添加tasks.json文件,将上文中的代码,复制粘贴进去保存(需要根据dosbox和汇编工具的位置做修改)
  2. 在编辑好汇编代码之后,点击终端-运行任务就会自动打开dosbox软件运行程序
  3. 如果需要调试,那么在dosbox运行结束之后输入命令td test
  4. 退出dosbox:点击X号,或者输入exit

也可以点击运行生成任务,选择了这个任务之后,以后可以直接点击或者通过快捷键运行任务

运行效果

参考资料

  • vscode关于task.json的帮助文档
  • vscode中关于task.json中需要的软件自带环境变量的文档
  • 在notepad++中的配置方法

在vscode中调用dosbox来运行tasm汇编程序(tasks.json code runner)相关推荐

  1. rea t插件 vscode_VSCode构建汇编语言环境(配置VSCode自动调用dosbox编译运行MASM/TASM程序)...

    首先,最简单的方法当然是直接安装vscode插件比如下面这个:根据里面的说明使用即可 MASM/TASM - Visual Studio Marketplace​marketplace.visuals ...

  2. 自动化调用dosbox编译运行MASM/TASM代码

    利用终端自动化编译运行MASM/TASM代码 如果需要配置方法,请参考 notepad++配置自动化编译运行TASM的方法 notepad++配置自动化编译运行MASM的方法 VSCode使用终端任务 ...

  3. vscode 运行html服务器运行_如何在vscode中调用浏览器运行html?

    展开全部 打开vscode编辑器,点击编辑器主界面左上侧第五个小图标--e69da5e6ba903231313335323631343130323136353331333365633864'扩展'按钮 ...

  4. 程序中调用CMD,运行命令或启动子程序

    首先,需要注意的是,CMD 是以空格来区分参数的,如果路径或参数中带有空格,可以将路径或参数 用双引号括起来处理 一.打开本地视频文件示例 本示例是QT示例,QT 提供了QProcess,可以用来执行 ...

  5. java怎么中断流_JAVA代码运行中断

    publicclassImageReduce{/*对图像进行缩放处理*/publicvoidscale(StringsrcImageFile,Stringresult,doublescale,bool ...

  6. VSCODE中配置JavaScript编译环境

    文章目录 01. 起因 02. 下载安装VSCODE 03. 方式一:使用Node.js做为解释器运行JS代码 Node.js的安装和配置 在VSCODE中配置Node.js 04. 方式二:使用VS ...

  7. Vue学习笔记7 - 在Vscode中配置Vetur,ESlint,Prettier

    俗话说得好,工欲善其事必先利其器,想要熟练开发Vue项目,一个好的开发环境就是必不可少了,这里我就选用了vscode作为开发工具,毕竟vscode免费,还跨平台,应用范围也广,著名的vue开源项目:后 ...

  8. golang 同一个包中函数互相调用报错 undefined 以及在 VSCode 中配置右键执行整个包文件

    1. 代码结构 demo 文件夹下有两个文件,分别为 hello.go 和 main.go ,结构如下: wohu@wohu:~/GoCode/src$ tree demo/ demo/ ├── he ...

  9. vscode 中C++运行编译运行多文件问题总结

    来源链接:https://blog.csdn.net/weixin_38260878/article/details/101049070?depth_1-utm_source=distribute.p ...

最新文章

  1. Ubuntu 14.04下java开发环境的搭建--2--Eclipse的安装
  2. Yolov5 face训练手册
  3. 学python最好的方式-最好的Python入门教程是?
  4. 如何更好的排版介绍性文字
  5. 使用org.apache.commons.io.FileUtils,IOUtils工具类操作文件
  6. C++,string类的指针,string类数组的指针 string *s
  7. CSS cursor 和 opacity 属性
  8. scrapy.spider
  9. [ZJOI2012]灾难(建图)
  10. 微信支付V3-企业转账至零钱1/2
  11. 发生事故单位照常发工资可不可以索要误工费
  12. layui当前表格第一行_layui数据表格新增一行
  13. 在MAC环境下玩转树莓派
  14. Gradient Descent and NSCA
  15. 五、数据CRUD操作
  16. 广州移动华为认证培训之行
  17. TL-WR941N V2 漏洞
  18. 【Linux】生产者消费者模型
  19. [BZOJ 1193] 马步距离
  20. Python练习14:天天向上的力量I

热门文章

  1. autoJS pro-手机自动化脚本基础小功能篇(截图、版本号、打印日志)
  2. 几种常见的数据标准化的方法总结
  3. iOS使用TestFlight测试流程
  4. 小白月赛 72(3/6)
  5. xv6---Lab4 traps
  6. Docker Commit Push Weblogic JDBC应用程序
  7. 如何快速启动android app
  8. 使用npm安装包本地快速启动前端项目方法
  9. python延时函数的使用
  10. Java Springboot 微信第三方支付 证书认证绑定 Docker导入CER证书