Skip to main content

execute queries

[์—ฐ๊ฒฐ] ๋ฐ์ดํ„ฐ ์„ธํŠธ์— ๋Œ€ํ•ด ํ•˜๋‚˜ ์ด์ƒ์˜ ์ฟผ๋ฆฌ๋ฅผ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.

๋ˆ„๊ฐ€ ์ด ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‚˜์š”?

CodeQL์€(๋Š”) ๋‹ค์Œ ๋ฆฌํฌ์ง€ํ† ๋ฆฌ ์œ ํ˜•์— ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

  • GitHub.com์˜ ํผ๋ธ”๋ฆญ ๋ฆฌํฌ์ง€ํ† ๋ฆฌ, GitHub CodeQL ์‚ฌ์šฉ ์•ฝ๊ด€ ์ฐธ์กฐ
  • GitHub Code Security๋ฅผ ์‚ฌ์šฉํ•˜๋„๋ก ์„ค์ •๋œ GitHub Team์˜ ์กฐ์ง ์†Œ์œ  ๋ฆฌํฌ์ง€ํ† ๋ฆฌ

์ด ๋ฌธ์„œ์˜ ๋‚ด์šฉ

์ฐธ๊ณ  ํ•ญ๋ชฉ

์ด ์ฝ˜ํ…์ธ ๋Š” CodeQL CLI์˜ ์ตœ์‹  ๋ฆด๋ฆฌ์Šค์— ๋Œ€ํ•ด ์„ค๋ช…ํ•ฉ๋‹ˆ๋‹ค. ์ด ์š”์†Œ์— ๋Œ€ํ•œ ์ž์„ธํ•œ ๋‚ด์šฉ์€ https://github.com/github/codeql-cli-binaries/releases์„(๋ฅผ) ์ฐธ์กฐํ•˜์„ธ์š”.

์ด์ „ ๋ฆด๋ฆฌ์Šค์—์„œ ์ด ๋ช…๋ น์— ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ์˜ต์…˜์˜ ์„ธ๋ถ€ ์ •๋ณด๋ฅผ ๋ณด๋ ค๋ฉด ํ„ฐ๋ฏธ๋„์—์„œ ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์—ฌ --help ๋ช…๋ น์„ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.

๊ฐœ์š”

Shell
codeql execute queries [--output=<dir|file.bqrs>] [--threads=<num>] <options>... -- <dataset> <query|dir|suite|pack>...

์„ค๋ช…

[์—ฐ๊ฒฐ] ๋ฐ์ดํ„ฐ ์„ธํŠธ์— ๋Œ€ํ•ด ํ•˜๋‚˜ ์ด์ƒ์˜ ์ฟผ๋ฆฌ๋ฅผ ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค.

์ด ๋ช…๋ น์€ ์ผ๋ฐ˜์ ์œผ๋กœ ์ง์ ‘ ํ˜ธ์ถœํ•ด์„œ๋Š” ์•ˆ ๋ฉ๋‹ˆ๋‹ค. ๋Œ€์‹  codeql database run-queries ๋˜๋Š” codeql query run์„ ์‚ฌ์šฉํ•˜๋ฉด ํŠน์ • JVM ์˜ต์…˜์œผ๋กœ codeql execute queries๋ฅผ ์‹œ์ž‘ํ•˜์—ฌ QL ํ‰๊ฐ€๊ธฐ์˜ ์„ฑ๋Šฅ์„ ์กฐ์ •ํ•ฉ๋‹ˆ๋‹ค.

์˜ต์…˜

๊ธฐ๋ณธ ์˜ต์…˜

<dataset>

[ํ•„์ˆ˜] ์ฟผ๋ฆฌํ•  ์›์‹œ QL ๋ฐ์ดํ„ฐ ์„ธํŠธ์˜ ๊ฒฝ๋กœ์ž…๋‹ˆ๋‹ค.

<query|dir|suite|pack>...

[ํ•„์ˆ˜] ์‹คํ–‰ํ•  ์ฟผ๋ฆฌ์ž…๋‹ˆ๋‹ค. ๊ฐ ์ธ์ˆ˜๋Š” scope/name@range:path ํ˜•์‹์ž…๋‹ˆ๋‹ค.

  • scope/name์€ CodeQL ํŒฉ์˜ ์ •๊ทœํ™”๋œ ์ด๋ฆ„์ž…๋‹ˆ๋‹ค.
  • range๋Š” semver ๋ฒ”์œ„์ž…๋‹ˆ๋‹ค.
  • path๋Š” ํŒŒ์ผ ์‹œ์Šคํ…œ ๊ฒฝ๋กœ์ž…๋‹ˆ๋‹ค.

scope/name์„ ์ง€์ •ํ•˜๋ฉด range ๋ฐ path๋Š” ์„ ํƒ ์‚ฌํ•ญ์ž…๋‹ˆ๋‹ค. ๋ˆ„๋ฝ๋œ range๋Š” ์ง€์ •๋œ ํŒฉ์˜ ์ตœ์‹  ๋ฒ„์ „์„ ์˜๋ฏธํ•ฉ๋‹ˆ๋‹ค. ๋ˆ„๋ฝ๋œ path๋Š” ์ง€์ •๋œ ํŒฉ์˜ ๊ธฐ๋ณธ ์ฟผ๋ฆฌ ๋„๊ตฌ ๋ชจ์Œ์„ ์˜๋ฏธํ•ฉ๋‹ˆ๋‹ค.

path๋Š” *.ql ์ฟผ๋ฆฌ ํŒŒ์ผ, ํ•˜๋‚˜ ์ด์ƒ์˜ ์ฟผ๋ฆฌ๊ฐ€ ํฌํ•จ๋œ ๋””๋ ‰ํ„ฐ๋ฆฌ ๋˜๋Š” .qls ์ฟผ๋ฆฌ ๋„๊ตฌ ๋ชจ์Œ ํŒŒ์ผ ์ค‘ ํ•˜๋‚˜์ผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ง€์ •๋œ ํŒฉ ์ด๋ฆ„์ด ์—†์œผ๋ฉด path๋ฅผ ์ œ๊ณตํ•ด์•ผ ํ•˜๋ฉฐ ํ˜„์žฌ ํ”„๋กœ์„ธ์Šค์˜ ํ˜„์žฌ ์ž‘์—… ๋””๋ ‰ํ„ฐ๋ฆฌ๋ฅผ ๊ธฐ์ค€์œผ๋กœ ํ•ด์„๋ฉ๋‹ˆ๋‹ค.

๋ฆฌํ„ฐ๋Ÿด @ ๋˜๋Š” :์„ ํฌํ•จํ•˜๋Š” path๋ฅผ ์ง€์ •ํ•˜๋ ค๋ฉด path:directory/with:and@/chars์™€ ๊ฐ™์ด ์ธ์ˆ˜์˜ ์ ‘๋‘์‚ฌ๋กœ path:๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

