欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何配置?Sublime?Text4為?C++?編輯器

 更新時(shí)間:2023年06月14日 10:30:04   作者:zwyyy456  
這篇文章主要介紹了配置Sublime Text4為C++編輯器,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

概述

涉及以下插件的安裝和配置Package Control Terminus LSP LSP-clangd clang-format LSP-pyright LSP-json

配置sublime

安裝Package Control以進(jìn)行包管理。

Terminus

安裝Terminus以實(shí)現(xiàn)sublime text4內(nèi)的terminal。

綁定快捷鍵:

[
	{
		"keys": [
			"ctrl+shift+t"
		],
		"command": "terminus_open",
		"args": {
            // 打開(kāi)時(shí)要執(zhí)行的命令
            // "cmd": "fish",
			"cwd": "${file_path:${folder}}"
		}
	}
]

自定義在Terminus的終端中編譯運(yùn)行cpp文件:

Tools->Build System->New Build System中新建編譯文件,保存為CppTerminus.sublime-build,替換內(nèi)容為:

{
	// MacOS
	"cmd": [
		"zsh",
		"-c",
		"clang++ '${file}' -std=c++17 -stdlib=libc++ -o '${file_path}/../bin/${file_base_name}' && ${file_path}/../bin/${file_base_name}"
	],
	"file_regex": "^(..{FNXX==XXFN}*):([0-9]+):?([0-9]+)?:? (.*)$",
	"working_dir": "${file_path}",
	"encoding": "utf-8",
	"selector": "source.c, source.c++",
	"variants": [
		{
			"name": "Run In Terminus",
			"target": "terminus_exec",
			"cancel": "terminus_cancel_build",
			"cmd": [
				"zsh",
				"-c",
				"clang++ '${file}' -std=c++17 -stdlib=libc++ -o '${file_path}/../bin/${file_base_name}' && ${file_path}/../bin/${file_base_name}"
			]
		},
		{
			"name": "Create Input File",
			"cmd": [
				"zsh",
				"-c",
				"touch ${file_path}/../in_out/${file_base_name}.in && open -a Sublime\\ Text ${file_path}/../in_out/${file_base_name}.in"
			]
		},
		{
			"name": "Run In Terminal",
			"cmd": [
				"zsh",
				"-c",
				"clang++ '${file}' -std=c++17 -stdlib=libc++ -o '${file_path}/../bin/${file_base_name}' && open -a Terminal.app '${file_path}/../bin/${file_base_name}'"
			]
		},
	]
}

注意要保證源文件和bin文件夾、in_out文件夾在同一目錄下。

配置LSP + LSP-clangd

安裝這兩個(gè)插件,windows和linux需要手動(dòng)安裝clangd并添加到path。

mac下安裝clangd

我的mac已經(jīng)自帶了clangd,安裝好這兩個(gè)插件即可實(shí)現(xiàn)語(yǔ)法提示; 如果沒(méi)有安裝clangd,通過(guò)以下命令安裝:

brew install llvm
echo 'export PATH="/usr/local/opt/llvm/bin:$PATH"' >> ~/.zshrc
echo 'export LDFLAGS="-L/usr/local/opt/llvm/lib"' >> ~/.zshrc
echo 'export CPPFLAGS="-I/usr/local/opt/llvm/include"' >> ~/.zshrc

Debian(testing)安裝clangd和clang

sudo apt install clangdsudo apt install llvmsudo apt install clang

windows下安裝llvm

借助scoop, scoop install llvm 然后安裝Visual Stdudio Build Tools,鑒于windows上clang默認(rèn)的c++庫(kù)就是msvc,所以就用這個(gè)吧,別折騰mingw了.

配置LSP-clangd

Preferences->Package Settings->LSP->Settings,寫(xiě)入這樣幾行

