[[oktatas:programozás:java:java_fejlesztői_környezet_kialakítása|< Java fejlesztő környezet kialakítása]] ====== Java - Visual Studio Code ====== * **Szerző:** Sallai András * Copyright (c) 2021, Sallai András * Szerkesztve: 2021-2024 * Licenc: [[https://creativecommons.org/licenses/by-sa/4.0/|CC Attribution-Share Alike 4.0 International]] * Web: https://szit.hu ===== Bevezetés ===== A Visual Studio Code, néha röviden VSCode, egy nyílt forráskódú szövegszerkesztő. A Programozás > Programok névtérben is van egy Visual Studo Code leírás: * [[oktatas:programozas:programok:visual_studio_code|Visual Studo Code]] ===== Telepítés ===== Töltsük le az alábbi helyről: * https://code.visualstudio.com/ ===== Felület ===== {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:visual_studio_code.png?400|}} Az oldalsáv **nézeteket** tartalmazhat. Az EXPLORER estén alapértelmezetten a következő nézetek jelennek meg: * > APP01 - könyvtár nézet - a megnyitott projekt könyvtár neve jelenik meg * > OUTLINE * > TIMELINE Ha megnyitunk egy .java kiterjesztésű állományt, akkor lesz egy JAVA PROJECTS nézetünk is: * > JAVA PROJECTS {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:explorer_views.png|}} A nézetek a ">" karakterre (ikonra) kattintva lenyithatók. ===== Java projects nézet ===== {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:vscode_java_projects_view_labels.png|}} ===== Bővítmények ===== ==== Microsoft megoldások ==== * Project Manager for Java * Language Support for Java(TM) by Red Hat * Debugger for Java (ez kell a lejátszógomb megjelenéséhez .java fájloknál) * Maven for Java * Test Runner for Java Az Extension Pack tartalmazza mindezeket: * Extension Pack for Java * Plusz még: * Visual Studio IntelliCode Teszteléshez opcionálisan letölthető még: * JUnit JAR Downloader ==== Oracle megoldás ==== A bővítmény neve egyszerűen Java: * Java Előbb be kell állítani a Java helyét. Tegyük fel, hogy a Java a következő helyen található: * /usr/lib/jvm/java-17-openjdk-amd64/ * Settings * jdk: Jdkhome Új projekt kezdése: * Java: New Project... ===== Java ===== A Visual Studio Code képes használni az előtelepített Java keretrendszereket, de le is tudja azokat tölteni. Java JDK az Oracle-től: * https://www.oracle.com/java/technologies/javase-downloads.html ==== Java JDK választás ==== Hívjuk meg a VSCode parancspaneljét, például az F1 billentyűvel, majd keressük meg: * Java: Configure Java Runtime Ott kattintsunk a ceruza ikonra: {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:select_java-jdk.png|}} Láthatóvá válnak a telepített Java JDK verziók: {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:select_java-jdk_2.png|}} Válasszuk ki a kívánt változatot. Ellenőrzésként írassuk ki milyen Java verzióval működik a megírt programunk: * [[oktatas:programozas:java:java_nyelv_jellemzok#a_java_verzio_kiiratasa|Java verzió kiíratása]] ==== Java választás tárolása ==== A beállítás a következő helyen tárolódik Windowson: * c:\Users\janos\AppData\Roaming\Code\User\settings.json Linuxon: * /home/janos/.config/Code/User/settings.json Lehetséges tartalom: { "window.zoomLevel": 2, "java.configuration.runtimes": [ { "name": "JavaSE-17", "path": "C:\\Program Files\\Java\\jdk-17.0.2", "default": true }, { "name": "JavaSE-1.8", "path": "C:\\Program Files\\Java\\jdk1.8.0_211" } ] } ===== Projekt kezdés ===== * View > Command Palette... * Kezdjük el írni: * Java: Create Java Project... * Lehetőségek * No build tools * Maven * Gradle * Spring Boot * Quarkus * MicroProfile * JavaFX * Micronaut * Graal Gloud Native Az egyes lehetőségekhez megfelelő bővítmény lehet szükséges. ===== Tesztelés ===== Bővítmény: * JUnit JAR Downloader * View > Command Palette... * Kezdjük el írni: * JUnit * Kiválasztjuk: Download JUnit JAR files * Megkérdezi, hova szeretnénk letölteni. Alapértelmezés: * lib * Csak nyomjunk egy Enter-t. Ez fel is veszi a használható könyvtárak közzé. Vegyük fel a test könyvtárat a forráskönyvtárak közzé. Szerkesszük a .vscode/settings.json { "java.project.sourcePaths": ["src", "test"], "java.project.outputPath": "bin" } A tesztosztály és a tesztmetódus tetszőleges nevű lehet. import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; class AppValami { @Test public void calcAreaAssertion() { assertEquals(525.0, App.calcArea(30, 35 )); } } Futtatáshoz az akciósávon kémcső. További tesztírás: * https://junit.org/junit5/docs/current/user-guide/#writing-tests-assertions (2021) ===== Beállítások törlése ===== rm ~/.config/Code/User/ Windows PowerShell: rm C:\Users\user\AppData\Roaming\Code\User\ ===== GitHub kijelentkezés ===== * Akciósáv > Accounts > janos (GitHub) > Sign Out ===== GitHub VSCode-ban ===== A GitHub VSCode-ban való használatához telepíteni kell a következő bővítményt: * GitHub Pull Request and Issues Forrás: https://code.visualstudio.com/docs/sourcecontrol/github (2023) ===== Automatikus mentés ===== Az automatikus mentés ki/be kapcsolása: * Ctrl + Shift + P (Vagy F1) * File: Toggle Auto Save ===== Újratervezés ===== * F2 Az F2 helyzetérzékeny. Az oldalsávon az EXPLORER-ben használhatjuk a kijelölt fájlok és könyvtárak átnevezésre. A szerkesztőben, különböző szimbólumokra állva (változók, metódusok stb) azok átnevezése kezdeményezhető. ===== JAR fájl készítés ===== Az oldalsávon, kinyitjuk a Java project összetevőt: * JAVA PROJECTS Az egeret ezen rész felé viszem. Ekkor megjelenik egy ehhez hasonló alakzat: |-> Jobbra mutató nyíl talppal. Ekkor megkérdezi, melyik a fő osztály, és készül a .jar fájl a projekt gyökér könyvtárában. {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:jar_keszites.png?400|}} ===== Code Runner ===== A Code Runner egy bővítmény, amely lehetővé teszi többféle programozási nyelven készült program futtatását, ha csak egy fájl van önmagában projekt nélkül. Néha zavaró lehet ha projektet készítőt is használunk. 2023-10-08-i kiadás a következő nyelveket támogatja: C, C++, Java, JavaScript, PHP, Python, Perl, Perl 6, Ruby, Go, Lua, Groovy, PowerShell, BAT/CMD, BASH/SH, F# Script, F# (.NET Core), C# Script, C# (.NET Core), VBScript, TypeScript, CoffeeScript, Scala, Swift, Julia, Crystal, OCaml Script, R, AppleScript, Elixir, Visual Basic .NET, Clojure, Haxe, Objective-C, Rust, Racket, Scheme, AutoHotkey, AutoIt, Kotlin, Dart, Free Pascal, Haskell, Nim, D, Lisp, Kit, V, SCSS, Sass, CUDA, Less, Fortran, Ring, Standard ML, Zig, Mojo ===== Debug ===== Legyen telepítve a "Debugger for Java" bővítmény. Írjunk egy rövid kódot: public class App { public static void main(String[] args) { String a = "valami"; System.out.println(a); } } A public static felett megjelenik két szöveg, ami nem a kód része. A VSCode része: Run | Debug Kattintsunk a Debug-ra. ===== Formázás mentéskor ===== Ne rendezze egy sorba a forráskódot: A VSCode beállításainál: * [ ] Format On Save ===== Forráskód formázása ===== Bővítmény: * Prettier A parancspanelon kezdjük el írni: Format Két lehetőségünk lesz: * Format Document * Format Selection ===== Maven projekt ===== **Archetype** alatt, **alkalmazás sablont** értünk. Az első helyeken két archetype található: * no archetype * archetype quickstart Ha archetype quickstart-t választunk egy Java projekt létrehozása során, a VSCode rákérdez a projekt több tulajdonságára is. Nélküle csak a csomag nevét kérdezi meg, a projekt helye és neve mellett. Egy minimális pom.xml jön létre. ==== Sablon használata ==== Szükséges bővítmény: * Maven for Java * Project Manager for Java Ha telepítve van a Code Runner, érdemes letiltani. Projekt létrehozása: - Parancs panel indítása (Ctrl+Shift+p) - Elkezdjük írni: Java - Választás: **Maven** create from archetype - Választás: maven-archetype-quickstart - Választás: 1.4 - Javítjuk: com.exeple helyett: lan.zold - Javítjuk: demo helyett: projekt01 - Kiválasztjuk a könyvtárat - Ezen a könyvtáron belül jön létre egy projekt01 könyvtár Parancssorban: - Define value for preperty 'version' 1.0-SNAPSHOT: : - Y: : A VSCode egy darabig eldolgozik Projekt futtatása: F5 ==== Sablon nélkül ==== A **No Archetype** az újabb VSCode verziókban jelent meg, 2023-ban. Forrás: https://github.com/microsoft/vscode-maven/issues/869 * **Maven** create from archetype * No Archetype... * (Create a basic Maven project diretly. * com.example * Input group Id of your project. * demo * Input artifact Id (also as project name) of your project. * [Select Destination Folder] Kiírja hol hozta létre a projektet. ==== Tesztelés ==== A baloldali "akció sávon" megjelenik egy kémcső. Ha erre kattintunk, tőle jobbra az "oldal sávon" tesztelési lehetőségek jelennek meg. Ha Maven projektet hoztunk létre (nem No Archetype), akkor lesz a projektnek egy AppTest része. Alapból van egy tesztünk is benne. Futtassuk. Az AppTest felé visszük az egeret, ekkor megjelenik egy lejátszógomb. ===== TODO ===== Két hasznos bővítmény: * TODO Highlight * Kiemeli a kódban a TODE és FIXME megjegyzés feliratait * **TODO Tree** * Az akciósávon megjelenít egy fát. * Arra kattintva, az oldalsávon megjelennek a tennivalók fanézetben. ===== A szerkesztő beállításai ===== A kódszerkesztőt minden projekthez a következő helyen állíthatjuk be: $HOME/.config/Code/User/settings.json Csak egy projekthez, a projekt könyvtárában a .vscode könyvtárban végezzük el a beállításokat: .vscode/settings.json ==== Ajánlások és paraméterleírások kikapcsolása ==== Az **IntelliSense** egy általános kifejezés a különféle kódszerkesztő funkciókra. Szokás kódkiegészítőnek, tartalomsegítőnek vagy kód utalásoknak is hívni. * kódkiegészítés * paraméterinformációk * gyors információk * tag listák Az IntelliSense a következő beállításokkal szabályozható. { "editor.quickSuggestions": { "other": false, "comments": false, "strings": false }, "editor.parameterHints.enabled": false, } Ha zavaró a sok felugró ablak tegyük false értékre, azt ami nem szükséges. Forrás: https://code.visualstudio.com/docs/editor/intellisense (2023) ==== settings.json generálás ==== Ha nincs .vscode/settings.json fájl, de szeretnénk egy beállítást leírni a fájlban, automatikusan legeneráltathatjuk: * Parancspanel: * Ctrl+P * >Open Workspace Settings (JSON) A parancs létrehozza fájlt üresen: { } Írjuk be a beállításunk, például: { "window.zooomLevel": 4 } A beállítást megtehetjük a felhasználó profil könyvtárában is. Ekkor a parancspanelon: * Parancspanel * Ctrl+P * >Open Settings (JSON) ==== Whitespcae karakterek ==== A Whitespace karakterek láthatóságának bekapcsolása. { "editor.renderWhitespace": "all" } ===== A java.awt nem látszik ===== A java.awt osztályokhoz esetén a kiegészítő nem ajánlja fel a java.awt osztályait. Megoldás: A szerkesztő beállításaiba: "java.completion.filteredTypes" : [ "java.awt.List", "com.sun.*" ], Helyben: .vscode/settings.json Például: { "java.project.sourcePaths": ["src"], "java.project.outputPath": "bin", "java.project.referencedLibraries": [ "lib/**/*.jar" ], "java.completion.filteredTypes" : [ "java.awt.List", "com.sun.*" ], } Forrás: * https://github.com/redhat-developer/vscode-java/issues/1093 (2021) ===== Fájlok fejléce ===== Telepítsük a psioniq File Header bővítményt: * psioniq File Header A beállítás fájlba másoljuk be: //... "psi-header.config": { "forceToTop": true, "blankLinesAfter": 1, "license": "Custom" }, "psi-header.variables": [ ["company", "Sallai Andras"], ["author", "Sallai Andras"], ["authoremail", "andrewteki@gmail.com"] ], "psi-header.changes-tracking": { "isActive": true, "modAuthor": "Modified By: ", "modDate": "Last Modified: ", "modDateFormat": "date", "include": [], "exclude": [ "markdown", "json", "jsonc" ], "excludeGlob": [ "out/**", "src/**/*.xyz" ], "autoHeader": "manualSave" }, "psi-header.license-text": [ "MIT", ], "psi-header.templates": [ { "language": "*", "template": [ "File: <>", "Project: <>", "Created Date: <>", "Author: <>", "-----", "Last Modified: <>", "Modified By: ", "-----", "Copyright (c) <> <>" "", "<>", ], "changeLogCaption": "HISTORY:", "changeLogHeaderLineCount": 2, "changeLogEntryTemplate": [ "<>\t<>\t" ] }, }], } Csak a helyi projekt beállításaihoz másoljuk, mert másként minden projekt ilyen licencű lesz. A fejléc beillesztése: * F1 * Header Insert 6 üres sor helyett 1 van beállítva. Minden új fájlhoz hozzáfűzi. ===== MIT licenc hozzáadó ===== Telepítendő bővítmény: * MIT License Adder Indítás: * F1 * MIT ===== Bővítmények licenceléshez ===== ==== Choose A license ==== Egy licenc fájlt szúr be. ==== MIT License Adder ==== MIT licenc fájl szúr be ==== psioniq File Header ==== Ez a fájlt kell szerkeszteni: .vscode/settings.json majd: * F1 * Header Insert ==== License Header Manager ==== * F1 * Create new License Template * Edit License Templates * Add license header Jó lenne, rossz hónapot és napot ír. ==== Codeium ==== A Codeium egy kód asszisztens. Regisztráció szükséges a webhelyén: * https://codeium.com/ Telepítsük a **Codeium** bővítményt. Jelentkezzünk be a bővítménybe, majd működik azonnal. === Kiegészítések lapozása === Beállíthatunk gyorsbillentyűt például a kiegészítések lapozásához: Nyissuk meg a gyorsbillentyű beállításokat: * Ctrl + K, Ctrl + S Keressünk rá: * Codeium | Show Next Completion | Alt + RightArrow | | Show Previous Completion | Alt + LeftArrow | ===== Alapértelmezett terminál beállítása ===== * F1 * Terminal: Select Default Profile ===== Panel kapcsolása ===== Panel ki-be kapcsolása: * Ctrl + J A panel az alsó rész, ahol a terminál is megjelenik. ===== Billentyűkombináció ===== ==== Megjegyzés ==== * Windows * Ctrl + ü * Linux: * Ctrl + Shift + 6 ==== Tabulátor ==== A tabulátor viselkedése a **Ctrl + M** billentyűkombinációval állítható: * Ctrl + M A VSCode-ban a Tab billentyű hatására a szerkesztőben beszúr egy tabulátor a kódba. A Ctrl+M hatására ez a viselkedés megváltozik és a szerkesztő felületén ugrál a VSCode UI elemein. Ha újból megnyomjuk visszakapcsol az eredeti állapotba. ==== Automatikus kiegészítés ==== Ha kivétel kezelés szükséges, a sorra állok, majd: * Ctrl + . De ha az egeret sorra viszem és kattintok a Quick fix-re, az is jó. ==== Java fájlok létrehozása ==== Az oldalsávon Java Projekt alatt jobb egér, osztály létrehozása. ===== Project Template ===== Telepítsük a következő bővítményt: * Project Templates Készítsük el a template-nek szánt projektet. Az oldalsávon jobb egér gomb, ahol elmenthetjük az új sablont, vagy használhatjuk a már mentett sablont: * Save Project as Template * Create Project from Template ==== A templatek helye ==== * $HOME/.config/Code/User/ProjectTemplates # Linux * $HOME/Library/Application Support/Code/User/ProjectTemplates # macOS * %APPDATA%\Code\User\ProjectTemplates # Windows ==== Bővítmény webhely ==== * https://marketplace.visualstudio.com/items?itemName=cantonios.project-templates ===== Template Generátor ===== Fájlok vagy könyvtárak template-ként használhatók. A **{homedir}/.vscode/templates** könyvtárba tesszük azokat a fájlokat és könyvtárakat, amiket sablonként szeretnénk használni. Jelöljük meg az explolerben milyen könyvtárban szeretnénk a fájl létrehozni. A template kiválasztása: * jobb egér gomb a könyvtáron * F1 parancs panel: Files: New File from Template Ezt követően megjelennek a {homedir}/.vscode/templates könyvtárban található fájlok. Válasszunk. Rákérdez milyen fájlba szeretnénk tenni, és kész. ===== Java snippets ===== * cl - class Valami { } * ctor - konstruktor - public Valami() { } * method - metódus - public void name() { } * fori - for (int i = 0; i < array.length; i++) { } * foreach - for (iterable_type iterable_element : iterable) { } * if * ifelse * new - új objektum példány ===== Felhasználói snippets ===== * File > Preferences > User Snippets Három lehetőségünk van: * Globális snippets létrehozása * Projekt számára snippets létrehozása * Adott nyelvhez snippets létrehozása Válasszuk ki kívánt lehetőséget. "console.log": { "prefix": "log", "body": [ "console.log('$1');", "$2" ], "description": "console.log beszúrása" } ===== Lorem ipsum ===== Megadhatjuk hány szóból álljon a kitöltő szöveg: lorem10 lorem50 ===== REST API kliens ===== Bővítmény: * Thunder Client ===== A bin könyvtár törlés ===== A bin könyvtár törlése váratlan problémákat okozhat. A kód nem fordul automatikusan újra. Megoldás: * F1 > Clean the java language server workspace ===== SQLite3 ===== Bővítmény neve: * SQLite3 Editor Az oldalsávon megjelenít egy SQLITE3 EDITOR TABLES nézetet. ===== Diagram rajzoló ===== Bővítmény: * Draw.io Integration * This unofficial extension integrates Draw.io into VS Co... * Henning Dieterichs Készítsünk egy valami.drawio kiterjesztésű fájlt. Elindul a diagram rajzoló. ===== Git verziókövető ===== Ha a VSCode segítségével megnyitott könyvtár egyik szülő könyvtára már tartalmaz Git tárolót, akkor figyelmeztetést kapunk: {{:oktatas:programozas:java:java_fejlesztoi_koernyezet_kialakitasa:vscode_git_perent_dir.png?400|}} ===== Java Inlay Hints ===== A VSCode egy függvény hívásakor utal a paraméterekre. Ez néha zavaró lehet. Triangle.calcArea(/* base: */ 30, /* height */ 35); Beállítás: * Setting > Java Inlay Hints Beállítási lehetőségek: * none * literals - változók esetén nem hivatkozik * all - változók és literálisok esetén is hivatkozik ===== Konfiguráció ===== Konfiguráció létrehozása: * Run > Add configuration... Ha nincs megnyitva Java fájl, akkor még ki kell választani a "Java" lehetőséget. Létrejön: .vscode/launch.json Alapértelmezetten két konfiguráció jön létre: * Current File * App A Current File és más konfiguráció futtatása: * Akciósáv > "Run and Debug" A lejátszógomb mellett, legördülő listadobozból kiválaszthatjuk a kívánt konfigurációt. ===== A File Utils bővítmény ===== Szokták még ajánlani a **File Utils** nevű bővítményt "Steffen Leistner"-től. * File Utils ===== A module-info.java esete ===== Ha JavaFX projektet hozunk létre a "Project Manager for Java" bővítménnyel a moduláris Java projektet kapunk. Ez a gyakorlatban az jelenti, hogy lesz a src/java könyvtárban egy modul-info.java állományunk. A moduláris programozás eredménye, hogy a module-info.java fájlban meg kell jelölni függőségként minden olyan külső programozói könyvtárat, amit szeretnénk használni. A legtöbb Java programozói könyvtár nem használható modulárisan, így nem a .jar fájl nevét szokták beírni függőségként. Ez automatikus modulbetöltést jelent, amiről a VSCode is azt mondja, hogy unstable. Ezért mindig aláhúzza az automatikus importálású kiegészítőket. Az állandó figyelmeztetés zavaró lehet. Kikapcsolása: Szerkesszük a következő állományt: * .settings/org.eclipse.jdt.core.prefs Vegyük fel a következő sort: org.eclipse.jdt.core.compiler.problem.unstableAutoModuleName=ignore A .settings/org.eclipse.jdt.core.prefs fájl rejtett, így a VSCode-ban megnyitása: Ctrl+o, majd rejtett fájlok láthatóságát bekapcsoljuk, és kiválasztjuk a fájlt. ===== Link ===== * https://code.visualstudio.com/docs/java/java-tutorial (2022) * https://code.visualstudio.com/docs/java/java-project (2022)