scope/name๊ณผ path๋ฅผ ์ง€์ •ํ•˜๋ฉด path๋Š” ์ ˆ๋Œ“๊ฐ’์ด ๋  ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค. CodeQL ํŒฉ์˜ ๋ฃจํŠธ์— ์ƒ๋Œ€์ ์ธ ๊ฒƒ์œผ๋กœ ๊ฐ„์ฃผ๋ฉ๋‹ˆ๋‹ค.

-o, --output=<dir|file.bqrs>

์ผ๋ฐ˜์ ์œผ๋กœ ์ฟผ๋ฆฌ์˜ BQRS ์ถœ๋ ฅ์ด ๊ธฐ๋ก๋  ๊ธฐ์กด ๋””๋ ‰ํ„ฐ๋ฆฌ์ž…๋‹ˆ๋‹ค. ์ด ๋””๋ ‰ํ„ฐ๋ฆฌ _๋‚ด_์˜ ํŒŒ์ผ ์ด๋ฆ„์€ QL ํŒŒ์ผ ์ด๋ฆ„์—์„œ ํŒŒ์ƒ๋ฉ๋‹ˆ๋‹ค.

๋˜๋Š” ์‹คํ–‰ํ•  ์ฟผ๋ฆฌ๊ฐ€ ์ •ํ™•ํžˆ ํ•˜๋‚˜ ์žˆ๋Š” ๊ฒฝ์šฐ ์ž‘์„ฑํ•  ์‹ค์ œ BQRS ํŒŒ์ผ์˜ ์ด๋ฆ„์ด๊ฑฐ๋‚˜, ์‚ฌ๋žŒ์ด ์ฝ์„ ์ˆ˜ ์žˆ๋Š” ๊ฒฐ๊ณผ ํ‘œํ˜„์„ ํ‘œ์ค€ ์ถœ๋ ฅ์— ๊ธฐ๋กํ•˜๋„๋ก ์ƒ๋žตํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--no-rerun

์ถœ๋ ฅ ์œ„์น˜์— ์ด๋ฏธ BQRS ๊ฒฐ๊ณผ๊ฐ€ ์ €์žฅ๋œ ๊ฒƒ์ฒ˜๋Ÿผ ๋ณด์ด๋Š” ์ฟผ๋ฆฌ์˜ ํ‰๊ฐ€๋ฅผ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค.

์‚ฌ์šฉํ•  ๋ชจ๋ธ ํŒฉ์„ ์ œ์–ดํ•˜๋Š” ์˜ต์…˜

--model-packs=<name@range>...

ํ‰๊ฐ€ํ•˜๋ ค๋Š” ์ฟผ๋ฆฌ๋ฅผ ์‚ฌ์šฉ์ž ์ง€์ •ํ•˜๊ธฐ ์œ„ํ•ด ๋ชจ๋ธ ํŒฉ์œผ๋กœ ์‚ฌ์šฉํ•  CodeQL ํŒฉ ์ด๋ฆ„ ๋ชฉ๋ก(๊ฐ๊ฐ ์„ ํƒ์  ๋ฒ„์ „ ๋ฒ”์œ„ ํฌํ•จ)์ž…๋‹ˆ๋‹ค.

์‚ฌ์šฉํ•  ์œ„ํ˜‘ ๋ชจ๋ธ์„ ์ œ์–ดํ•˜๋Š” ์˜ต์…˜

--threat-model=<name>...

์‚ฌ์šฉํ•˜๊ฑฐ๋‚˜ ์‚ฌ์šฉํ•˜์ง€ ์•Š๋„๋ก ์„ค์ •ํ•  ์œ„ํ˜‘ ๋ชจ๋ธ์˜ ๋ชฉ๋ก์ž…๋‹ˆ๋‹ค.

์ธ์ˆ˜๋Š” ์œ„ํ˜‘ ๋ชจ๋ธ์˜ ์ด๋ฆ„์ด๋ฉฐ, ์„ ํƒ ์‚ฌํ•ญ์œผ๋กœ ์•ž์— '!'๊ฐ€ ์˜ฌ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. '!'๊ฐ€ ์—†์œผ๋ฉด, ๋ช…๋ช…๋œ ์œ„ํ˜‘ ๋ชจ๋ธ ๋ฐ ๋ชจ๋“  ํ•˜์œ„ ํ•ญ๋ชฉ์ด ์‚ฌ์šฉํ•˜๋„๋ก ์„ค์ •๋ฉ๋‹ˆ๋‹ค. '!'๊ฐ€ ์žˆ์œผ๋ฉด, ๋ช…๋ช…๋œ ์œ„ํ˜‘ ๋ชจ๋ธ ๋ฐ ๋ชจ๋“  ํ•˜์œ„ ํ•ญ๋ชฉ์ด ์‚ฌ์šฉํ•˜์ง€ ์•Š๋„๋ก ์„ค์ •๋ฉ๋‹ˆ๋‹ค.

'๊ธฐ๋ณธ' ์œ„ํ˜‘ ๋ชจ๋ธ์€ ๊ธฐ๋ณธ์ ์œผ๋กœ ์‚ฌ์šฉํ•˜๋„๋ก ์„ค์ •๋˜์ง€๋งŒ, '--threat-model !default'๋ฅผ ์ง€์ •ํ•˜์—ฌ ์‚ฌ์šฉํ•˜์ง€ ์•Š๋„๋ก ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

'๋ชจ๋‘' ์œ„ํ˜‘ ๋ชจ๋ธ์„ ์‚ฌ์šฉํ•˜์—ฌ ๋ชจ๋“  ์œ„ํ˜‘ ๋ชจ๋ธ์„ ์‚ฌ์šฉํ•˜๊ฑฐ๋‚˜ ์‚ฌ์šฉํ•˜์ง€ ์•Š๋„๋ก ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--threat-model ์˜ต์…˜์€ ์ˆœ์„œ๋Œ€๋กœ ์ฒ˜๋ฆฌ๋ฉ๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด, '--threat-model local --threat-model !environment'๋Š” 'ํ™˜๊ฒฝ' ์œ„ํ˜‘ ๋ชจ๋ธ์„ ์ œ์™ธํ•œ '๋กœ์ปฌ' ๊ทธ๋ฃน์˜ ๋ชจ๋“  ์œ„ํ˜‘ ๋ชจ๋ธ์„ ์‚ฌ์šฉํ•˜๋„๋ก ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

์ด ์˜ต์…˜์€ ์œ„ํ˜‘ ๋ชจ๋ธ์„ ์ง€์›ํ•˜๋Š” ์–ธ์–ด์—๋งŒ ์ ์šฉ๋ฉ๋‹ˆ๋‹ค.

v2.15.3๋ถ€ํ„ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์ฟผ๋ฆฌ ํ‰๊ฐ€๊ธฐ๋ฅผ ์ œ์–ดํ•˜๋Š” ์˜ต์…˜

--[no-]tuple-counting