{
    // 在主頁(yè)面只顯示error紅色下劃線
    //"show_diagnostics_severity_level": 1,
    // 代碼提示顯示燈泡圖標(biāo)
    "show_code_actions": "bulb",
    // 保存時(shí)自動(dòng)格式化
    "lsp_format_on_save": true,
}

再到Preferences->Package Settings->LSP->Servers->LSP-clangd中,寫(xiě)入以下幾行

// Settings in here override those in "LSP-clangd/LSP-clangd.sublime-settings"
{
    "initializationOptions": {
        // 啟用clang-tidy代碼檢查,可能啟用后warning會(huì)比較多,自己看著辦吧
        "clangd.clang-tidy": true,
        // 美化clangd輸出的JSON
        "clangd.pretty": true,
    }
}

再到project/code(源文件所在目錄)下新建.clang-tidy文件,寫(xiě)入:

Checks: "bugprone-*,\
google-*,\
misc-*,\
modernize-*,\
performance-*,\
readability-*,\
portability-*,\
"
HeaderFilterRegex: 'Source/cm[^/]*\.(h|hxx|cxx)$'
CheckOptions:
  - key:   modernize-use-default-member-init.UseAssignment
    value: '1'
  - key:   modernize-use-equals-default.IgnoreMacros
    value: '0'
  - key:   modernize-use-auto.MinTypeNameLength
    value: '80'

LSP-clangd默認(rèn)是使用c++98來(lái)檢查代碼的,要修改為c++17,需要在項(xiàng)目根目錄下新建.clangd文件,文件內(nèi)容如下:

CompileFlags:
	Add: [-std=c++17]

推薦方式為利用cmake生成compile_commands.jsonCMakeLists.txt的內(nèi)容如下:

cmake_minimum_required(VERSION 3.22)
# Enable C++11
set(CMAKE_CXX_STANDARD 17)
# 設(shè)置項(xiàng)目名
project(LeetCpp)
# 源文件
aux_source_directory(. SOURCES)
# 頭文件
include_directories(.)
add_executable(${PROJECT_NAME} ${SOURCES})

通過(guò)cmake .. -DCMAKE_EXPORT_COMPILE_COMMANDS=1生成compile_commands.json文件,注意要在build目錄下,且build的上級(jí)目錄存在CMakelists.txt

配置clang-format

安裝好clang-format插件之后,只需在project/code下新建.clang-format文件,寫(xiě)入以下內(nèi)容

抄的網(wǎng)上的,修改了大括號(hào)換行的部分(左大括號(hào)不單獨(dú)位于一行)

