-
-
Notifications
You must be signed in to change notification settings - Fork 302
Which features can ViVeTool toggle?\DE
ℹ️ Um zu verstehen, was ViVe(Tool) tun kann und was nicht, müssen wir uns einige Grundlagen der Funktionsverwaltung in Windows genauer anschauen.
Wie üblich beim großen Projekten ist jeder größeren Änderung in Windows eine numerische Aufgaben-ID zugewiesen. Diese Aufgaben-ID in Microsoft's internem Bugtracker ist identisch mit der, die später eine Feature ID wird. Die IDs, die man in einem bestimmten Windows Build aktivieren kann sind in verschiedenen (Meta)dateien deklariert, die in dem Kompilierungsprozess von Windows eingebunden werden. Das ist der Grund, warum Features von einem Build auf das andere entfernt werden können — eine einfache Änderung der Metadaten reicht aus, um den Code für ein Feature komplett zu entfernen. Der Code für das Feature existiert immer noch im Quellcode, aber nicht mehr in der kompilierten Datei.
Feature-Referenzen sind direkt in Bibliotheken und Programme eingebettet, in denen Code für ein bestimmtes Feature vorhanden ist — es gibt keine zentrale Datenbank. In den meisten Fällen werden Features mithilfe von Debugging-Symbolen gefunden. Debugging-Symbole sind Dateien die von Microsoft veröffentlicht werden, um Entwicklern bei der Fehlersuche in ihren Programmen zu helfen. Diese Dateien enthalten genügend Informationen um den Namen und die ID eines Features zu bestimmen. Dieser Prozess muss für jede Datei in Windows wiederholt werden, wobei nicht für alle Dateien auch Debugging-Symbole veröffentlicht werden (oftmals fehlen diese zum Beispiel für Dateien, die mit DRM zu tun haben).
Features haben vier mögliche Ausgangszustände, in denen sie ausgeliefert werden können:
- Standardmäßig Deaktiviert
- Standardmäßig Aktiviert
- Immer Deaktiviert
- Immer Aktiviert
Wenn ein Feature in einem der "Standardmäßig"-Zustände ausgeliefert wird, enthälten die zugehörigen Binärdateien beide Codepfade - einen für den deaktivierten Zustand, und einen für den aktivierten Zustand. Wenn man bei diesen Features den Zustand umschaltet, führt das zu sichtbaren Veränderungen.
Wenn ein Feature hingegen in einem der beiden "Immer"-Zustände ausgeliefert wird, hat das Umschalten keine Auswirkung, da kein alternativer Codepfad mehr vorhanden ist.
Genau wie das Vorhandensein eines Features wird auch der Auslieferungszustand zum Zeitpunkt der Kompilierung von Windows festgelegt. Das ist der Grund, warum Features von einem Build auf das andere zum Teil nicht mehr aktiviert werden können — dies kann teilweise sogar durch ein einfaches kumulatives Update geschehen.
Wenn ViVeTool verwendet wird um einen Featuezustand zu ändern, ruft es die relevanten Funktionsverwaltungs-APIs auf, um die Anfrage zu erfüllen. Wenn die Meldung "Successfully set feature configuration" erscheint, bedeutet das lediglich, dass die API die Anfrage verarbeitet hat.
Weder ViVeTool noch die API können garantieren, dass die geänderte Konfiguration eine sichtbare Änderung zur Folge hat. Dies liegt an der zuvor erwähnten dezentralen Natur der IDs, die in einem Windows Build vorhanden sind.
Wenn ein Online-Tutorial in dem ViVeTool verwendet wurde bei dir nicht den gewünschten Effekt hatte, kann es sein dass das Tutorial für eine andere Version von Windows gemacht wurde. Bitte erstelle in diesem Fall keinen Fehlerbericht auf Github, da es hier unsererseits nichts zu beheben gibt. Es handelt sich hier lediglich um eine Resultat der Funktionsweise von Feature IDs, die nicht in unserer Hand liegt.