[๊ณ ๊ธ‰] ์ฟผ๋ฆฌ ํ‰๊ฐ€๊ธฐ ๋กœ๊ทธ์— ๊ฐ ํ‰๊ฐ€ ๋‹จ๊ณ„์— ๋Œ€ํ•œ ํŠœํ”Œ ์ˆ˜๋ฅผ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค. --evaluator-log ์˜ต์…˜์ด ์ œ๊ณต๋˜๋ฉด ๋ช…๋ น์œผ๋กœ ์ƒ์„ฑ๋œ ํ…์ŠคํŠธ ๊ธฐ๋ฐ˜ ๋ฐ ๊ตฌ์กฐํ™”๋œ JSON ๋กœ๊ทธ ๋ชจ๋‘์— ํŠœํ”Œ ์ˆ˜๊ฐ€ ํฌํ•จ๋ฉ๋‹ˆ๋‹ค. (๋ณต์žกํ•œ QL ์ฝ”๋“œ์˜ ์„ฑ๋Šฅ ์ตœ์ ํ™”์— ์œ ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.)

--timeout=<seconds>

[๊ณ ๊ธ‰] ์ฟผ๋ฆฌ ํ‰๊ฐ€์— ๋Œ€ํ•œ ์‹œ๊ฐ„ ์ œํ•œ ๊ธธ์ด(์ดˆ)๋ฅผ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

์‹œ๊ฐ„ ์ œํ•œ ๊ธฐ๋Šฅ์€ ๋ณต์žกํ•œ ์ฟผ๋ฆฌ๋ฅผ ํ‰๊ฐ€ํ•˜๋Š” ๋ฐ "์˜์›ํžˆ" ๊ฑธ๋ฆฌ๋Š” ์‚ฌ๋ก€๋ฅผ ์žก์•„๋‚ด๊ธฐ ์œ„ํ•œ ๊ฒƒ์ž…๋‹ˆ๋‹ค. ์ฟผ๋ฆฌ ํ‰๊ฐ€์— ๊ฑธ๋ฆด ์ˆ˜ ์žˆ๋Š” ์ด ์‹œ๊ฐ„์„ ์ œํ•œํ•˜๋Š” ํšจ๊ณผ์ ์ธ ๋ฐฉ๋ฒ•์€ ์•„๋‹™๋‹ˆ๋‹ค. ๋ณ„๋„๋กœ ์‹œ๊ฐ„์ด ์ง€์ •๋œ ๊ฐ ๊ณ„์‚ฐ ๋ถ€๋ถ„์ด ์‹œ๊ฐ„ ์ œํ•œ ๋‚ด์— ์™„๋ฃŒ๋˜๋Š” ํ•œ ํ‰๊ฐ€๋ฅผ ๊ณ„์†ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ํ˜„์žฌ ์ด๋ ‡๊ฒŒ ๋ณ„๋„๋กœ ์‹œ๊ฐ„์ด ์ง€์ •๋œ ๋ถ€๋ถ„์€ ์ตœ์ ํ™”๋œ ์ฟผ๋ฆฌ์˜ "RA ๊ณ„์ธต"์ด์ง€๋งŒ ๋‚˜์ค‘์— ๋ณ€๊ฒฝ๋  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์‹œ๊ฐ„ ์ œํ•œ์ด ์ง€์ •๋˜์ง€ ์•Š๊ฑฐ๋‚˜ 0์œผ๋กœ ์ง€์ •๋œ ๊ฒฝ์šฐ ์‹œ๊ฐ„ ์ œํ•œ์ด ์„ค์ •๋˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค(๊ธฐ๋ณธ ์‹œ๊ฐ„ ์ œํ•œ์ด 5๋ถ„์ธ codeql test run ์ œ์™ธ).

-j, --threads=<num>

ํ•ด๋‹น ์Šค๋ ˆ๋“œ ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์ฟผ๋ฆฌ๋ฅผ ํ‰๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.

๊ธฐ๋ณธ๊ฐ’์€ 1์ž…๋‹ˆ๋‹ค. 0์„ ์ „๋‹ฌํ•˜์—ฌ ์ปดํ“จํ„ฐ์˜ ์ฝ”์–ด๋‹น ํ•˜๋‚˜์˜ ์Šค๋ ˆ๋“œ๋ฅผ ์‚ฌ์šฉํ•˜๊ฑฐ๋‚˜ -_N_์„ ์ „๋‹ฌํ•˜์—ฌ _N_๊ฐœ์˜ ์ฝ”์–ด๋ฅผ ์‚ฌ์šฉํ•˜์ง€ ์•Š์€ ์ƒํƒœ๋กœ ๋‘˜ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค(ํ•˜๋‚˜ ์ด์ƒ์˜ ์Šค๋ ˆ๋“œ๋ฅผ ๊ณ„์† ์‚ฌ์šฉํ•˜๋Š” ๊ฒฝ์šฐ ์ œ์™ธ).

--[no-]save-cache

[๊ณ ๊ธ‰] ๋””์Šคํฌ ์บ์‹œ์— ์ค‘๊ฐ„ ๊ฒฐ๊ณผ๋ฅผ ์ ๊ทน์ ์œผ๋กœ ๊ธฐ๋กํ•ฉ๋‹ˆ๋‹ค. ์‹œ๊ฐ„์ด ๋” ๋งŽ์ด ๊ฑธ๋ฆฌ๊ณ  ๋””์Šคํฌ ๊ณต๊ฐ„์ด ํ›จ์”ฌ ๋” ๋งŽ์ด ์‚ฌ์šฉ๋˜์ง€๋งŒ ์œ ์‚ฌํ•œ ์ฟผ๋ฆฌ์˜ ํ›„์† ์‹คํ–‰ ์†๋„๊ฐ€ ๋นจ๋ผ์งˆ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--[no-]expect-discarded-cache

[๊ณ ๊ธ‰] ์ฟผ๋ฆฌ๊ฐ€ ์‹คํ–‰๋œ ํ›„ ์บ์‹œ๊ฐ€ ์‚ญ์ œ๋œ๋‹ค๋Š” ๊ฐ€์ •์— ๋”ฐ๋ผ ํ‰๊ฐ€ํ•  ์กฐ๊ฑด์ž์™€ ๋””์Šคํฌ ์บ์‹œ์— ๊ธฐ๋กํ•  ๋‚ด์šฉ์„ ๊ฒฐ์ •ํ•ฉ๋‹ˆ๋‹ค.

--[no-]keep-full-cache

[๊ณ ๊ธ‰] ํ‰๊ฐ€๊ฐ€ ์™„๋ฃŒ๋œ ํ›„ ๋””์Šคํฌ ์บ์‹œ๋ฅผ ์ •๋ฆฌํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ๋‚˜์ค‘์— codeql dataset cleanup ๋˜๋Š” codeql database cleanup์„ ์ˆ˜ํ–‰ํ•˜๋ ค๋Š” ๊ฒฝ์šฐ ์‹œ๊ฐ„์ด ์ ˆ์•ฝ๋ฉ๋‹ˆ๋‹ค.

--max-disk-cache=<MB>