# 語(yǔ)言: None, Cpp, Java, JavaScript, ObjC, Proto, TableGen, TextProto
Language: Cpp
# BasedOnStyle: LLVM
# 訪問(wèn)說(shuō)明符(public、private等)的偏移
AccessModifierOffset: -2
# 開(kāi)括號(hào)(開(kāi)圓括號(hào)、開(kāi)尖括號(hào)、開(kāi)方括號(hào))后的對(duì)齊: Align, DontAlign, AlwaysBreak(總是在開(kāi)括號(hào)后換行)
AlignAfterOpenBracket: Align
# 連續(xù)賦值時(shí),對(duì)齊所有等號(hào)
AlignConsecutiveAssignments: false
# 連續(xù)聲明時(shí),對(duì)齊所有聲明的變量名
AlignConsecutiveDeclarations: false
# 右對(duì)齊逃脫換行(使用反斜杠換行)的反斜杠
AlignEscapedNewlines: Right
# 水平對(duì)齊二元和三元表達(dá)式的操作數(shù)
AlignOperands: true
# 對(duì)齊連續(xù)的尾隨的注釋
AlignTrailingComments: true
# 不允許函數(shù)聲明的所有參數(shù)在放在下一行
AllowAllParametersOfDeclarationOnNextLine: false
# 不允許短的塊放在同一行
AllowShortBlocksOnASingleLine: true
# 允許短的case標(biāo)簽放在同一行
AllowShortCaseLabelsOnASingleLine: true
# 允許短的函數(shù)放在同一行: None, InlineOnly(定義在類中), Empty(空函數(shù)), Inline(定義在類中,空函數(shù)), All
AllowShortFunctionsOnASingleLine: None
# 允許短的if語(yǔ)句保持在同一行
AllowShortIfStatementsOnASingleLine: true
# 允許短的循環(huán)保持在同一行
AllowShortLoopsOnASingleLine: true
# 總是在返回類型后換行: None, All, TopLevel(頂級(jí)函數(shù),不包括在類中的函數(shù)), 
# AllDefinitions(所有的定義,不包括聲明), TopLevelDefinitions(所有的頂級(jí)函數(shù)的定義)
AlwaysBreakAfterReturnType: None
# 總是在多行string字面量前換行
AlwaysBreakBeforeMultilineStrings: false
# 總是在template聲明后換行
AlwaysBreakTemplateDeclarations: true
# false表示函數(shù)實(shí)參要么都在同一行,要么都各自一行
BinPackArguments: true
# false表示所有形參要么都在同一行,要么都各自一行
BinPackParameters: true
# 大括號(hào)換行,只有當(dāng)BreakBeforeBraces設(shè)置為Custom時(shí)才有效
BraceWrapping:
  # class定義后面
  AfterClass: false
  # 控制語(yǔ)句后面
  AfterControlStatement: false
  # enum定義后面
  AfterEnum: false
  # 函數(shù)定義后面
  AfterFunction: false
  # 命名空間定義后面
  AfterNamespace: false
  # struct定義后面
  AfterStruct: false
  # union定義后面
  AfterUnion: false
  # extern之后
  AfterExternBlock: false
  # catch之前
  BeforeCatch: false
  # else之前
  BeforeElse: false
  # 縮進(jìn)大括號(hào)
  IndentBraces: false
  # 分離空函數(shù)
  SplitEmptyFunction: false
  # 分離空語(yǔ)句
  SplitEmptyRecord: false
  # 分離空命名空間
  SplitEmptyNamespace: false
