【VsCode】通过tasks.json中的problemMatcher属性的fileLocation子属性设定问题的输出内容
admin
2024-03-27 07:42:50
0

前言

这个问题是起因在我想把代码指向的相对路径更改为使用宏的绝对路径便于编译调试,但是在一次调试过程中有一个编译时报错,点击报错内容项时,却显示找不到路径文件。报错详细内容显示是 即:代码路径+绝对路径。

"resource": "/c:/Users/97852/Desktop/ZryCode/CODE/C++/C:/Users/97852/Desktop/ZryCode/CODE/C++/Processing/IQProcess.cpp",

那么这里的错误就已经很明显了,“现在VS 认为错误的查找路径应当是相对路径,并且拼接格式是 代码路径再拼接编译时路径。”。

接下来就是解决问题需要了解的内容。我从VS的官方帮助手册和开放源码中找到了解决方法,现在整理记录下来。

tasks.json 是什么?

tasks.json是VsCode提供的一种快捷配置文件,用来集中管理 VsCode 的编译调试功能。
VS Code软件会通过 工作区 或者 打开文件夹的当前目录下(这取决于你是否为当前代码项目创建了工作区) 的.vscode 下的 tasks.json配置来为每一次调试,执行对应的相关设置内容。

问题界面是什么?

问题界面如果没有专门设置的话,就是在下方显示的编译调试辅助工具栏显示告警和错误的相关信息。
通过双击对应的问题条目,可以自动跳转到问题所在的代码文件的对应行数。

怎么设定自己的问题界面显示内容?

tasks.json中可以设置一个属性名为 problemMatcher ,这个是用来规定问题界面的全部内容的。
而它的子属性有一个名为:fileLocation的就是指的问题界面文件目录的查找方式。也就是此次问题的所在。
这里我们要将代码文件查找方式设定为自适应,并添加非绝对路径时的查找路径。

即将 属性 fileLocation 的 Value值 设定为 autodetect(自适应) "${workspaceRoot}"(这里指定非绝对路径时的查找路径 为工作区根目录)

"problemMatcher": {"owner": "cpp","fileLocation": ["autodetect","${workspaceRoot}"],"pattern": {"regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$","file": 1,"line": 2,"column": 3,"severity": 4,"message": 5}
},

补充

vscode 对于 json 文件的解析方式的开源代码部分.

  • 摘录 文件目录设定部分的说明:
  /*** Defines how filename reported in a problem pattern* should be read. Valid values are:*  - "absolute": the filename is always treated absolute.*  - "relative": the filename is always treated relative to*    the current working directory. This is the default.*  - ["relative", "path value"]: the filename is always*    treated relative to the given path value.*  - "autodetect": the filename is treated relative to*    the current workspace directory, and if the file*    does not exist, it is treated as absolute.*  - ["autodetect", "path value"]: the filename is treated*    relative to the given path value, and if it does not*    exist, it is treated as absolute.*/fileLocation?: string | string[];

全文附注:

The following interfaces define the basic schema of the file.tasks.json
Note: Some task options are contributed by VS Code extensions. You can use IntelliSense to find a complete list, using the Trigger Suggestions command (Ctrl+Space).tasks.json