์ค‘๊ฐ„ ์ฟผ๋ฆฌ ๊ฒฐ๊ณผ์— ๋Œ€ํ•ด ๋””์Šคํฌ ์บ์‹œ๊ฐ€ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ์ตœ๋Œ€ ๊ณต๊ฐ„์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

์ด ํฌ๊ธฐ๊ฐ€ ๋ช…์‹œ์ ์œผ๋กœ ๊ตฌ์„ฑ๋˜์ง€ ์•Š์€ ๊ฒฝ์šฐ ํ‰๊ฐ€๊ธฐ๋Š” ๋ฐ์ดํ„ฐ ์„ธํŠธ์˜ ํฌ๊ธฐ์™€ ์ฟผ๋ฆฌ์˜ ๋ณต์žก์„ฑ์— ๋”ฐ๋ผ "ํ•ฉ๋ฆฌ์ ์ธ" ์–‘์˜ ์บ์‹œ ๊ณต๊ฐ„์„ ์‚ฌ์šฉํ•˜๋ ค๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ์ด ๊ธฐ๋ณธ ์‚ฌ์šฉ๋Ÿ‰๋ณด๋‹ค ๋†’์€ ํ•œ๋„๋ฅผ ๋ช…์‹œ์ ์œผ๋กœ ์„ค์ •ํ•˜๋ฉด ์ถ”๊ฐ€ ์บ์‹ฑ์ด ๊ฐ€๋Šฅํ•ด์ง€๋ฏ€๋กœ ์ดํ›„ ์ฟผ๋ฆฌ์˜ ์†๋„๋ฅผ ๋†’์ผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--min-disk-free=<MB>

[๊ณ ๊ธ‰] ํŒŒ์ผ ์‹œ์Šคํ…œ์—์„œ ์‚ฌ์šฉ ๊ฐ€๋Šฅํ•œ ๊ณต๊ฐ„์˜ ๋ชฉํ‘œ๋Ÿ‰์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

--max-disk-cache๊ฐ€ ์ง€์ •๋˜์ง€ ์•Š์€ ๊ฒฝ์šฐ ํŒŒ์ผ ์‹œ์Šคํ…œ์˜ ์‚ฌ์šฉ ๊ฐ€๋Šฅํ•œ ๊ณต๊ฐ„์ด ์ด ๊ฐ’ ์•„๋ž˜๋กœ ๋–จ์–ด์ง€๋ฉด ํ‰๊ฐ€๊ธฐ๋Š” ๋””์Šคํฌ ์บ์‹œ ์‚ฌ์šฉ๋Ÿ‰์„ ์ค„์ด๋ ค๊ณ  ๋…ธ๋ ฅํ•ฉ๋‹ˆ๋‹ค.

--min-disk-free-pct=<pct>

[๊ณ ๊ธ‰] ํŒŒ์ผ ์‹œ์Šคํ…œ์—์„œ ์‚ฌ์šฉ ๊ฐ€๋Šฅํ•œ ๊ณต๊ฐ„์˜ ๋ชฉํ‘œ ๋น„์œจ์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

--max-disk-cache๊ฐ€ ์ง€์ •๋˜์ง€ ์•Š์€ ๊ฒฝ์šฐ ํŒŒ์ผ ์‹œ์Šคํ…œ์˜ ์‚ฌ์šฉ ๊ฐ€๋Šฅํ•œ ๊ณต๊ฐ„์ด ์ด ๋ฐฑ๋ถ„์œจ ์•„๋ž˜๋กœ ๋–จ์–ด์ง€๋ฉด ํ‰๊ฐ€๊ธฐ๋Š” ๋””์Šคํฌ ์บ์‹œ ์‚ฌ์šฉ๋Ÿ‰์„ ์ค„์ด๋ ค๊ณ  ๋…ธ๋ ฅํ•ฉ๋‹ˆ๋‹ค.

--external=<pred>=<file.csv>

์™ธ๋ถ€ ์กฐ๊ฑด์ž <pred> ์˜ ํ–‰์„ ํฌํ•จํ•˜๋Š” CSV ํŒŒ์ผ์ž…๋‹ˆ๋‹ค. ์—ฌ๋Ÿฌ --external ์˜ต์…˜์„ ์ œ๊ณตํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--xterm-progress=<mode>

[๊ณ ๊ธ‰] xterm ์ปจํŠธ๋กค ์‹œํ€€์Šค๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ QL ํ‰๊ฐ€ ์ค‘์— ์ง„ํ–‰๋ฅ  ์ถ”์ ์„ ํ‘œ์‹œํ• ์ง€ ์—ฌ๋ถ€๋ฅผ ์ œ์–ดํ•ฉ๋‹ˆ๋‹ค. ๊ฐ€๋Šฅํ•œ ๊ฐ’์€ ๋‹ค์Œ๊ณผ ๊ฐ™์Šต๋‹ˆ๋‹ค.

no: ๋ณต์žกํ•œ ์ง„ํ–‰๋ฅ ์„ ์ƒ์„ฑํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ๋ฉ์ฒญํ•œ ํ„ฐ๋ฏธ๋„์„ ๊ฐ€์ •ํ•ฉ๋‹ˆ๋‹ค.

auto (๊ธฐ๋ณธ๊ฐ’): ๋ช…๋ น์ด ์ ์ ˆํ•œ ํ„ฐ๋ฏธ๋„์—์„œ ์‹คํ–‰๋˜๊ณ  ์žˆ๋Š”์ง€ ์—ฌ๋ถ€๋ฅผ ์ž๋™์œผ๋กœ ๊ฐ์ง€ํ•ฉ๋‹ˆ๋‹ค.

yes: ํ„ฐ๋ฏธ๋„์ด xterm ์ปจํŠธ๋กค ์‹œํ€€์Šค๋ฅผ ์ดํ•ดํ•  ์ˆ˜ ์žˆ๋‹ค๊ณ  ๊ฐ€์ •ํ•ฉ๋‹ˆ๋‹ค. ์ด ๊ธฐ๋Šฅ์€ ์—ฌ์ „ํžˆ โ€‹โ€‹ํ„ฐ๋ฏธ๋„์˜ _ํฌ๊ธฐ_๋ฅผ ์ž๋™์œผ๋กœ ๊ฐ์ง€ํ•  ์ˆ˜ ์žˆ๋Š”์ง€ ์—ฌ๋ถ€์— ๋”ฐ๋ผ ๋‹ฌ๋ผ์ง‘๋‹ˆ๋‹ค(Windows์—์„œ๋Š” ๊ตฌํ˜„๋˜์ง€ ์•Š์Œ). ๋˜ํ•œ -q๊ฐ€ ์ฃผ์–ด์ง€๋ฉด ์ด ๊ธฐ๋Šฅ์€ ๋น„ํ™œ์„ฑํ™”๋ฉ๋‹ˆ๋‹ค.