# 在二元運(yùn)算符前換行: None(在操作符后換行), NonAssignment(在非賦值的操作符前換行), All(在操作符前換行)
BreakBeforeBinaryOperators: NonAssignment
# 在大括號(hào)前換行: Attach(始終將大括號(hào)附加到周圍的上下文), Linux(除函數(shù)、命名空間和類定義,與Attach類似), 
#   Mozilla(除枚舉、函數(shù)、記錄定義,與Attach類似), Stroustrup(除函數(shù)定義、catch、else,與Attach類似), 
#   Allman(總是在大括號(hào)前換行), GNU(總是在大括號(hào)前換行,并對(duì)于控制語(yǔ)句的大括號(hào)增加額外的縮進(jìn)), WebKit(在函數(shù)前換行), Custom
#   注:這里認(rèn)為語(yǔ)句塊也屬于函數(shù)
BreakBeforeBraces: Custom
# 在三元運(yùn)算符前換行
BreakBeforeTernaryOperators: false
# 在構(gòu)造函數(shù)的初始化列表的冒號(hào)后換行
BreakConstructorInitializers: AfterColon
#BreakInheritanceList: AfterColon
BreakStringLiterals: false
# 每行字符的限制,0表示沒(méi)有限制
ColumnLimit: 0
CompactNamespaces: true
# 構(gòu)造函數(shù)的初始化列表要么都在同一行,要么都各自一行
ConstructorInitializerAllOnOneLineOrOnePerLine: false
# 構(gòu)造函數(shù)的初始化列表的縮進(jìn)寬度
ConstructorInitializerIndentWidth: 4
# 延續(xù)的行的縮進(jìn)寬度
ContinuationIndentWidth: 4
# 去除C++11的列表初始化的大括號(hào){后和}前的空格
Cpp11BracedListStyle: true
# 繼承最常用的指針和引用的對(duì)齊方式
DerivePointerAlignment: false
# 固定命名空間注釋
FixNamespaceComments: true
# 縮進(jìn)case標(biāo)簽
IndentCaseLabels: false
IndentPPDirectives: None
# 縮進(jìn)寬度
IndentWidth: 4
# 函數(shù)返回類型換行時(shí),縮進(jìn)函數(shù)聲明或函數(shù)定義的函數(shù)名
IndentWrappedFunctionNames: false
# 保留在塊開(kāi)始處的空行
KeepEmptyLinesAtTheStartOfBlocks: false
# 連續(xù)空行的最大數(shù)量
MaxEmptyLinesToKeep: 1
# 命名空間的縮進(jìn): None, Inner(縮進(jìn)嵌套的命名空間中的內(nèi)容), All
NamespaceIndentation: None
# 指針和引用的對(duì)齊: Left, Right, Middle
PointerAlignment: Right
# 允許重新排版注釋
ReflowComments: true
# 允許排序#include
SortIncludes: false
# 允許排序 using 聲明
SortUsingDeclarations: false
# 在C風(fēng)格類型轉(zhuǎn)換后添加空格
SpaceAfterCStyleCast: false
# 在Template 關(guān)鍵字后面添加空格
SpaceAfterTemplateKeyword: true
# 在賦值運(yùn)算符之前添加空格
SpaceBeforeAssignmentOperators: true
# SpaceBeforeCpp11BracedList: true
# SpaceBeforeCtorInitializerColon: true
# SpaceBeforeInheritanceColon: true
# 開(kāi)圓括號(hào)之前添加一個(gè)空格: Never, ControlStatements, Always
SpaceBeforeParens: ControlStatements
# SpaceBeforeRangeBasedForLoopColon: true
# 在空的圓括號(hào)中添加空格
SpaceInEmptyParentheses: false
# 在尾隨的評(píng)論前添加的空格數(shù)(只適用于//)
SpacesBeforeTrailingComments: 1
# 在尖括號(hào)的<后和>前添加空格
SpacesInAngles: false
# 在C風(fēng)格類型轉(zhuǎn)換的括號(hào)中添加空格
SpacesInCStyleCastParentheses: false
# 在容器(ObjC和JavaScript的數(shù)組和字典等)字面量中添加空格
SpacesInContainerLiterals: true
# 在圓括號(hào)的(后和)前添加空格
SpacesInParentheses: false
# 在方括號(hào)的[后和]前添加空格,lamda表達(dá)式和未指明大小的數(shù)組的聲明不受影響
SpacesInSquareBrackets: false
# 標(biāo)準(zhǔn): Cpp03, Cpp11, Auto
Standard: Cpp11
# tab寬度
TabWidth: 4
# 使用tab字符: Never, ForIndentation, ForContinuationAndIndentation, Always
UseTab: Never

命令行使用sublime text4打開(kāi)文件

mac下添加軟連接: ln /Applications/Sublime\ Text.app/Contents/SharedSupport/bin/subl /usr/local/bin/subl

debian下執(zhí)行sudo ln -s /opt/sublime_text/sublime_text /usr/local/bin/subl

之后就能用subl test.cpp命令來(lái)調(diào)用sublime text4打開(kāi)test.cpp了。

leetcode相關(guān)配置

安裝leetgo: brew install j178/tap/leetgo

在預(yù)期的leetcode項(xiàng)目目錄下執(zhí)行leetgo init,然后配置leetgo.yaml

# leetgo project level config, global config is at /Users/zwy/.config/leetgo/config.yaml
# for more details, please refer to https://github.com/j178/leetgo
# author
author: zwyyy456
language: en
code:
  lang: cpp
leetcode:
  site: https://leetcode.com
#  credentials:
#    from: browser
editor:
  use: custom
  command: "subl"
  # use: vscode