interface TaskConfiguration extends BaseTaskConfiguration {/*** The configuration's version number*/version: '2.0.0';/*** Windows specific task configuration*/windows?: BaseTaskConfiguration;/*** macOS specific task configuration*/osx?: BaseTaskConfiguration;/*** Linux specific task configuration*/linux?: BaseTaskConfiguration;
}interface BaseTaskConfiguration {/*** The type of a custom task. Tasks of type "shell" are executed* inside a shell (e.g. bash, cmd, powershell, ...)*/type: 'shell' | 'process';/*** The command to be executed. Can be an external program or a shell* command.*/command: string;/*** Specifies whether a global command is a background task.*/isBackground?: boolean;/*** The command options used when the command is executed. Can be omitted.*/options?: CommandOptions;/*** The arguments passed to the command. Can be omitted.*/args?: string[];/*** The presentation options.*/presentation?: PresentationOptions;/*** The problem matcher to be used if a global command is executed (e.g. no tasks* are defined). A tasks.json file can either contain a global problemMatcher* property or a tasks property but not both.*/problemMatcher?: string | ProblemMatcher | (string | ProblemMatcher)[];/*** The configuration of the available tasks. A tasks.json file can either* contain a global problemMatcher property or a tasks property but not both.*/tasks?: TaskDescription[];
}/*** Options to be passed to the external program or shell*/
export interface CommandOptions {/*** The current working directory of the executed program or shell.* If omitted the current workspace's root is used.*/cwd?: string;/*** The environment of the executed program or shell. If omitted* the parent process' environment is used.*/env?: { [key: string]: string };/*** Configuration of the shell when task type is `shell`*/shell: {/*** The shell to use.*/executable: string;/*** The arguments to be passed to the shell executable to run in command mode* (e.g ['-c'] for bash or ['/S', '/C'] for cmd.exe).*/args?: string[];};
}/*** The description of a task.*/
interface TaskDescription {/*** The task's name*/label: string;/*** The type of a custom task. Tasks of type "shell" are executed* inside a shell (e.g. bash, cmd, powershell, ...)*/type: 'shell' | 'process';/*** The command to execute. If the type is "shell" it should be the full* command line including any additional arguments passed to the command.*/command: string;/*** Whether the executed command is kept alive and runs in the background.*/isBackground?: boolean;/*** Additional arguments passed to the command. Should be used if type* is "process".*/args?: string[];/*** Defines the group to which this task belongs. Also supports to mark* a task as the default task in a group.*/group?: 'build' | 'test' | { kind: 'build' | 'test'; isDefault: boolean };/*** The presentation options.*/presentation?: PresentationOptions;/*** The problem matcher(s) to use to capture problems in the tasks* output.*/problemMatcher?: string | ProblemMatcher | (string | ProblemMatcher)[];/*** Defines when and how a task is run.*/runOptions?: RunOptions;
}interface PresentationOptions {/*** Controls whether the task output is reveal in the user interface.* Defaults to `always`.*/reveal?: 'never' | 'silent' | 'always';/*** Controls whether the command associated with the task is echoed* in the user interface. Defaults to `true`.*/echo?: boolean;/*** Controls whether the panel showing the task output is taking focus.* Defaults to `false`.*/focus?: boolean;/*** Controls if the task panel is used for this task only (dedicated),* shared between tasks (shared) or if a new panel is created on* every task execution (new). Defaults to `shared`.*/panel?: 'shared' | 'dedicated' | 'new';/*** Controls whether to show the `Terminal will be reused by tasks,* press any key to close it` message.*/showReuseMessage?: boolean;/*** Controls whether the terminal is cleared before this task is run.* Defaults to `false`.*/clear?: boolean;/*** Controls whether the task is executed in a specific terminal* group using split panes. Tasks in the same group (specified by a string value)* will use split terminals to present instead of a new terminal panel.*/group?: string;
}/*** A description of a problem matcher that detects problems* in build output.*/
interface ProblemMatcher {/*** The name of a base problem matcher to use. If specified the* base problem matcher will be used as a template and properties* specified here will replace properties of the base problem* matcher*/base?: string;/*** The owner of the produced VS Code problem. This is typically* the identifier of a VS Code language service if the problems are* to be merged with the one produced by the language service* or 'external'. Defaults to 'external' if omitted.*/owner?: string;/*** The severity of the VS Code problem produced by this problem matcher.** Valid values are:*   "error": to produce errors.*   "warning": to produce warnings.*   "info": to produce infos.** The value is used if a pattern doesn't specify a severity match group.* Defaults to "error" if omitted.*/severity?: string;/*** Defines how filename reported in a problem pattern* should be read. Valid values are:*  - "absolute": the filename is always treated absolute.*  - "relative": the filename is always treated relative to*    the current working directory. This is the default.*  - ["relative", "path value"]: the filename is always*    treated relative to the given path value.*  - "autodetect": the filename is treated relative to*    the current workspace directory, and if the file*    does not exist, it is treated as absolute.*  - ["autodetect", "path value"]: the filename is treated*    relative to the given path value, and if it does not*    exist, it is treated as absolute.*/fileLocation?: string | string[];/*** The name of a predefined problem pattern, the inline definition* of a problem pattern or an array of problem patterns to match* problems spread over multiple lines.*/pattern?: string | ProblemPattern | ProblemPattern[];/*** Additional information used to detect when a background task (like a watching task in Gulp)* is active.*/background?: BackgroundMatcher;
}/*** A description to track the start and end of a background task.*/
interface BackgroundMatcher {/*** If set to true the watcher is in active mode when the task* starts. This is equals of issuing a line that matches the* beginPattern.*/activeOnStart?: boolean;/*** If matched in the output the start of a background task is signaled.*/beginsPattern?: string;/*** If matched in the output the end of a background task is signaled.*/endsPattern?: string;
}interface ProblemPattern {/*** The regular expression to find a problem in the console output of an* executed task.*/regexp: string;/*** Whether the pattern matches a problem for the whole file or for a location* inside a file.** Defaults to "location".*/kind?: 'file' | 'location';/*** The match group index of the filename.*/file: number;/*** The match group index of the problem's location. Valid location* patterns are: (line), (line,column) and (startLine,startColumn,endLine,endColumn).* If omitted the line and column properties are used.*/location?: number;/*** The match group index of the problem's line in the source file.* Can only be omitted if location is specified.*/line?: number;/*** The match group index of the problem's column in the source file.*/column?: number;/*** The match group index of the problem's end line in the source file.** Defaults to undefined. No end line is captured.*/endLine?: number;/*** The match group index of the problem's end column in the source file.** Defaults to undefined. No end column is captured.*/endColumn?: number;/*** The match group index of the problem's severity.** Defaults to undefined. In this case the problem matcher's severity* is used.*/severity?: number;/*** The match group index of the problem's code.** Defaults to undefined. No code is captured.*/code?: number;/*** The match group index of the message. Defaults to 0.*/message: number;/*** Specifies if the last pattern in a multi line problem matcher should* loop as long as it does match a line consequently. Only valid on the* last problem pattern in a multi line problem matcher.*/loop?: boolean;
}/*** A description to when and how run a task.*/
interface RunOptions {/*** Controls how variables are evaluated when a task is executed through* the Rerun Last Task command.* The default is `true`, meaning that variables will be re-evaluated when* a task is rerun. When set to `false`, the resolved variable values from* the previous run of the task will be used.*/reevaluateOnRerun?: boolean;/*** Specifies when a task is run.** Valid values are:*   "default": The task will only be run when executed through the Run Task command.*   "folderOpen": The task will be run when the containing folder is opened.*/runOn?: string;
}