25x80 (๋˜๋Š” ์ด์™€ ์œ ์‚ฌ): yes์™€ ๊ฐ™์Šต๋‹ˆ๋‹ค. ๋˜ํ•œ ํ„ฐ๋ฏธ๋„์˜ ํฌ๊ธฐ๋ฅผ ๋ช…์‹œ์ ์œผ๋กœ ์ง€์ •ํ•ฉ๋‹ˆ๋‹ค. (yes์™€ ๋‹ฌ๋ฆฌ ์ด ๊ธฐ๋Šฅ์€ Windows์—์„œ ์ž‘๋™ํ•ฉ๋‹ˆ๋‹ค.)

25x80:/dev/pts/17 (๋˜๋Š” ์ด์™€ ์œ ์‚ฌ): stderr์™€ ๋‹ค๋ฅธ ํ„ฐ๋ฏธ๋„์—์„œ ๋ณต์žกํ•œ ์ง„ํ–‰๋ฅ ์„ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค. ์ฃผ๋กœ ๋‚ด๋ถ€ ํ…Œ์ŠคํŠธ์— ์œ ์šฉํ•ฉ๋‹ˆ๋‹ค.

๊ตฌ์กฐํ™”๋œ ํ‰๊ฐ€๊ธฐ ๋กœ๊ทธ์˜ ์ถœ๋ ฅ์„ ์ œ์–ดํ•˜๋Š” ์˜ต์…˜

--evaluator-log=<file>

[๊ณ ๊ธ‰] ํ‰๊ฐ€๊ธฐ ์„ฑ๋Šฅ์— ๋Œ€ํ•œ ๊ตฌ์กฐํ™”๋œ ๋กœ๊ทธ๋ฅผ ์ง€์ •๋œ ํŒŒ์ผ๋กœ ์ถœ๋ ฅํ•ฉ๋‹ˆ๋‹ค. ์ด ๋กœ๊ทธ ํŒŒ์ผ์˜ ํ˜•์‹์€ ์˜ˆ๊ณ  ์—†์ด ๋ณ€๊ฒฝ๋  ์ˆ˜ ์žˆ์ง€๋งŒ ๋‘ ๊ฐœ์˜ ์ค„ ๋ฐ”๊ฟˆ ๋ฌธ์ž(๊ธฐ๋ณธ๊ฐ’) ๋˜๋Š” --evaluator-log-minify ์˜ต์…˜์ด ์ „๋‹ฌ๋œ ๊ฒฝ์šฐ ํ•˜๋‚˜์˜ ๊ธฐ๋ณธ๊ฐ’ ๋ฌธ์ž๋กœ ๊ตฌ๋ถ„๋œ JSON ๊ฐœ์ฒด ์ŠคํŠธ๋ฆผ์ž…๋‹ˆ๋‹ค. codeql generate log-summary <file>์„(๋ฅผ) ์‚ฌ์šฉํ•˜์—ฌ ์ด ํŒŒ์ผ์— ๋Œ€ํ•œ ๋ณด๋‹ค ์•ˆ์ •์ ์ธ ์š”์•ฝ์„ ์ƒ์„ฑํ•˜๊ณ  ํŒŒ์ผ์„ ์ง์ ‘ ๊ตฌ๋ฌธ ๋ถ„์„ํ•˜์ง€ ๋งˆ์‹ญ์‹œ์˜ค. ํŒŒ์ผ์ด ์ด๋ฏธ ์žˆ์œผ๋ฉด ๋ฎ์–ด์”๋‹ˆ๋‹ค.

--evaluator-log-minify

[๊ณ ๊ธ‰] --evaluator-log ์˜ต์…˜์„ ์ „๋‹ฌํ•˜๋Š” ๊ฒฝ์šฐ ์ด ์˜ต์…˜๋„ ์ „๋‹ฌํ•˜๋ฉด ์ƒ์„ฑ๋˜๋Š” JSON ๋กœ๊ทธ์˜ ํฌ๊ธฐ๊ฐ€ ์ตœ์†Œํ™”๋˜์ง€๋งŒ ๊ฐ€๋…์„ฑ์ด ํ›จ์”ฌ ๋–จ์–ด์ง‘๋‹ˆ๋‹ค.

QL ์ปดํŒŒ์ผ์„ ์ œ์–ดํ•˜๋Š” ์˜ต์…˜

--warnings=<mode>

QL ์ปดํŒŒ์ผ๋Ÿฌ์—์„œ ๊ฒฝ๊ณ ๋ฅผ ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ๋ฒ•์ž…๋‹ˆ๋‹ค. ๋‹ค์Œ ์ค‘ ํ•˜๋‚˜์ž…๋‹ˆ๋‹ค.

hide: ๊ฒฝ๊ณ ๋ฅผ ํ‘œ์‹œํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

show (๊ธฐ๋ณธ๊ฐ’): ๊ฒฝ๊ณ ๋ฅผ ์ถœ๋ ฅํ•˜์ง€๋งŒ ์ปดํŒŒ์ผ์„ ๊ณ„์†ํ•ฉ๋‹ˆ๋‹ค.

error: ๊ฒฝ๊ณ ๋ฅผ ์˜ค๋ฅ˜๋กœ ์ฒ˜๋ฆฌํ•ฉ๋‹ˆ๋‹ค.

--no-debug-info

๋””๋ฒ„๊น…์„ ์œ„ํ•ด RA์—์„œ ์›๋ณธ ์œ„์น˜ ์ •๋ณด๋ฅผ ๋‚ด๋ณด๋‚ด์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

--[no-]fast-compilation

[์‚ฌ์šฉ๋˜์ง€ ์•Š์Œ] [๊ณ ๊ธ‰] ํŠนํžˆ ๋А๋ฆฐ ์ตœ์ ํ™” ๋‹จ๊ณ„๋ฅผ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค.

--no-release-compatibility

[๊ณ ๊ธ‰] ์ด์‹์„ฑ์„ ํฌ์ƒํ•˜๊ณ  ์ตœ์‹  ์ปดํŒŒ์ผ๋Ÿฌ ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