到此這篇關(guān)于配置 Sublime Text4為 C++ 編輯器的文章就介紹到這了,更多相關(guān)Sublime Text4配置C++內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++小知識(shí):復(fù)制粘貼代碼千萬(wàn)要小心

    C++小知識(shí):復(fù)制粘貼代碼千萬(wàn)要小心

    今天小編就為大家分享一篇關(guān)于C++小知識(shí):復(fù)制粘貼代碼千萬(wàn)要小心,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)系列篇二叉樹(shù)的遍歷

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)系列篇二叉樹(shù)的遍歷

    本章將會(huì)詳細(xì)講解二叉樹(shù)遍歷的四種方式,分別為前序遍歷、中序遍歷、后續(xù)遍歷和層序遍歷。在學(xué)習(xí)遍歷之前,會(huì)先帶大家回顧一下二叉樹(shù)的基本概念
    2022-02-02
  • C++前綴樹(shù)字典樹(shù)的學(xué)習(xí)與模擬實(shí)現(xiàn)代碼示例

    C++前綴樹(shù)字典樹(shù)的學(xué)習(xí)與模擬實(shí)現(xiàn)代碼示例

    這篇文章主要介紹了C++前綴樹(shù)字典樹(shù)的學(xué)習(xí)與模擬實(shí)現(xiàn)代碼示例,Trie又被稱為前綴樹(shù)、字典樹(shù),所以當(dāng)然是一棵樹(shù),上面這棵Trie樹(shù)包含的字符串集合是{in,inn,int,tea,ten,to},每個(gè)節(jié)點(diǎn)的編號(hào)是我們?yōu)榱嗣枋龇奖慵由先サ?需要的朋友可以參考下
    2023-07-07
  • 基于C語(yǔ)言實(shí)現(xiàn)三子棋游戲

    基于C語(yǔ)言實(shí)現(xiàn)三子棋游戲

    這篇文章主要為大家詳細(xì)介紹了基于C語(yǔ)言實(shí)現(xiàn)三子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 快速模式匹配算法(KMP)的深入理解

    快速模式匹配算法(KMP)的深入理解

    本篇文章是對(duì)快速模式匹配算法(KMP)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • windows上安裝CLion教程及簡(jiǎn)單使用詳解

    windows上安裝CLion教程及簡(jiǎn)單使用詳解

    這篇文章主要介紹了windows上安裝CLion教程及簡(jiǎn)單使用,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例

    C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例

    這篇文章主要介紹了C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • 一文解密C++中的多態(tài)機(jī)制

    一文解密C++中的多態(tài)機(jī)制

    眾所周知C++語(yǔ)言的三大特性:封裝、多態(tài)、繼承,其中多態(tài)就是去完成某個(gè)行為,但是會(huì)根據(jù)不同的對(duì)象產(chǎn)生不同的狀態(tài),下面小編就來(lái)帶大家深入了解一下C++的多態(tài)機(jī)制吧
    2023-07-07
  • C++紅黑樹(shù)的底層實(shí)現(xiàn)機(jī)制詳解

    C++紅黑樹(shù)的底層實(shí)現(xiàn)機(jī)制詳解

    紅黑樹(shù)與AVL樹(shù)一樣,也是一種自平衡的二叉搜索樹(shù),它在每個(gè)結(jié)點(diǎn)上增加一個(gè)存儲(chǔ)位表示結(jié)點(diǎn)的顏色,可以是Red或Black,通過(guò)對(duì)任何一條從根到葉子的路徑上各個(gè)結(jié)點(diǎn)著色方式的限制,本文介紹了C++紅黑樹(shù)的底層實(shí)現(xiàn)機(jī)制,需要的朋友可以參考下
    2024-08-08
  • C語(yǔ)言make和Makefile介紹及使用

    C語(yǔ)言make和Makefile介紹及使用

    這篇文章介紹了C語(yǔ)言make和Makefile以及使用方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-01-01

最新評(píng)論