당신의 첫번째 익스텐션
이번 주제에서는, 익스텐션을 만들기 위한 기본 컨셉에 대해 설명합니다. Node.js 와 Git을 먼저 설치 한 다음, Yeoman 과 VS Code Extension Generator가 정상적으로 설치 되어 있는지 확인해주십시오.
npm install -g yo generator-code
generator로 타입스크립트나 자바스크립트 프로젝트의 틀을 만들어 개발을 준비합니다. generator를 실행하고 TypeScript project를 위한 몇 필드를 채우십시오:
yo code
# ? What type of extension do you want to create? New Extension (TypeScript)
# ? What's the name of your extension? HelloWorld
### Press <Enter> to choose default for all options below ###
# ? What's the identifier of your extension? helloworld
# ? What's the description of your extension? LEAVE BLANK
# ? Initialize a git repository? Yes
# ? Which package manager to use? npm
code ./helloworld
다음으로 에디터 안에서, kb(workbench.action.debug.start)
를 누르면 새로운 Extension Development Host 창에서 익스텐션을 컴파일, 실행 할 수 있습니다.
Hello World
커맨드를 새 창의 Command Palette (kb(workbench.action.showCommands)
)에서 실행합니다:
Hello World
알림이 뜨는걸 볼 수 있습니다. 성공했습니다 !
익스텐션 개발
메시지에 변화를 만들어봅시다:
extension.ts
파일에서 메시지를Hello World
에서Hello VS Code
로 바꾸십시오.- 새 창에서
Reload Window
를 실행합니다. Hello World
커맨드를 다시 실행합니다.
업데이트된 메시지가 올라오는걸 볼 수 있습니다.
여기 몇 가지 시도 해볼만한 아이디어가 있습니다:
- Command Palette 에서
Hello World
커맨드에 새 이름을 주십시오. - 정보 창에 현재 시간을 표기해주는 다른 커맨드에 Contribute 하십시오.
vscode.window.showInformationMessage
를 다른 VS Code API 로 교체해서 경고 메시지를 띄워주십시오.
디버깅 익스텐션
VS Code의 자체 디버깅 기능으로 익스텐션을 쉽게 디버그 할 수 있습니다. 라인 옆을 클릭해서 VS Code가 멈추게 될 breakpoint 를 설정할 수 있습니다. 에디터에서 변수 위에 마우스를 올리거나, 왼쪽의 Debug View를 사용해서 변수의 값을 확인 할 수 있습니다. 디버그 콘솔로 expression을 계산 할 수 있습니다.
VS Code 에서 Node.js 앱 디버깅하는걸 Node.js Debugging Topic에서 더 알아볼 수 있습니다.
다음 단계
다음 Extension Anatomy주제에서는, Hello World
예제의 소스 코드를 더 자세히 보고, 주요 컨셉들을 설명합니다.
이번 튜토리얼의 소스 코드는 https://github.com/Microsoft/vscode-extension-samples/tree/master/helloworld-sample 에서 확인 할 수 있습니다. Extension Guides주제에서는, 각각 다른 VS Code API 혹은 Contribution Point를 설명하는 다른 예제들을 포함하고 있습니다.
자바스크립트의 경우
저희는 타입스크립트가 VS Code 익스텐션을 개발할 때 있어서 가장 좋은 경험을 준다고 믿기 때문에, 이 가이드에서 VS Code 익스텐션을 타입스크립트로 개발하는 방법 위주로 기술했습니다. 하지만 만약 자바스크립트를 선호 한다면, helloworld-minimal-sample 를 통해 계속 진행하십시오.