๋•Œ๋•Œ๋กœ QL ํ‰๊ฐ€๊ธฐ๋Š” ์ƒˆ๋กœ์šด QL ์–ธ์–ด ๊ธฐ๋Šฅ ๋ฐ ํ‰๊ฐ€๊ธฐ ์ตœ์ ํ™”๋ฅผ QL ์ปดํŒŒ์ผ๋Ÿฌ๊ฐ€ ๊ธฐ๋ณธ์ ์œผ๋กœ ์‚ฌ์šฉํ•˜๊ธฐ ์ „์— ๋ช‡๋ช‡ ๋ฆด๋ฆฌ์Šค์—์„œ ์ง€์›ํ•ฉ๋‹ˆ๋‹ค. ์ด๋ ‡๊ฒŒ ํ•˜๋ฉด ์ตœ์‹  CodeQL ๋ฆด๋ฆฌ์Šค์—์„œ ์ฟผ๋ฆฌ๋ฅผ ๊ฐœ๋ฐœํ•  ๋•Œ ๊ฒฝํ—˜ํ•˜๋Š” ์„ฑ๋Šฅ์ด ์ฝ”๋“œ ๊ฒ€์‚ฌ ๋˜๋Š” CI ํ†ตํ•ฉ์— ์•„์ง ์‚ฌ์šฉ ์ค‘์ผ ์ˆ˜ ์žˆ๋Š” ์•ฝ๊ฐ„ ์ด์ „ ๋ฆด๋ฆฌ์Šค์™€ ์ผ์น˜ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์ฟผ๋ฆฌ๊ฐ€ ๋‹ค๋ฅธ(์ด์ „ ๋˜๋Š” ์ดํ›„) CodeQL ๋ฆด๋ฆฌ์Šค์™€ ํ˜ธํ™˜๋˜๋Š” ๊ฒƒ์— ์‹ ๊ฒฝ ์“ฐ์ง€ ์•Š๋Š” ๊ฒฝ์šฐ ์ด ํ”Œ๋ž˜๊ทธ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์ปดํŒŒ์ผ๋Ÿฌ์˜ ์ตœ๊ทผ ๊ฐœ์„  ์‚ฌํ•ญ์„ ์กฐ๊ธฐ์— ์‚ฌ์šฉํ•˜๋„๋ก ์„ค์ •ํ•˜๊ณ  ์•ฝ๊ฐ„์˜ ์ถ”๊ฐ€ ์„ฑ๋Šฅ์„ ์–ป์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ์ตœ๊ทผ ๊ฐœ์„  ์‚ฌํ•ญ์ด ์—†๋Š” ๋ฆด๋ฆฌ์Šค์—์„œ ์ด ์˜ต์…˜์€ ์ž๋™์œผ๋กœ ์•„๋ฌด ์ž‘์—…๋„ ์ˆ˜ํ–‰ํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ ์ „์—ญ CodeQL ๊ตฌ์„ฑ ํŒŒ์ผ์—์„œ ํ•œ ๋ฒˆ๋งŒ ์„ค์ •ํ•ด๋„ ์•ˆ์ „ํ•ฉ๋‹ˆ๋‹ค.

v2.11.1๋ถ€ํ„ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--[no-]local-checking

์‚ฌ์šฉ๋˜๋Š” QL ์›๋ณธ ๋ถ€๋ถ„์—์„œ๋งŒ ์ดˆ๊ธฐ ๊ฒ€์‚ฌ๋ฅผ ์ˆ˜ํ–‰ํ•ฉ๋‹ˆ๋‹ค.

--no-metadata-verification

QLDoc ์ฃผ์„์— ํฌํ•จ๋œ ์ฟผ๋ฆฌ ๋ฉ”ํƒ€๋ฐ์ดํ„ฐ์˜ ์œ ํšจ์„ฑ์„ ๊ฒ€์‚ฌํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

--compilation-cache-size=<MB>

[๊ณ ๊ธ‰] ์ปดํŒŒ์ผ ์บ์‹œ ๋””๋ ‰ํ„ฐ๋ฆฌ์˜ ๊ธฐ๋ณธ ์ตœ๋Œ€ ํฌ๊ธฐ๋ฅผ ์žฌ์ •์˜ํ•ฉ๋‹ˆ๋‹ค.

--fail-on-ambiguous-relation-name

[๊ณ ๊ธ‰] ์ปดํŒŒ์ผ ์ค‘์— ๋ชจํ˜ธํ•œ ๊ด€๊ณ„ ์ด๋ฆ„์ด ์ƒ์„ฑ๋˜๋ฉด ์ปดํŒŒ์ผ์— ์‹คํŒจํ•ฉ๋‹ˆ๋‹ค.

์ปดํŒŒ์ผ ํ™˜๊ฒฝ์„ ์„ค์ •ํ•˜๋Š” ์˜ต์…˜

--search-path=<dir>[:<dir>...]

QL ํŒฉ์„ ์ฐพ์„ ์ˆ˜ ์žˆ๋Š” ๋””๋ ‰ํ„ฐ๋ฆฌ ๋ชฉ๋ก์ž…๋‹ˆ๋‹ค. ๊ฐ ๋””๋ ‰ํ„ฐ๋ฆฌ๋Š” QL ํŒฉ(๋˜๋Š” ๋ฃจํŠธ์— .codeqlmanifest.json ํŒŒ์ผ์ด ํฌํ•จ๋œ ํŒฉ ๋ฒˆ๋“ค) ๋˜๋Š” ๊ทธ๋Ÿฌํ•œ ๋””๋ ‰ํ„ฐ๋ฆฌ ํ•˜๋‚˜ ์ด์ƒ์˜ ์ง๊ณ„ ๋ถ€๋ชจ์ผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๊ฒฝ๋กœ์— ๋‘˜ ์ด์ƒ์˜ ๋””๋ ‰ํ„ฐ๋ฆฌ๊ฐ€ ํฌํ•จ๋œ ๊ฒฝ์šฐ ๋””๋ ‰ํ„ฐ๋ฆฌ์˜ ์ˆœ์„œ๊ฐ€ ์šฐ์„  ์ˆœ์œ„๋ฅผ ์ •์˜ํ•ฉ๋‹ˆ๋‹ค. ํ™•์ธํ•ด์•ผ ํ•˜๋Š” ํŒฉ ์ด๋ฆ„์ด ๋””๋ ‰ํ„ฐ๋ฆฌ ํŠธ๋ฆฌ ์ค‘ ๋‘˜ ์ด์ƒ์—์„œ ์ผ์น˜ํ•˜๋Š” ๊ฒฝ์šฐ ๋จผ์ € ์ง€์ •๋œ ๋””๋ ‰ํ„ฐ๋ฆฌ๊ฐ€ ์šฐ์„ ํ•ฉ๋‹ˆ๋‹ค.

์˜คํ”ˆ ์†Œ์Šค CodeQL ๋ฆฌํฌ์ง€ํ† ๋ฆฌ์˜ ์ฒดํฌ ์•„์›ƒ์—์„œ ์ด๋ฅผ ๊ฐ€๋ฆฌํ‚ค๋ฉด ํ•ด๋‹น ๋ฆฌํฌ์ง€ํ† ๋ฆฌ์— ์žˆ๋Š” ์–ธ์–ด ์ค‘ ํ•˜๋‚˜๋ฅผ ์ฟผ๋ฆฌํ•  ๋•Œ ์ž‘๋™ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

์••์ถ•์„ ํ‘ผ CodeQL ํˆด์ฒด์ธ์˜ ํ˜•์ œ๋กœ CodeQL ๋ฆฌํฌ์ง€ํ† ๋ฆฌ๋ฅผ ์ฒดํฌ ์•„์›ƒํ•œ ๊ฒฝ์šฐ ์ด ์˜ต์…˜์„ ์ง€์ •ํ•  ํ•„์š”๊ฐ€ ์—†์Šต๋‹ˆ๋‹ค. ์ด๋Ÿฌํ•œ ํ˜•์ œ ๋””๋ ‰ํ„ฐ๋ฆฌ๋Š” ๋‹ค๋ฅธ ๋ฐฉ๋ฒ•์œผ๋กœ๋Š” ์ฐพ์„ ์ˆ˜ ์—†๋Š” QL ํŒฉ์œผ๋กœ ํ•ญ์ƒ ๊ฒ€์ƒ‰๋ฉ๋‹ˆ๋‹ค. (์ด ๊ธฐ๋ณธ๊ฐ’์ด ์ž‘๋™ํ•˜์ง€ ์•Š๋Š” ๊ฒฝ์šฐ ์‚ฌ์šฉ์ž๋ณ„ ๊ตฌ์„ฑ ํŒŒ์ผ์—์„œ --search-path๋ฅผ ํ•œ ๋ฒˆ๋งŒ ์„ค์ •ํ•˜๋Š” ๊ฒƒ์ด ์ข‹์Šต๋‹ˆ๋‹ค).

