Merge branch 'js/vscode'
Add a script (in contrib/) to help users of VSCode work better with our codebase. * js/vscode: vscode: let cSpell work on commit messages, too vscode: add a dictionary for cSpell vscode: use 8-space tabs, no trailing ws, etc for Git's source code vscode: wrap commit messages at column 72 by default vscode: only overwrite C/C++ settings mingw: define WIN32 explicitly cache.h: extract enum declaration from inside a struct declaration vscode: hard-code a couple defines contrib: add a script to initialize VS Code configurationmaint
commit
30cf1911e2
|
@ -207,6 +207,7 @@
|
|||
/config.mak.autogen
|
||||
/config.mak.append
|
||||
/configure
|
||||
/.vscode/
|
||||
/tags
|
||||
/TAGS
|
||||
/cscope*
|
||||
|
|
24
cache.h
24
cache.h
|
@ -1423,18 +1423,20 @@ extern void *read_object_with_reference(const struct object_id *oid,
|
|||
extern struct object *peel_to_type(const char *name, int namelen,
|
||||
struct object *o, enum object_type);
|
||||
|
||||
enum date_mode_type {
|
||||
DATE_NORMAL = 0,
|
||||
DATE_RELATIVE,
|
||||
DATE_SHORT,
|
||||
DATE_ISO8601,
|
||||
DATE_ISO8601_STRICT,
|
||||
DATE_RFC2822,
|
||||
DATE_STRFTIME,
|
||||
DATE_RAW,
|
||||
DATE_UNIX
|
||||
};
|
||||
|
||||
struct date_mode {
|
||||
enum date_mode_type {
|
||||
DATE_NORMAL = 0,
|
||||
DATE_RELATIVE,
|
||||
DATE_SHORT,
|
||||
DATE_ISO8601,
|
||||
DATE_ISO8601_STRICT,
|
||||
DATE_RFC2822,
|
||||
DATE_STRFTIME,
|
||||
DATE_RAW,
|
||||
DATE_UNIX
|
||||
} type;
|
||||
enum date_mode_type type;
|
||||
const char *strftime_fmt;
|
||||
int local;
|
||||
};
|
||||
|
|
|
@ -528,7 +528,7 @@ ifneq (,$(findstring MINGW,$(uname_S)))
|
|||
COMPAT_OBJS += compat/mingw.o compat/winansi.o \
|
||||
compat/win32/pthread.o compat/win32/syslog.o \
|
||||
compat/win32/dirent.o
|
||||
BASIC_CFLAGS += -DPROTECT_NTFS_DEFAULT=1
|
||||
BASIC_CFLAGS += -DWIN32 -DPROTECT_NTFS_DEFAULT=1
|
||||
EXTLIBS += -lws2_32
|
||||
GITLIBS += git.res
|
||||
PTHREAD_LIBS =
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
init.sh whitespace=-indent-with-non-tab
|
|
@ -0,0 +1,14 @@
|
|||
Configuration for VS Code
|
||||
=========================
|
||||
|
||||
[VS Code](https://code.visualstudio.com/) is a lightweight but powerful source
|
||||
code editor which runs on your desktop and is available for
|
||||
[Windows](https://code.visualstudio.com/docs/setup/windows),
|
||||
[macOS](https://code.visualstudio.com/docs/setup/mac) and
|
||||
[Linux](https://code.visualstudio.com/docs/setup/linux). Among other languages,
|
||||
it has [support for C/C++ via an extension](https://github.com/Microsoft/vscode-cpptools).
|
||||
|
||||
To start developing Git with VS Code, simply run the Unix shell script called
|
||||
`init.sh` in this directory, which creates the configuration files in
|
||||
`.vscode/` that VS Code consumes. `init.sh` needs access to `make` and `gcc`,
|
||||
so run the script in a Git SDK shell if you are using Windows.
|
|
@ -0,0 +1,375 @@
|
|||
#!/bin/sh
|
||||
|
||||
die () {
|
||||
echo "$*" >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
cd "$(dirname "$0")"/../.. ||
|
||||
die "Could not cd to top-level directory"
|
||||
|
||||
mkdir -p .vscode ||
|
||||
die "Could not create .vscode/"
|
||||
|
||||
# General settings
|
||||
|
||||
cat >.vscode/settings.json.new <<\EOF ||
|
||||
{
|
||||
"C_Cpp.intelliSenseEngine": "Default",
|
||||
"C_Cpp.intelliSenseEngineFallback": "Disabled",
|
||||
"[git-commit]": {
|
||||
"editor.wordWrap": "wordWrapColumn",
|
||||
"editor.wordWrapColumn": 72
|
||||
},
|
||||
"[c]": {
|
||||
"editor.detectIndentation": false,
|
||||
"editor.insertSpaces": false,
|
||||
"editor.tabSize": 8,
|
||||
"editor.wordWrap": "wordWrapColumn",
|
||||
"editor.wordWrapColumn": 80,
|
||||
"files.trimTrailingWhitespace": true
|
||||
},
|
||||
"files.associations": {
|
||||
"*.h": "c",
|
||||
"*.c": "c"
|
||||
},
|
||||
"cSpell.ignorePaths": [
|
||||
],
|
||||
"cSpell.words": [
|
||||
"DATAW",
|
||||
"DBCACHED",
|
||||
"DFCHECK",
|
||||
"DTYPE",
|
||||
"Hamano",
|
||||
"HCAST",
|
||||
"HEXSZ",
|
||||
"HKEY",
|
||||
"HKLM",
|
||||
"IFGITLINK",
|
||||
"IFINVALID",
|
||||
"ISBROKEN",
|
||||
"ISGITLINK",
|
||||
"ISSYMREF",
|
||||
"Junio",
|
||||
"LPDWORD",
|
||||
"LPPROC",
|
||||
"LPWSTR",
|
||||
"MSVCRT",
|
||||
"NOARG",
|
||||
"NOCOMPLETE",
|
||||
"NOINHERIT",
|
||||
"RENORMALIZE",
|
||||
"STARTF",
|
||||
"STARTUPINFOEXW",
|
||||
"Schindelin",
|
||||
"UCRT",
|
||||
"YESNO",
|
||||
"argcp",
|
||||
"beginthreadex",
|
||||
"committish",
|
||||
"contentp",
|
||||
"cpath",
|
||||
"cpidx",
|
||||
"ctim",
|
||||
"dequote",
|
||||
"envw",
|
||||
"ewah",
|
||||
"fdata",
|
||||
"fherr",
|
||||
"fhin",
|
||||
"fhout",
|
||||
"fragp",
|
||||
"fsmonitor",
|
||||
"hnsec",
|
||||
"idents",
|
||||
"includeif",
|
||||
"interpr",
|
||||
"iprog",
|
||||
"isexe",
|
||||
"iskeychar",
|
||||
"kompare",
|
||||
"mksnpath",
|
||||
"mktag",
|
||||
"mktree",
|
||||
"mmblob",
|
||||
"mmbuffer",
|
||||
"mmfile",
|
||||
"noenv",
|
||||
"nparents",
|
||||
"ntpath",
|
||||
"ondisk",
|
||||
"ooid",
|
||||
"oplen",
|
||||
"osdl",
|
||||
"pnew",
|
||||
"pold",
|
||||
"ppinfo",
|
||||
"pushf",
|
||||
"pushv",
|
||||
"rawsz",
|
||||
"rebasing",
|
||||
"reencode",
|
||||
"repo",
|
||||
"rerere",
|
||||
"scld",
|
||||
"sharedrepo",
|
||||
"spawnv",
|
||||
"spawnve",
|
||||
"spawnvpe",
|
||||
"strdup'ing",
|
||||
"submodule",
|
||||
"submodules",
|
||||
"topath",
|
||||
"topo",
|
||||
"tpatch",
|
||||
"unexecutable",
|
||||
"unhide",
|
||||
"unkc",
|
||||
"unkv",
|
||||
"unmark",
|
||||
"unmatch",
|
||||
"unsets",
|
||||
"unshown",
|
||||
"untracked",
|
||||
"untrackedcache",
|
||||
"unuse",
|
||||
"upos",
|
||||
"uval",
|
||||
"vreportf",
|
||||
"wargs",
|
||||
"wargv",
|
||||
"wbuffer",
|
||||
"wcmd",
|
||||
"wcsnicmp",
|
||||
"wcstoutfdup",
|
||||
"wdeltaenv",
|
||||
"wdir",
|
||||
"wenv",
|
||||
"wenvblk",
|
||||
"wenvcmp",
|
||||
"wenviron",
|
||||
"wenvpos",
|
||||
"wenvsz",
|
||||
"wfile",
|
||||
"wfilename",
|
||||
"wfopen",
|
||||
"wfreopen",
|
||||
"wfullpath",
|
||||
"which'll",
|
||||
"wlink",
|
||||
"wmain",
|
||||
"wmkdir",
|
||||
"wmktemp",
|
||||
"wnewpath",
|
||||
"wotype",
|
||||
"wpath",
|
||||
"wpathname",
|
||||
"wpgmptr",
|
||||
"wpnew",
|
||||
"wpointer",
|
||||
"wpold",
|
||||
"wpos",
|
||||
"wputenv",
|
||||
"wrmdir",
|
||||
"wship",
|
||||
"wtarget",
|
||||
"wtemplate",
|
||||
"wunlink",
|
||||
"xcalloc",
|
||||
"xgetcwd",
|
||||
"xmallocz",
|
||||
"xmemdupz",
|
||||
"xmmap",
|
||||
"xopts",
|
||||
"xrealloc",
|
||||
"xsnprintf",
|
||||
"xutftowcs",
|
||||
"xutftowcsn",
|
||||
"xwcstoutf"
|
||||
],
|
||||
"cSpell.ignoreRegExpList": [
|
||||
"\\\"(DIRC|FSMN|REUC|UNTR)\\\"",
|
||||
"\\\\u[0-9a-fA-Fx]{4}\\b",
|
||||
"\\b(filfre|frotz|xyzzy)\\b",
|
||||
"\\bCMIT_FMT_DEFAULT\\b",
|
||||
"\\bde-munge\\b",
|
||||
"\\bGET_OID_DISAMBIGUATORS\\b",
|
||||
"\\bHASH_RENORMALIZE\\b",
|
||||
"\\bTREESAMEness\\b",
|
||||
"\\bUSE_STDEV\\b",
|
||||
"\\Wchar *\\*\\W*utfs\\W",
|
||||
"cURL's",
|
||||
"nedmalloc'ed",
|
||||
"ntifs\\.h",
|
||||
],
|
||||
}
|
||||
EOF
|
||||
die "Could not write settings.json"
|
||||
|
||||
# Infer some setup-specific locations/names
|
||||
|
||||
GCCPATH="$(which gcc)"
|
||||
GDBPATH="$(which gdb)"
|
||||
MAKECOMMAND="make -j5 DEVELOPER=1"
|
||||
OSNAME=
|
||||
X=
|
||||
case "$(uname -s)" in
|
||||
MINGW*)
|
||||
GCCPATH="$(cygpath -am "$GCCPATH")"
|
||||
GDBPATH="$(cygpath -am "$GDBPATH")"
|
||||
MAKE_BASH="$(cygpath -am /git-cmd.exe) --command=usr\\\\bin\\\\bash.exe"
|
||||
MAKECOMMAND="$MAKE_BASH -lc \\\"$MAKECOMMAND\\\""
|
||||
OSNAME=Win32
|
||||
X=.exe
|
||||
;;
|
||||
Linux)
|
||||
OSNAME=Linux
|
||||
;;
|
||||
Darwin)
|
||||
OSNAME=macOS
|
||||
;;
|
||||
esac
|
||||
|
||||
# Default build task
|
||||
|
||||
cat >.vscode/tasks.json.new <<EOF ||
|
||||
{
|
||||
// See https://go.microsoft.com/fwlink/?LinkId=733558
|
||||
// for the documentation about the tasks.json format
|
||||
"version": "2.0.0",
|
||||
"tasks": [
|
||||
{
|
||||
"label": "make",
|
||||
"type": "shell",
|
||||
"command": "$MAKECOMMAND",
|
||||
"group": {
|
||||
"kind": "build",
|
||||
"isDefault": true
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
EOF
|
||||
die "Could not install default build task"
|
||||
|
||||
# Debugger settings
|
||||
|
||||
cat >.vscode/launch.json.new <<EOF ||
|
||||
{
|
||||
// Use IntelliSense to learn about possible attributes.
|
||||
// Hover to view descriptions of existing attributes.
|
||||
// For more information, visit:
|
||||
// https://go.microsoft.com/fwlink/?linkid=830387
|
||||
"version": "0.2.0",
|
||||
"configurations": [
|
||||
{
|
||||
"name": "(gdb) Launch",
|
||||
"type": "cppdbg",
|
||||
"request": "launch",
|
||||
"program": "\${workspaceFolder}/git$X",
|
||||
"args": [],
|
||||
"stopAtEntry": false,
|
||||
"cwd": "\${workspaceFolder}",
|
||||
"environment": [],
|
||||
"externalConsole": true,
|
||||
"MIMode": "gdb",
|
||||
"miDebuggerPath": "$GDBPATH",
|
||||
"setupCommands": [
|
||||
{
|
||||
"description": "Enable pretty-printing for gdb",
|
||||
"text": "-enable-pretty-printing",
|
||||
"ignoreFailures": true
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
EOF
|
||||
die "Could not write launch configuration"
|
||||
|
||||
# C/C++ extension settings
|
||||
|
||||
make -f - OSNAME=$OSNAME GCCPATH="$GCCPATH" vscode-init \
|
||||
>.vscode/c_cpp_properties.json <<\EOF ||
|
||||
include Makefile
|
||||
|
||||
vscode-init:
|
||||
@mkdir -p .vscode && \
|
||||
incs= && defs= && \
|
||||
for e in $(ALL_CFLAGS) \
|
||||
'-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' \
|
||||
'-DGIT_LOCALE_PATH="$(localedir_relative_SQ)"' \
|
||||
'-DBINDIR="$(bindir_relative_SQ)"' \
|
||||
'-DFALLBACK_RUNTIME_PREFIX="$(prefix_SQ)"' \
|
||||
'-DDEFAULT_GIT_TEMPLATE_DIR="$(template_dir_SQ)"' \
|
||||
'-DETC_GITCONFIG="$(ETC_GITCONFIG_SQ)"' \
|
||||
'-DETC_GITATTRIBUTES="$(ETC_GITATTRIBUTES_SQ)"' \
|
||||
'-DGIT_LOCALE_PATH="$(localedir_relative_SQ)"' \
|
||||
'-DCURL_DISABLE_TYPECHECK', \
|
||||
'-DGIT_HTML_PATH="$(htmldir_relative_SQ)"' \
|
||||
'-DGIT_MAN_PATH="$(mandir_relative_SQ)"' \
|
||||
'-DGIT_INFO_PATH="$(infodir_relative_SQ)"'; do \
|
||||
case "$$e" in \
|
||||
-I.) \
|
||||
incs="$$(printf '% 16s"$${workspaceRoot}",\n%s' \
|
||||
"" "$$incs")" \
|
||||
;; \
|
||||
-I/*) \
|
||||
incs="$$(printf '% 16s"%s",\n%s' \
|
||||
"" "$${e#-I}" "$$incs")" \
|
||||
;; \
|
||||
-I*) \
|
||||
incs="$$(printf '% 16s"$${workspaceRoot}/%s",\n%s' \
|
||||
"" "$${e#-I}" "$$incs")" \
|
||||
;; \
|
||||
-D*) \
|
||||
defs="$$(printf '% 16s"%s",\n%s' \
|
||||
"" "$$(echo "$${e#-D}" | sed 's/"/\\&/g')" \
|
||||
"$$defs")" \
|
||||
;; \
|
||||
esac; \
|
||||
done && \
|
||||
echo '{' && \
|
||||
echo ' "configurations": [' && \
|
||||
echo ' {' && \
|
||||
echo ' "name": "$(OSNAME)",' && \
|
||||
echo ' "intelliSenseMode": "clang-x64",' && \
|
||||
echo ' "includePath": [' && \
|
||||
echo "$$incs" | sort | sed '$$s/,$$//' && \
|
||||
echo ' ],' && \
|
||||
echo ' "defines": [' && \
|
||||
echo "$$defs" | sort | sed '$$s/,$$//' && \
|
||||
echo ' ],' && \
|
||||
echo ' "browse": {' && \
|
||||
echo ' "limitSymbolsToIncludedHeaders": true,' && \
|
||||
echo ' "databaseFilename": "",' && \
|
||||
echo ' "path": [' && \
|
||||
echo ' "$${workspaceRoot}"' && \
|
||||
echo ' ]' && \
|
||||
echo ' },' && \
|
||||
echo ' "cStandard": "c11",' && \
|
||||
echo ' "cppStandard": "c++17",' && \
|
||||
echo ' "compilerPath": "$(GCCPATH)"' && \
|
||||
echo ' }' && \
|
||||
echo ' ],' && \
|
||||
echo ' "version": 4' && \
|
||||
echo '}'
|
||||
EOF
|
||||
die "Could not write settings for the C/C++ extension"
|
||||
|
||||
for file in .vscode/settings.json .vscode/tasks.json .vscode/launch.json
|
||||
do
|
||||
if test -f $file
|
||||
then
|
||||
if git diff --no-index --quiet --exit-code $file $file.new
|
||||
then
|
||||
rm $file.new
|
||||
else
|
||||
printf "The file $file.new has these changes:\n\n"
|
||||
git --no-pager diff --no-index $file $file.new
|
||||
printf "\n\nMaybe \`mv $file.new $file\`?\n\n"
|
||||
fi
|
||||
else
|
||||
mv $file.new $file
|
||||
fi
|
||||
done
|
Loading…
Reference in New Issue