扩展阅读:

Visual Studio Code Tasks 附录
Visual Studio 代码变量参考

相关内容

热门资讯

小棉袄电商洞察:短保零食爆火背... 当整个零食赛道还在价格战的泥潭里贴身肉搏时,长沙街头的一抹红蓝撞色,正用“新鲜”二字,悄然改写着游戏...
金价高位“吞没”!美元强势+获... 汇通财经APP讯——周三(2月26日)亚市早盘,现货黄金窄幅震荡,目前交投于5150美元/盎司附近。...
大疆反击美国禁令! 据路透社报道,中国无人机制造商大疆(DJI)周二表示,已提起诉讼,对美国联邦通信委员会(FCC)禁止...
AI算力需求刺激存储芯片股 兆... 来源:财联社 财联社2月24日讯(编辑 胡家荣)受益于海外市场消息利好,港股存储概念股走强。截至发稿...
2026年中国十大杰出品牌战略... 2026年,中国经济 将 在新质生产力驱动下稳健前行, 中国 企业竞争从产品、渠道层面升级为品牌心智...
原创 特... 一直以来,中美关系始终处于紧张状态,外部局势难以化解,特朗普却在国内遭遇了前所未有的压力。2月20日...
“红利+”指数集体涨超1%,关... 截至午间收盘,中证红利指数、国证价值100指数、国证自由现金流指数均上涨1.6%。Wind数据显示,...
ETF盘中资讯|低吸时刻?科创... 或被海外AI情绪错杀,重点布局国产AI产业链的科创人工智能ETF(589520)连跌两日,场内价格现...
哈登20分米切尔23分 骑士大... 【搜狐体育战报】北京时间2月25日NBA常规赛,主场作战的骑士以109-94击败尼克斯。阿伦19分1...
科创京津冀|十二年“聚链成群”... 2026年,京津冀协同发展迎来12周年。十二年时间,足够一个产业完成从“点”到“链”的蜕变。 早在2...
金价高位震荡!实探深圳水贝市场... 2月24日,农历正月初八,深圳水贝贵金属市场在春节“不打烊”的喧嚣后,迎来了马年首个正式工作日。尽管...
日照国资内部大调整:城投集团1... 经济导报记者 杨佳琪 2月24日,日照城投集团有限公司(下称“日照城投集团”)发布关于控股股东发生变...
南京商业大佬正式入主南通这家上... 2月24日晚间,南通上市公司*ST金灵披露公司控股股东和实际控制人变更的提示性公告。 根据《重整计划...
高特电子股权合规疑云:董事牵线... 来源丨时代商业研究院 作者丨陆烁宜 编辑丨郑琳 高校教师隐秘入股、其兄牵线融资获顾问费且获得员工持股...
大市“开门红”,白酒逆市调整,... 春节假期后首个交易日,白酒走出了“逆市”行情。 2月24日,A股大盘高开并收盘企稳4100点以上,但...
别让声誉危机,成为你融资路上的... 资本市场从来没有“温情脉脉”,只有“优胜劣汰”的残酷法则。一句广为流传的警示,道尽了企业发展的隐秘风...
钨价上涨颠覆传统逻辑,APT破... 2月25日,据中钨在线最新消息,一年来,钨价的高强度和快节奏走势,已基本颠覆了原有市场传统的交易逻辑...
波兰经济学教授:美国关税政策混... 美国最高法院20日裁定美国《国际紧急经济权力法》未授权总统大规模征收关税,美国总统特朗普当天宣布将对...
暴跌54%!非洲“一哥”跌落神... 作者:曾有为 那个曾经在非洲所向披靡、被誉为“手机中的战斗机”的传奇公司,在2026年初,交出了一份...
5个月内两次更替,涪陵榨菜迎“... 瑞财经 刘治颖 2月13日,涪陵榨菜(SZ002507)公告,提名夏强伟担任公司总经理,公司董事长、...