(์ฐธ๊ณ : Windows์—์„œ๋Š” ๊ฒฝ๋กœ ๊ตฌ๋ถ„ ๊ธฐํ˜ธ๊ฐ€ ;์ž…๋‹ˆ๋‹ค.)

--additional-packs=<dir>[:<dir>...]

์ด ๋””๋ ‰ํ„ฐ๋ฆฌ ๋ชฉ๋ก์ด ์ง€์ •๋œ ๊ฒฝ์šฐ --search-path์— ์žˆ๋Š” ๋””๋ ‰ํ„ฐ๋ฆฌ๋ณด๋‹ค ๋จผ์ € ํŒฉ์ด ๊ฒ€์ƒ‰๋ฉ๋‹ˆ๋‹ค. ์ด ์‚ฌ์ด์˜ ์ˆœ์„œ๋Š” ์ค‘์š”ํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ์ด ๋ชฉ๋ก์„ ํ†ตํ•ด ์„œ๋กœ ๋‹ค๋ฅธ ๋‘ ์œ„์น˜์—์„œ ํŒฉ ์ด๋ฆ„์„ ์ฐพ์„ ๊ฒฝ์šฐ ์˜ค๋ฅ˜๊ฐ€ ๋ฐœ์ƒํ•ฉ๋‹ˆ๋‹ค.

์ด ๊ธฐ๋Šฅ์€ ๊ธฐ๋ณธ ๊ฒฝ๋กœ์—๋„ ํ‘œ์‹œ๋˜๋Š” ํŒฉ์˜ ์ƒˆ ๋ฒ„์ „์„ ์ผ์‹œ์ ์œผ๋กœ ๊ฐœ๋ฐœํ•˜๋Š” ๊ฒฝ์šฐ์— ์œ ์šฉํ•ฉ๋‹ˆ๋‹ค. ๋ฐ˜๋ฉด์— ๊ตฌ์„ฑ ํŒŒ์ผ์—์„œ ์ด ์˜ต์…˜์„ ์žฌ์ •์˜ํ•˜๋Š” ๊ฒƒ์€ ๊ถŒ์žฅ๋˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ์ผ๋ถ€ ๋‚ด๋ถ€ ์ž‘์—…์—์„œ๋Š” ๊ตฌ์„ฑ๋œ ๊ฐ’์„ ์žฌ์ •์˜ํ•˜์—ฌ ์ฆ‰์‹œ ์ด ์˜ต์…˜์„ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.

(์ฐธ๊ณ : Windows์—์„œ๋Š” ๊ฒฝ๋กœ ๊ตฌ๋ถ„ ๊ธฐํ˜ธ๊ฐ€ ;์ž…๋‹ˆ๋‹ค.)

--library-path=<dir>[:<dir>...]

[๊ณ ๊ธ‰] QL ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์˜ ์›์‹œ ๊ฐ€์ ธ์˜ค๊ธฐ ๊ฒ€์ƒ‰ ๊ฒฝ๋กœ์— ์ถ”๊ฐ€๋  ์„ ํƒ์  ๋””๋ ‰ํ„ฐ๋ฆฌ ๋ชฉ๋ก์ž…๋‹ˆ๋‹ค. QL ํŒฉ์œผ๋กœ ํŒจํ‚ค์ง€๋˜์ง€ ์•Š์€ QL ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ์‚ฌ์šฉํ•˜๋ ค๋Š” ๊ฒฝ์šฐ์—๋งŒ ์‚ฌ์šฉํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

(์ฐธ๊ณ : Windows์—์„œ๋Š” ๊ฒฝ๋กœ ๊ตฌ๋ถ„ ๊ธฐํ˜ธ๊ฐ€ ;์ž…๋‹ˆ๋‹ค.)

--dbscheme=<file>

[๊ณ ๊ธ‰] ์ปดํŒŒ์ผํ•ด์•ผ ํ•˜๋Š” dbscheme ์ฟผ๋ฆฌ๋ฅผ ๋ช…์‹œ์ ์œผ๋กœ ์ •์˜ํ•ฉ๋‹ˆ๋‹ค. ์ž์‹ ์ด ์ˆ˜ํ–‰ํ•˜๊ณ  ์žˆ๋Š” ์ž‘์—…์— ๋Œ€ํ•ด ๋งค์šฐ ํ™•์‹ ํ•˜๋Š” ํ˜ธ์ถœ์ž์— ์˜ํ•ด์„œ๋งŒ ์ง€์ •๋˜์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

--compilation-cache=<dir>

[๊ณ ๊ธ‰] ์ปดํŒŒ์ผ ์บ์‹œ๋กœ ์‚ฌ์šฉํ•  ์ถ”๊ฐ€ ๋””๋ ‰ํ„ฐ๋ฆฌ๋ฅผ ์ง€์ •ํ•ฉ๋‹ˆ๋‹ค.

--no-default-compilation-cache

[๊ณ ๊ธ‰] ์ฟผ๋ฆฌ๋ฅผ ํฌํ•จํ•˜๋Š” QL ํŒฉ ๋˜๋Š” CodeQL ํˆด์ฒด์ธ ๋””๋ ‰ํ„ฐ๋ฆฌ์™€ ๊ฐ™์€ ํ‘œ์ค€ ์œ„์น˜์—์„œ ์ปดํŒŒ์ผ ์บ์‹œ๋ฅผ ์‚ฌ์šฉํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

CodeQL ํŒจํ‚ค์ง€ ๊ด€๋ฆฌ์ž๋ฅผ ๊ตฌ์„ฑํ•˜๋Š” ์˜ต์…˜

--registries-auth-stdin

์‰ผํ‘œ๋กœ ๊ตฌ๋ถ„๋œ <registry_url>=<token> ์Œ ๋ชฉ๋ก์„ ์ „๋‹ฌํ•˜์—ฌ GitHub Enterprise Server ์ปจํ…Œ์ด๋„ˆ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์— ์ธ์ฆํ•ฉ๋‹ˆ๋‹ค.

