Share via


Problemen met VSPackages oplossen

Van toepassing op: Visual Studio

In dit artikel worden veelvoorkomende problemen en tips voor het oplossen van problemen met uw VSPackages beschreven.

Een VSPackage zorgt ervoor dat Visual Studio niet kan worden gestart

In dit scenario start u Visual Studio in de veilige modus door devenv.exe /safemode in te voeren bij een opdrachtprompt. Tijdens dit proces worden geen VSPackages geladen, behalve de VSPackages die zijn opgenomen in Visual Studio.

Een VSPackage is niet geladen

Voer een of meer van de volgende stappen uit om dit probleem op te lossen:

  • Zorg ervoor dat u de registerhoofdmap gebruikt waarin de VSPackage is geregistreerd om uit te voeren, meestal de experimentele registerhoofdmap. Zie Het experimentele exemplaar voor meer informatie.

  • Als het VSPackage is bedoeld om te worden uitgevoerd in de experimentele registerhoofdmap, controleert u of u de experimentele versie van Visual Studio uitvoert.

    Als u de experimentele versie wilt uitvoeren, opent u een Visual Studio-opdrachtprompt en voert u vervolgens devenv /rootsuffix exp in.

  • Controleer uw VSPackage-registervermeldingen. Zie VSPackages registreren en VSPackages beheren voor meer informatie.

  • Open het venster Uitvoer van het exemplaar van Visual Studio dat het VSPackage niet kan laden. Informatie over waarom het VSPackage niet kan worden geladen, wordt mogelijk weergegeven in dat venster.

    Opmerking

    Als u de experimentele versie van Visual Studio start vanuit de Visual Studio Integrated Development Environment (IDE), controleert u het venster Uitvoer van beide versies.

  • Bekijk het activiteitenlogboek. Zie Procedure: het activiteitenlogboek gebruiken voor meer informatie.

  • Voor meer informatie over uitzonderingen die door de IDE worden gegenereerd, selecteert u Uitzonderingen in het menu Foutopsporing om de uitzonderingen in te schakelen. Selecteer in het dialoogvenster Uitzonderingen de typen uitzonderingen waarover u meer informatie wilt.

Een VSPackage is niet geregistreerd

Zorg ervoor dat de VSPackage-assembly zich op een vertrouwde locatie bevindt. RegPkg kan geen assembly's registreren op een niet-vertrouwde of gedeeltelijk vertrouwde locatie, zoals een netwerkshare in de standaard .NET-beveiligingsconfiguratie. Hoewel er een waarschuwing wordt weergegeven wanneer een gebruiker een project maakt op een niet-vertrouwde locatie, kan het selectievakje Dit bericht niet opnieuw weergeven voorkomen dat deze waarschuwing opnieuw wordt weergegeven.

Een opdracht is niet zichtbaar of er wordt een fout gegenereerd wanneer deze wordt geselecteerd

Voer de volgende stappen uit om dit probleem op te lossen:

  • Voeg de nieuwe of gewijzigde menuopdrachten en de opdrachten die al in de IDE aanwezig zijn, samen door devenv /rootsuffix Exp /setup in te voeren bij de Opdrachtprompt van Visual Studio.

  • Zorg ervoor dat Visual Studio UI.dll voor uw VSPackage kan vinden.

    1. Zoek de CLSID van het VSPackage in de sectie Pakketten van het register:

      HKLM\Software\Microsoft\Visual Studio\<version>\Packages

    2. Controleer of het pad dat is opgegeven door de subsleutel SatelliteDll juist is.

Een VSPackage gedraagt zich onverwacht

Voer een of meer van de volgende stappen uit om dit probleem op te lossen:

  • Stel onderbrekingspunten in uw code in.

    Goede uitgangspunten voor foutopsporing zijn de constructor en de initialisatiemethode. U kunt ook onderbrekingspunten instellen in het gebied dat u wilt evalueren, zoals een menuopdracht. Als u onderbrekingspunten wilt inschakelen, moet u uitvoeren onder het foutopsporingsprogramma.

    1. Selecteer Eigenschappen in het menu Project.

    2. Selecteer in het dialoogvenster Eigenschappenpagina's het tabblad Foutopsporing .

    3. Voer in het vak Opdrachtregelargumenten het hoofdachtervoegsel in van de ontwikkelomgeving waarop uw VSPackage zich richt. Als u bijvoorbeeld de experimentele build wilt selecteren, voert u het volgende in: /RootSuffix Exp.

    4. Selecteer in het menu Foutopsporingde optie Foutopsporing starten of druk op F5.

      Opmerking

      Als u fouten in een project opspoort, maakt of laadt u nu een bestaand exemplaar van uw project.

  • Gebruik het activiteitenlogboek.

    Traceer VSPackage-gedrag door informatie te schrijven naar het activiteitenlogboek op belangrijke punten. Deze techniek is vooral handig wanneer u een VSPackage uitvoert in een retailomgeving. Zie Procedure: het activiteitenlogboek gebruiken voor meer informatie.

  • Openbare symbolen gebruiken.

    Als u de leesbaarheid tijdens foutopsporing wilt verbeteren, kunt u symbolen koppelen aan het foutopsporingsprogramma:

    1. Ga in het menu Extra/Opties naar het dialoogvenster Foutopsporing/symbolen .
    2. Locatie van symboolbestand (.pdb) toevoegen: https://msdl.microsoft.com/download/symbols.
    3. Als u de prestaties wilt verbeteren, geeft u een symboolcachemap op, bijvoorbeeld : C:\symbols.

Er ontbreekt een VSPackage of een van de bijbehorende afhankelijkheden

  • Zorg ervoor dat de verwijzingspaden juist zijn voor beheerde code.

    1. Selecteer Eigenschappen in het menu Project.

    2. Selecteer het tabblad Verwijzingen in het dialoogvenster Eigenschappenpagina's en controleer of alle paden juist zijn. U kunt ook de objectbrowser gebruiken om te bladeren naar de objecten waarnaar wordt verwezen.

      Voor beheerde code kunt u de Fuslogvw.exe (Assembly Binding Log Viewer) gebruiken om de details van mislukte assemblyladingen weer te geven.

  • Voor niet-beheerde code zoekt u de CLSID van het VSPackage in het registerknooppunt Visual Studio CLSID:

    HKLM\Software\Microsoft\Visual Studio\<version>\CLSID

    Zorg ervoor dat de vermelding InprocServer32 het juiste pad van het VSPackage-DLL heeft.

Verwijzingen