Major architectural refactoring to achieve 1:1 structural compatibility: 🏗️ **VC2022 Structure Replication** - Iso1EXIDocument: 1:1 replica of VC2022 iso1EXIDocument struct - DinEXIDocument: 1:1 replica of VC2022 dinEXIDocument struct - Iso2EXIDocument: 1:1 replica of VC2022 iso2EXIDocument struct - All _isUsed flags and Initialize() methods exactly matching VC2022 🔄 **VC2022 Function Porting** - ParseXmlToIso1(): Exact port of VC2022 parse_xml_to_iso1() - EncodeIso1ExiDocument(): Exact port of VC2022 encode_iso1ExiDocument() - Choice 76 (V2G_Message) encoding with identical logic - BulkChargingComplete ignore behavior preserved ⚡ **Call Sequence Alignment** - Old: EncodeV2GMessage() → direct EXI encoding - New: EncodeV2GMessage() → Iso1EXIDocument → EncodeIso1ExiDocument() - Exact VC2022 call chain: init → parse → encode → finish 🔍 **1:1 Debug Comparison Ready** - C# exiDoc.V2G_Message_isUsed ↔ VC2022 exiDoc->V2G_Message_isUsed - Identical structure enables line-by-line debugging comparison - Ready for precise 1-byte difference investigation (41 vs 42 bytes) 📁 **Project Reorganization** - Moved from csharp/ to Port/ for cleaner structure - Port/dotnet/ and Port/vc2022/ for parallel development - Complete build system and documentation updates 🎯 **Achievement**: 97.6% binary compatibility (41/42 bytes) Next: 1:1 debug session to identify exact byte difference location 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
28 lines
1.5 KiB
Plaintext
28 lines
1.5 KiB
Plaintext
Debug mode enabled: detailed bit-level encoding/decoding output
|
||
?<3F><> [DEBUG CurrentDemandReq] Starting encoding, stream pos: 12
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 273, stream pos: 12
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 274, stream pos: 15
|
||
?”¬ [PhysicalValue] M=0, U=3, V=1, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 275, stream pos: 18
|
||
?“<> Grammar 275: choice 0 (EVMaximumVoltageLimit), 3-bit=0
|
||
?”¬ [PhysicalValue] M=0, U=4, V=471, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 276, stream pos: 23
|
||
?”¬ [PhysicalValue] M=0, U=3, V=100, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 277, stream pos: 26
|
||
?”¬ [PhysicalValue] M=3, U=5, V=50, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 278, stream pos: 30
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 280, stream pos: 30
|
||
?”¬ [PhysicalValue] M=0, U=2, V=0, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 281, stream pos: 34
|
||
?”¬ [PhysicalValue] M=0, U=2, V=0, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 282, stream pos: 37
|
||
?”¬ [PhysicalValue] M=0, U=4, V=460, pos=632385336
|
||
?”¬ [PhysicalValue] Encoded, pos_after=632385336
|
||
?”<> [DEBUG CurrentDemandReq] Grammar case: 3, stream pos: 41
|
||
€˜P<>ŒPÑ |