์˜ˆ๋ฅผ ๋“ค์–ด https://containers.GHEHOSTNAME1/v2/=TOKEN1,https://containers.GHEHOSTNAME2/v2/=TOKEN2๋ฅผ ์ „๋‹ฌํ•˜์—ฌ ๋‘ ๊ฐœ์˜ GitHub Enterprise Server ์ธ์Šคํ„ด์Šค์— ์ธ์ฆํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์ด๋ ‡๊ฒŒ ํ•˜๋ฉด CODEQL_REGISTRIES_AUTH ๋ฐ GITHUB_TOKEN ํ™˜๊ฒฝ ๋ณ€์ˆ˜๊ฐ€ ์žฌ์ •์˜๋ฉ๋‹ˆ๋‹ค. github.com ์ปจํ…Œ์ด๋„ˆ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์—๋งŒ ์ธ์ฆํ•ด์•ผ ํ•˜๋Š” ๊ฒฝ์šฐ ๋” ๊ฐ„๋‹จํ•œ --github-auth-stdin ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์—ฌ ์ธ์ฆํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

--github-auth-stdin

ํ‘œ์ค€ ์ž…๋ ฅ์„ ํ†ตํ•ด github.com์— GitHub Apps ํ† ํฐ ๋˜๋Š” ๊ฐœ์ธ์šฉ ์•ก์„ธ์Šค ํ† ํฐ์„ ์ „๋‹ฌํ•˜์—ฌ github.com ์ปจํ…Œ์ด๋„ˆ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์— ์ธ์ฆํ•ฉ๋‹ˆ๋‹ค.

GitHub Enterprise Server ์ปจํ…Œ์ด๋„ˆ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์— ์ธ์ฆํ•˜๋ ค๋ฉด --registries-auth-stdin์„ ์ „๋‹ฌํ•˜๊ฑฐ๋‚˜ CODEQL_REGISTRIES_AUTH ํ™˜๊ฒฝ ๋ณ€์ˆ˜๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

์ด๋ ‡๊ฒŒ ํ•˜๋ฉด GITHUB_TOKEN ํ™˜๊ฒฝ ๋ณ€์ˆ˜๊ฐ€ ์žฌ์ •์˜๋ฉ๋‹ˆ๋‹ค.

์ผ๋ฐ˜ ์˜ต์…˜

-h, --help

์ด ๋„์›€๋ง ํ…์ŠคํŠธ๋ฅผ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค.

-J=<opt>

[๊ณ ๊ธ‰] ๋ช…๋ น์„ ์‹คํ–‰ํ•˜๋Š” JVM์— ์˜ต์…˜์„ ์ง€์ •ํ•ฉ๋‹ˆ๋‹ค.

(๊ณต๋ฐฑ์„ ํฌํ•จํ•˜๋Š” ์˜ต์…˜์€ ์˜ฌ๋ฐ”๋ฅด๊ฒŒ ์ฒ˜๋ฆฌ๋˜์ง€ ์•Š์„ ์ˆ˜ ์žˆ์œผ๋‹ˆ ์ฃผ์˜ํ•˜์„ธ์š”.)

-v, --verbose

์ถœ๋ ฅ๋˜๋Š” ์ง„ํ–‰๋ฅ  ๋ฉ”์‹œ์ง€ ์ˆ˜๋ฅผ ์ ์ง„์ ์œผ๋กœ ๋Š˜๋ฆฝ๋‹ˆ๋‹ค.

-q, --quiet

์ถœ๋ ฅ๋˜๋Š” ์ง„ํ–‰๋ฅ  ๋ฉ”์‹œ์ง€ ์ˆ˜๋ฅผ ์ ์ง„์ ์œผ๋กœ ์ค„์ž…๋‹ˆ๋‹ค.

--verbosity=<level>

[๊ณ ๊ธ‰] ์„ธ๋ถ€ ์ •๋ณด ํ‘œ์‹œ ์ˆ˜์ค€์„ ์˜ค๋ฅ˜, ๊ฒฝ๊ณ , ์ง„ํ–‰๋ฅ , ์ง„ํ–‰๋ฅ +, ์ง„ํ–‰๋ฅ ++, ์ง„ํ–‰๋ฅ +++ ์ค‘ ํ•˜๋‚˜๋กœ ๋ช…์‹œ์ ์œผ๋กœ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. -v ๋ฐ -q๋ฅผ ์žฌ์ •์˜ํ•ฉ๋‹ˆ๋‹ค.

--logdir=<dir>

[๊ณ ๊ธ‰] ํƒ€์ž„์Šคํƒฌํ”„์™€ ์‹คํ–‰ ์ค‘์ธ ํ•˜์œ„ ๋ช…๋ น์˜ ์ด๋ฆ„์„ ํฌํ•จํ•˜๋Š” ์ƒ์„ฑ๋œ ์ด๋ฆ„์„ ์‚ฌ์šฉํ•˜์—ฌ ์ง€์ •๋œ ๋””๋ ‰ํ„ฐ๋ฆฌ์— ์žˆ๋Š” ํ•˜๋‚˜ ์ด์ƒ์˜ ํŒŒ์ผ์— ์ž์„ธํ•œ ๋กœ๊ทธ๋ฅผ ๊ธฐ๋กํ•ฉ๋‹ˆ๋‹ค.

(๋ชจ๋“  ๊ถŒํ•œ์„ ๊ฐ€์ง„ ์ด๋ฆ„์œผ๋กœ ๋กœ๊ทธ ํŒŒ์ผ์„ ์ž‘์„ฑํ•˜๋ ค๋ฉด --log-to-stderr์„(๋ฅผ) ์ง€์ •ํ•˜๊ณ  stderr๋ฅผ ์›ํ•˜๋Š” ๋Œ€๋กœ ๋ฆฌ๋””๋ ‰์…˜ํ•ฉ๋‹ˆ๋‹ค.)

--common-caches=<dir>

[๊ณ ๊ธ‰] ๋‹ค์šด๋กœ๋“œํ•œ QL ํŒฉ ๋ฐ ์ปดํŒŒ์ผ๋œ ์ฟผ๋ฆฌ ๊ณ„ํš๊ณผ ๊ฐ™์ด ์—ฌ๋Ÿฌ CLI ์‹คํ–‰ ๊ฐ„์— ์œ ์ง€๋˜๋Š” ๋””์Šคํฌ์˜ ์บ์‹œ๋œ ๋ฐ์ดํ„ฐ์˜ ์œ„์น˜๋ฅผ ์ œ์–ดํ•ฉ๋‹ˆ๋‹ค. ๋ช…์‹œ์ ์œผ๋กœ ์„ค์ •ํ•˜์ง€ ์•Š์€ ๊ฒฝ์šฐ ์ด ๊ธฐ๋ณธ๊ฐ’์€ ์‚ฌ์šฉ์ž์˜ ํ™ˆ ๋””๋ ‰ํ„ฐ๋ฆฌ์— ์ด๋ฆ„์ด ์ง€์ •๋œ .codeql ๋””๋ ‰ํ„ฐ๋ฆฌ๋กœ ์„ค์ •๋˜๋ฉฐ, ์•„์ง ์—†๋Š” ๊ฒฝ์šฐ ๋งŒ๋“ค์–ด์ง‘๋‹ˆ๋‹ค.

v2.15.2๋ถ€ํ„ฐ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.