فهرست منبع

delete OpenV2G 0.7

git-svn-id: https://svn.code.sf.net/p/openv2g/code/trunk@82 d9f2db14-54d0-4bde-b00c-16405c910529
sebastiankb 11 سال پیش
والد
کامیت
85cb922c5a
100فایلهای تغییر یافته به همراه0 افزوده شده و 37675 حذف شده
  1. 0 627
      .cproject
  2. 0 69
      .project
  3. 0 21
      .settings/org.eclipse.cdt.managedbuilder.core.prefs
  4. 0 49
      Debug/makefile
  5. 0 8
      Debug/objects.mk
  6. 0 22
      Debug/sources.mk
  7. 0 30
      Debug/src/appHandshake/subdir.mk
  8. 0 36
      Debug/src/codec/appHandCodec/subdir.mk
  9. 0 78
      Debug/src/codec/subdir.mk
  10. 0 33
      Debug/src/service/subdir.mk
  11. 0 39
      Debug/src/test/subdir.mk
  12. 0 24
      Debug/src/transport/subdir.mk
  13. 0 165
      LICENSE.txt
  14. 0 103
      README.txt
  15. 0 49
      Release/makefile
  16. 0 8
      Release/objects.mk
  17. 0 22
      Release/sources.mk
  18. 0 30
      Release/src/appHandshake/subdir.mk
  19. 0 36
      Release/src/codec/appHandCodec/subdir.mk
  20. 0 78
      Release/src/codec/subdir.mk
  21. 0 33
      Release/src/service/subdir.mk
  22. 0 39
      Release/src/test/subdir.mk
  23. 0 24
      Release/src/transport/subdir.mk
  24. 0 16
      data/test/sessionSetupReq.xml
  25. BIN
      data/test/sessionSetupReq.xml.exi
  26. 0 18
      data/test/sessionSetupRes.xml
  27. BIN
      data/test/sessionSetupRes.xml.exi
  28. 0 338
      src/appHandshake/appHand_DataDeserialization.c
  29. 0 415
      src/appHandshake/appHand_dataSerialization.c
  30. 0 70
      src/appHandshake/appHand_dataTypes.c
  31. 0 133
      src/appHandshake/appHand_dataTypes.h
  32. 0 87
      src/appHandshake/appHand_service.h
  33. 0 700
      src/codec/AbstractDecoderChannel.c
  34. 0 573
      src/codec/AbstractEncoderChannel.c
  35. 0 74
      src/codec/BitDecoderChannel.c
  36. 0 88
      src/codec/BitEncoderChannel.c
  37. 0 111
      src/codec/BitInputStream.c
  38. 0 66
      src/codec/BitInputStream.h
  39. 0 118
      src/codec/BitOutputStream.c
  40. 0 83
      src/codec/BitOutputStream.h
  41. 0 94
      src/codec/ByteDecoderChannel.c
  42. 0 128
      src/codec/ByteEncoderChannel.c
  43. 0 82
      src/codec/ByteStream.c
  44. 0 74
      src/codec/ByteStream.h
  45. 0 51
      src/codec/CoderChannel.h
  46. 0 356
      src/codec/DecoderChannel.h
  47. 0 1861
      src/codec/EXICoder.c
  48. 0 70
      src/codec/EXICoder.h
  49. 0 933
      src/codec/EXIDecoder.c
  50. 0 222
      src/codec/EXIDecoder.h
  51. 0 1010
      src/codec/EXIEncoder.c
  52. 0 271
      src/codec/EXIEncoder.h
  53. 0 60
      src/codec/EXIHeaderDecoder.c
  54. 0 59
      src/codec/EXIHeaderDecoder.h
  55. 0 44
      src/codec/EXIHeaderEncoder.c
  56. 0 60
      src/codec/EXIHeaderEncoder.h
  57. 0 75
      src/codec/EXIOptions.h
  58. 0 535
      src/codec/EXITypes.h
  59. 0 320
      src/codec/EncoderChannel.h
  60. 0 108
      src/codec/ErrorCodes.h
  61. 0 133
      src/codec/MethodsBag.c
  62. 0 70
      src/codec/MethodsBag.h
  63. 0 200
      src/codec/NameTableEntries.c
  64. 0 41
      src/codec/NameTableEntries.h
  65. 0 51
      src/codec/QNameDefines.h
  66. 0 981
      src/codec/QNames.c
  67. 0 74
      src/codec/QNames.h
  68. 0 144
      src/codec/StringTable.c
  69. 0 116
      src/codec/StringTable.h
  70. 0 67
      src/codec/UCSString.c
  71. 0 74
      src/codec/UCSString.h
  72. 0 862
      src/codec/appHandCodec/appHandEXICoder.c
  73. 0 70
      src/codec/appHandCodec/appHandEXICoder.h
  74. 0 2219
      src/codec/appHandCodec/appHandEXIDecoder.c
  75. 0 222
      src/codec/appHandCodec/appHandEXIDecoder.h
  76. 0 1415
      src/codec/appHandCodec/appHandEXIEncoder.c
  77. 0 271
      src/codec/appHandCodec/appHandEXIEncoder.h
  78. 0 98
      src/codec/appHandCodec/appHandNameTableEntries.c
  79. 0 41
      src/codec/appHandCodec/appHandNameTableEntries.h
  80. 0 51
      src/codec/appHandCodec/appHandQNameDefines.h
  81. 0 223
      src/codec/appHandCodec/appHandQNames.c
  82. 0 74
      src/codec/appHandCodec/appHandQNames.h
  83. 0 844
      src/service/v2g_dataTypes.c
  84. 0 1688
      src/service/v2g_dataTypes.h
  85. 0 83
      src/service/v2g_service.h
  86. 0 44
      src/service/v2g_serviceClientDataTransmitter.h
  87. 0 2743
      src/service/v2g_serviceClientStubs.c
  88. 0 320
      src/service/v2g_serviceClientStubs.h
  89. 0 7399
      src/service/v2g_serviceDataSerialization.c
  90. 0 2712
      src/service/v2g_serviceDispatcher.c
  91. 0 43
      src/service/v2g_serviceDispatcher.h
  92. 0 189
      src/service/v2g_serviceMethods.h
  93. 0 188
      src/test/evse_server.c
  94. 0 33
      src/test/evse_server.h
  95. 0 722
      src/test/evse_serviceMethods.c
  96. 0 44
      src/test/main.c
  97. 0 43
      src/test/main.h
  98. 0 466
      src/test/main_codec.c
  99. 0 1615
      src/test/pev_service.c
  100. 0 76
      src/test/serviceClientDataTransmitter.c

+ 0 - 627
.cproject

@@ -1,627 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<?fileVersion 4.0.0?>
-
-<cproject storage_type_id="org.eclipse.cdt.core.XmlProjectDescriptionStorage">
-	<storageModule moduleId="org.eclipse.cdt.core.settings">
-		<cconfiguration id="cdt.managedbuild.config.gnu.mingw.exe.debug.181718907">
-			<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="cdt.managedbuild.config.gnu.mingw.exe.debug.181718907" moduleId="org.eclipse.cdt.core.settings" name="Debug">
-				<externalSettings/>
-				<extensions>
-					<extension id="org.eclipse.cdt.core.PE" point="org.eclipse.cdt.core.BinaryParser"/>
-					<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
-					<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
-					<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
-				</extensions>
-			</storageModule>
-			<storageModule moduleId="cdtBuildSystem" version="4.0.0">
-				<configuration artifactName="OpenV2G" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.debug,org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.exe" cleanCommand="rm -rf" description="" id="cdt.managedbuild.config.gnu.mingw.exe.debug.181718907" name="Debug" parent="cdt.managedbuild.config.gnu.mingw.exe.debug">
-					<folderInfo id="cdt.managedbuild.config.gnu.mingw.exe.debug.181718907." name="/" resourcePath="">
-						<toolChain id="cdt.managedbuild.toolchain.gnu.mingw.base.186426714" name="MinGW GCC" superClass="cdt.managedbuild.toolchain.gnu.mingw.base">
-							<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.PE" id="cdt.managedbuild.target.gnu.platform.mingw.base.208578740" name="Debug Platform" osList="win32" superClass="cdt.managedbuild.target.gnu.platform.mingw.base"/>
-							<builder buildPath="${workspace_loc:/OpenV2G/Debug}" id="org.eclipse.cdt.build.core.internal.builder.135121082" keepEnvironmentInBuildfile="false" name="CDT Internal Builder" superClass="org.eclipse.cdt.build.core.internal.builder"/>
-							<tool id="cdt.managedbuild.tool.gnu.assembler.mingw.base.467817276" name="GCC Assembler" superClass="cdt.managedbuild.tool.gnu.assembler.mingw.base">
-								<inputType id="cdt.managedbuild.tool.gnu.assembler.input.1213164158" superClass="cdt.managedbuild.tool.gnu.assembler.input"/>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.archiver.mingw.base.260408959" name="GCC Archiver" superClass="cdt.managedbuild.tool.gnu.archiver.mingw.base"/>
-							<tool id="cdt.managedbuild.tool.gnu.cpp.compiler.mingw.base.1208420490" name="GCC C++ Compiler" superClass="cdt.managedbuild.tool.gnu.cpp.compiler.mingw.base">
-								<option id="gnu.cpp.compiler.option.optimization.level.650473997" name="Optimization Level" superClass="gnu.cpp.compiler.option.optimization.level" value="gnu.cpp.compiler.optimization.level.none" valueType="enumerated"/>
-								<option id="gnu.cpp.compiler.option.debugging.level.2034188123" name="Debug Level" superClass="gnu.cpp.compiler.option.debugging.level" value="gnu.cpp.compiler.debugging.level.max" valueType="enumerated"/>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.c.compiler.mingw.base.1511109002" name="GCC C Compiler" superClass="cdt.managedbuild.tool.gnu.c.compiler.mingw.base">
-								<option id="gnu.c.compiler.option.include.paths.229245493" name="Include paths (-I)" superClass="gnu.c.compiler.option.include.paths" valueType="includePath">
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/codec}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/appHandshake}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/codec/appHandCodec}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/transport}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/service}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/test}&quot;"/>
-								</option>
-								<option defaultValue="gnu.c.optimization.level.none" id="gnu.c.compiler.option.optimization.level.1880660058" name="Optimization Level" superClass="gnu.c.compiler.option.optimization.level" valueType="enumerated"/>
-								<option id="gnu.c.compiler.option.debugging.level.890071608" name="Debug Level" superClass="gnu.c.compiler.option.debugging.level" value="gnu.c.debugging.level.max" valueType="enumerated"/>
-								<option id="gnu.c.compiler.option.warnings.pedantic.1983095151" name="Pedantic (-pedantic)" superClass="gnu.c.compiler.option.warnings.pedantic" value="true" valueType="boolean"/>
-								<option id="gnu.c.compiler.option.misc.ansi.1916749690" name="Support ANSI programs (-ansi)" superClass="gnu.c.compiler.option.misc.ansi" value="true" valueType="boolean"/>
-								<option id="gnu.c.compiler.option.warnings.toerrors.990186240" name="Warnings as errors (-Werror)" superClass="gnu.c.compiler.option.warnings.toerrors" value="false" valueType="boolean"/>
-								<option id="gnu.c.compiler.option.warnings.pedantic.error.145905553" name="Pedantic warnings as errors (-pedantic-errors)" superClass="gnu.c.compiler.option.warnings.pedantic.error" value="true" valueType="boolean"/>
-								<inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.1904654876" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.c.linker.mingw.base.1907160138" name="MinGW C Linker" superClass="cdt.managedbuild.tool.gnu.c.linker.mingw.base">
-								<inputType id="cdt.managedbuild.tool.gnu.c.linker.input.1866282924" superClass="cdt.managedbuild.tool.gnu.c.linker.input">
-									<additionalInput kind="additionalinputdependency" paths="$(USER_OBJS)"/>
-									<additionalInput kind="additionalinput" paths="$(LIBS)"/>
-								</inputType>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.cpp.linker.mingw.base.521623519" name="MinGW C++ Linker" superClass="cdt.managedbuild.tool.gnu.cpp.linker.mingw.base"/>
-						</toolChain>
-					</folderInfo>
-					<sourceEntries>
-						<entry flags="VALUE_WORKSPACE_PATH|RESOLVED" kind="sourcePath" name=""/>
-					</sourceEntries>
-				</configuration>
-			</storageModule>
-			<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/>
-			<storageModule moduleId="org.eclipse.cdt.internal.ui.text.commentOwnerProjectMappings"/>
-			<storageModule moduleId="org.eclipse.cdt.core.language.mapping"/>
-			<storageModule moduleId="org.eclipse.cdt.make.core.buildtargets"/>
-		</cconfiguration>
-		<cconfiguration id="cdt.managedbuild.config.gnu.mingw.exe.release.681614450">
-			<storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="cdt.managedbuild.config.gnu.mingw.exe.release.681614450" moduleId="org.eclipse.cdt.core.settings" name="Release">
-				<externalSettings/>
-				<extensions>
-					<extension id="org.eclipse.cdt.core.PE" point="org.eclipse.cdt.core.BinaryParser"/>
-					<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
-					<extension id="org.eclipse.cdt.core.GASErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
-					<extension id="org.eclipse.cdt.core.GLDErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
-				</extensions>
-			</storageModule>
-			<storageModule moduleId="cdtBuildSystem" version="4.0.0">
-				<configuration artifactName="OpenV2G" buildArtefactType="org.eclipse.cdt.build.core.buildArtefactType.exe" buildProperties="org.eclipse.cdt.build.core.buildType=org.eclipse.cdt.build.core.buildType.release,org.eclipse.cdt.build.core.buildArtefactType=org.eclipse.cdt.build.core.buildArtefactType.exe" cleanCommand="rm -rf" description="" id="cdt.managedbuild.config.gnu.mingw.exe.release.681614450" name="Release" parent="cdt.managedbuild.config.gnu.mingw.exe.release">
-					<folderInfo id="cdt.managedbuild.config.gnu.mingw.exe.release.681614450." name="/" resourcePath="">
-						<toolChain id="cdt.managedbuild.toolchain.gnu.mingw.base.544862828" name="MinGW GCC" superClass="cdt.managedbuild.toolchain.gnu.mingw.base">
-							<targetPlatform archList="all" binaryParser="org.eclipse.cdt.core.PE" id="cdt.managedbuild.target.gnu.platform.mingw.base.452289502" name="Debug Platform" osList="win32" superClass="cdt.managedbuild.target.gnu.platform.mingw.base"/>
-							<builder buildPath="${workspace_loc:/OpenV2G/Release}" id="org.eclipse.cdt.build.core.internal.builder.360170814" keepEnvironmentInBuildfile="false" name="CDT Internal Builder" superClass="org.eclipse.cdt.build.core.internal.builder"/>
-							<tool id="cdt.managedbuild.tool.gnu.assembler.mingw.base.586100401" name="GCC Assembler" superClass="cdt.managedbuild.tool.gnu.assembler.mingw.base">
-								<inputType id="cdt.managedbuild.tool.gnu.assembler.input.1634756901" superClass="cdt.managedbuild.tool.gnu.assembler.input"/>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.archiver.mingw.base.934860510" name="GCC Archiver" superClass="cdt.managedbuild.tool.gnu.archiver.mingw.base"/>
-							<tool id="cdt.managedbuild.tool.gnu.cpp.compiler.mingw.base.596457747" name="GCC C++ Compiler" superClass="cdt.managedbuild.tool.gnu.cpp.compiler.mingw.base">
-								<option id="gnu.cpp.compiler.option.optimization.level.2131218410" name="Optimization Level" superClass="gnu.cpp.compiler.option.optimization.level" value="gnu.cpp.compiler.optimization.level.most" valueType="enumerated"/>
-								<option id="gnu.cpp.compiler.option.debugging.level.1665313885" name="Debug Level" superClass="gnu.cpp.compiler.option.debugging.level" value="gnu.cpp.compiler.debugging.level.none" valueType="enumerated"/>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.c.compiler.mingw.base.2107890734" name="GCC C Compiler" superClass="cdt.managedbuild.tool.gnu.c.compiler.mingw.base">
-								<option id="gnu.c.compiler.option.include.paths.289860304" name="Include paths (-I)" superClass="gnu.c.compiler.option.include.paths" valueType="includePath">
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/codec}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/codec/appHandCodec}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/appHandshake}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/transport}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/service}&quot;"/>
-									<listOptionValue builtIn="false" value="&quot;${workspace_loc:/OpenV2G/src/test}&quot;"/>
-								</option>
-								<option defaultValue="gnu.c.optimization.level.most" id="gnu.c.compiler.option.optimization.level.899621054" name="Optimization Level" superClass="gnu.c.compiler.option.optimization.level" value="gnu.c.optimization.level.most" valueType="enumerated"/>
-								<option id="gnu.c.compiler.option.debugging.level.1251127335" name="Debug Level" superClass="gnu.c.compiler.option.debugging.level" value="gnu.c.debugging.level.max" valueType="enumerated"/>
-								<option id="gnu.c.compiler.option.misc.ansi.496561434" name="Support ANSI programs (-ansi)" superClass="gnu.c.compiler.option.misc.ansi" value="true" valueType="boolean"/>
-								<option id="gnu.c.compiler.option.warnings.pedantic.289278524" name="Pedantic (-pedantic)" superClass="gnu.c.compiler.option.warnings.pedantic" value="true" valueType="boolean"/>
-								<option id="gnu.c.compiler.option.warnings.pedantic.error.822372173" name="Pedantic warnings as errors (-pedantic-errors)" superClass="gnu.c.compiler.option.warnings.pedantic.error" value="true" valueType="boolean"/>
-								<option id="gnu.c.compiler.option.optimization.flags.1051939537" name="Other optimization flags" superClass="gnu.c.compiler.option.optimization.flags" value="-Os" valueType="string"/>
-								<option id="gnu.c.compiler.option.misc.other.1470884128" name="Other flags" superClass="gnu.c.compiler.option.misc.other" value="-c -fmessage-length=0" valueType="string"/>
-								<inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.898314529" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.c.linker.mingw.base.2082341498" name="MinGW C Linker" superClass="cdt.managedbuild.tool.gnu.c.linker.mingw.base">
-								<option id="gnu.c.link.option.other.71044722" name="Other options (-Xlinker [option])" superClass="gnu.c.link.option.other"/>
-								<inputType id="cdt.managedbuild.tool.gnu.c.linker.input.153003457" superClass="cdt.managedbuild.tool.gnu.c.linker.input">
-									<additionalInput kind="additionalinputdependency" paths="$(USER_OBJS)"/>
-									<additionalInput kind="additionalinput" paths="$(LIBS)"/>
-								</inputType>
-							</tool>
-							<tool id="cdt.managedbuild.tool.gnu.cpp.linker.mingw.base.557104889" name="MinGW C++ Linker" superClass="cdt.managedbuild.tool.gnu.cpp.linker.mingw.base"/>
-						</toolChain>
-					</folderInfo>
-				</configuration>
-			</storageModule>
-			<storageModule moduleId="org.eclipse.cdt.core.externalSettings"/>
-			<storageModule moduleId="org.eclipse.cdt.internal.ui.text.commentOwnerProjectMappings"/>
-			<storageModule moduleId="org.eclipse.cdt.core.language.mapping"/>
-			<storageModule moduleId="org.eclipse.cdt.make.core.buildtargets"/>
-		</cconfiguration>
-	</storageModule>
-	<storageModule moduleId="cdtBuildSystem" version="4.0.0">
-		<project id="OpenV2G.cdt.managedbuild.target.gnu.mingw.exe.1420366407" name="Executable" projectType="cdt.managedbuild.target.gnu.mingw.exe"/>
-	</storageModule>
-	<storageModule moduleId="scannerConfiguration">
-		<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/>
-		<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="makefileGenerator">
-				<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/${specs_file}&quot;'" command="sh" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-c 'g++ -E -P -v -dD &quot;${plugin_state_location}/specs.cpp&quot;'" command="sh" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC">
-			<buildOutputProvider>
-				<openAction enabled="true" filePath=""/>
-				<parser enabled="true"/>
-			</buildOutputProvider>
-			<scannerInfoProvider id="specsFile">
-				<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/specs.c&quot;'" command="sh" useDefault="true"/>
-				<parser enabled="true"/>
-			</scannerInfoProvider>
-		</profile>
-		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.mingw.exe.release.681614450;cdt.managedbuild.config.gnu.mingw.exe.release.681614450.;cdt.managedbuild.tool.gnu.c.compiler.base.1358204014;cdt.managedbuild.tool.gnu.c.compiler.input.822105819">
-			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="makefileGenerator">
-					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/${specs_file}&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'g++ -E -P -v -dD &quot;${plugin_state_location}/specs.cpp&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/specs.c&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-		</scannerConfigBuildInfo>
-		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.mingw.exe.release.681614450;cdt.managedbuild.config.gnu.mingw.exe.release.681614450.;cdt.managedbuild.tool.gnu.c.compiler.mingw.exe.release.150928873;cdt.managedbuild.tool.gnu.c.compiler.input.2117635578">
-			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="makefileGenerator">
-					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/${specs_file}&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'g++ -E -P -v -dD &quot;${plugin_state_location}/specs.cpp&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/specs.c&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-		</scannerConfigBuildInfo>
-		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.mingw.exe.debug.181718907;cdt.managedbuild.config.gnu.mingw.exe.debug.181718907.;cdt.managedbuild.tool.gnu.c.compiler.mingw.exe.debug.113647340;cdt.managedbuild.tool.gnu.c.compiler.input.67299528">
-			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="makefileGenerator">
-					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/${specs_file}&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'g++ -E -P -v -dD &quot;${plugin_state_location}/specs.cpp&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/specs.c&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-		</scannerConfigBuildInfo>
-		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.mingw.exe.debug.1536681007;cdt.managedbuild.config.gnu.mingw.exe.debug.1536681007.;cdt.managedbuild.tool.gnu.c.compiler.mingw.exe.debug.1257453970;cdt.managedbuild.tool.gnu.c.compiler.input.1901507773">
-			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="makefileGenerator">
-					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/${specs_file}&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'g++ -E -P -v -dD &quot;${plugin_state_location}/specs.cpp&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/specs.c&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-		</scannerConfigBuildInfo>
-		<scannerConfigBuildInfo instanceId="cdt.managedbuild.config.gnu.mingw.exe.release.1091708379;cdt.managedbuild.config.gnu.mingw.exe.release.1091708379.;cdt.managedbuild.tool.gnu.c.compiler.mingw.exe.release.1844784508;cdt.managedbuild.tool.gnu.c.compiler.input.1276057383">
-			<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.make.core.GCCStandardMakePerFileProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="makefileGenerator">
-					<runAction arguments="-f ${project_name}_scd.mk" command="make" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/${specs_file}" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.cpp" command="g++" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-E -P -v -dD ${plugin_state_location}/specs.c" command="gcc" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfile">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/${specs_file}&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileCPP">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'g++ -E -P -v -dD &quot;${plugin_state_location}/specs.cpp&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-			<profile id="org.eclipse.cdt.managedbuilder.core.GCCWinManagedMakePerProjectProfileC">
-				<buildOutputProvider>
-					<openAction enabled="true" filePath=""/>
-					<parser enabled="true"/>
-				</buildOutputProvider>
-				<scannerInfoProvider id="specsFile">
-					<runAction arguments="-c 'gcc -E -P -v -dD &quot;${plugin_state_location}/specs.c&quot;'" command="sh" useDefault="true"/>
-					<parser enabled="true"/>
-				</scannerInfoProvider>
-			</profile>
-		</scannerConfigBuildInfo>
-	</storageModule>
-</cproject>

+ 0 - 69
.project

@@ -1,69 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<projectDescription>
-	<name>OpenV2G</name>
-	<comment></comment>
-	<projects>
-	</projects>
-	<buildSpec>
-		<buildCommand>
-			<name>org.eclipse.cdt.managedbuilder.core.genmakebuilder</name>
-			<triggers>clean,full,incremental,</triggers>
-			<arguments>
-				<dictionary>
-					<key>?name?</key>
-					<value></value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.append_environment</key>
-					<value>true</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.buildArguments</key>
-					<value></value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.buildCommand</key>
-					<value>make</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.buildLocation</key>
-					<value>${workspace_loc:/OpenV2G/Debug}</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.contents</key>
-					<value>org.eclipse.cdt.make.core.activeConfigSettings</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.enableAutoBuild</key>
-					<value>false</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.enableCleanBuild</key>
-					<value>true</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.enableFullBuild</key>
-					<value>true</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.stopOnError</key>
-					<value>true</value>
-				</dictionary>
-				<dictionary>
-					<key>org.eclipse.cdt.make.core.useDefaultBuildCmd</key>
-					<value>true</value>
-				</dictionary>
-			</arguments>
-		</buildCommand>
-		<buildCommand>
-			<name>org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder</name>
-			<arguments>
-			</arguments>
-		</buildCommand>
-	</buildSpec>
-	<natures>
-		<nature>org.eclipse.cdt.core.cnature</nature>
-		<nature>org.eclipse.cdt.managedbuilder.core.managedBuildNature</nature>
-		<nature>org.eclipse.cdt.managedbuilder.core.ScannerConfigNature</nature>
-	</natures>
-</projectDescription>

+ 0 - 21
.settings/org.eclipse.cdt.managedbuilder.core.prefs

@@ -1,21 +0,0 @@
-eclipse.preferences.version=1
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/CPATH/delimiter=;
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/CPATH/operation=remove
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/C_INCLUDE_PATH/delimiter=;
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/C_INCLUDE_PATH/operation=remove
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/append=true
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/appendContributed=true
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/CPATH/delimiter=;
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/CPATH/operation=remove
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/C_INCLUDE_PATH/delimiter=;
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/C_INCLUDE_PATH/operation=remove
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/append=true
-environment/buildEnvironmentInclude/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/appendContributed=true
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/LIBRARY_PATH/delimiter=;
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/LIBRARY_PATH/operation=remove
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/append=true
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.debug.181718907/appendContributed=true
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/LIBRARY_PATH/delimiter=;
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/LIBRARY_PATH/operation=remove
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/append=true
-environment/buildEnvironmentLibrary/cdt.managedbuild.config.gnu.mingw.exe.release.681614450/appendContributed=true

+ 0 - 49
Debug/makefile

@@ -1,49 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
--include ../makefile.init
-
-RM := rm -rf
-
-# All of the sources participating in the build are defined here
--include sources.mk
--include src/transport/subdir.mk
--include src/test/subdir.mk
--include src/service/subdir.mk
--include src/codec/appHandCodec/subdir.mk
--include src/codec/subdir.mk
--include src/appHandshake/subdir.mk
--include subdir.mk
--include objects.mk
-
-ifneq ($(MAKECMDGOALS),clean)
-ifneq ($(strip $(C_DEPS)),)
--include $(C_DEPS)
-endif
-endif
-
--include ../makefile.defs
-
-# Add inputs and outputs from these tool invocations to the build variables 
-
-# All Target
-all: OpenV2G.exe
-
-# Tool invocations
-OpenV2G.exe: $(OBJS) $(USER_OBJS)
-	@echo 'Building target: $@'
-	@echo 'Invoking: MinGW C Linker'
-	gcc  -o "OpenV2G.exe" $(OBJS) $(USER_OBJS) $(LIBS)
-	@echo 'Finished building target: $@'
-	@echo ' '
-
-# Other Targets
-clean:
-	-$(RM) $(OBJS)$(C_DEPS)$(EXECUTABLES) OpenV2G.exe
-	-@echo ' '
-
-.PHONY: all clean dependents
-.SECONDARY:
-
--include ../makefile.targets

+ 0 - 8
Debug/objects.mk

@@ -1,8 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-USER_OBJS :=
-
-LIBS :=
-

+ 0 - 22
Debug/sources.mk

@@ -1,22 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-O_SRCS := 
-C_SRCS := 
-S_UPPER_SRCS := 
-OBJ_SRCS := 
-ASM_SRCS := 
-OBJS := 
-C_DEPS := 
-EXECUTABLES := 
-
-# Every subdirectory with source files must be described here
-SUBDIRS := \
-src/transport \
-src/test \
-src/service \
-src/codec/appHandCodec \
-src/codec \
-src/appHandshake \
-

+ 0 - 30
Debug/src/appHandshake/subdir.mk

@@ -1,30 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/appHandshake/appHand_DataDeserialization.c \
-../src/appHandshake/appHand_dataSerialization.c \
-../src/appHandshake/appHand_dataTypes.c 
-
-OBJS += \
-./src/appHandshake/appHand_DataDeserialization.o \
-./src/appHandshake/appHand_dataSerialization.o \
-./src/appHandshake/appHand_dataTypes.o 
-
-C_DEPS += \
-./src/appHandshake/appHand_DataDeserialization.d \
-./src/appHandshake/appHand_dataSerialization.d \
-./src/appHandshake/appHand_dataTypes.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/appHandshake/%.o: ../src/appHandshake/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O0 -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 36
Debug/src/codec/appHandCodec/subdir.mk

@@ -1,36 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/codec/appHandCodec/appHandEXICoder.c \
-../src/codec/appHandCodec/appHandEXIDecoder.c \
-../src/codec/appHandCodec/appHandEXIEncoder.c \
-../src/codec/appHandCodec/appHandNameTableEntries.c \
-../src/codec/appHandCodec/appHandQNames.c 
-
-OBJS += \
-./src/codec/appHandCodec/appHandEXICoder.o \
-./src/codec/appHandCodec/appHandEXIDecoder.o \
-./src/codec/appHandCodec/appHandEXIEncoder.o \
-./src/codec/appHandCodec/appHandNameTableEntries.o \
-./src/codec/appHandCodec/appHandQNames.o 
-
-C_DEPS += \
-./src/codec/appHandCodec/appHandEXICoder.d \
-./src/codec/appHandCodec/appHandEXIDecoder.d \
-./src/codec/appHandCodec/appHandEXIEncoder.d \
-./src/codec/appHandCodec/appHandNameTableEntries.d \
-./src/codec/appHandCodec/appHandQNames.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/codec/appHandCodec/%.o: ../src/codec/appHandCodec/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O0 -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 78
Debug/src/codec/subdir.mk

@@ -1,78 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/codec/AbstractDecoderChannel.c \
-../src/codec/AbstractEncoderChannel.c \
-../src/codec/BitDecoderChannel.c \
-../src/codec/BitEncoderChannel.c \
-../src/codec/BitInputStream.c \
-../src/codec/BitOutputStream.c \
-../src/codec/ByteDecoderChannel.c \
-../src/codec/ByteEncoderChannel.c \
-../src/codec/ByteStream.c \
-../src/codec/EXICoder.c \
-../src/codec/EXIDecoder.c \
-../src/codec/EXIEncoder.c \
-../src/codec/EXIHeaderDecoder.c \
-../src/codec/EXIHeaderEncoder.c \
-../src/codec/MethodsBag.c \
-../src/codec/NameTableEntries.c \
-../src/codec/QNames.c \
-../src/codec/StringTable.c \
-../src/codec/UCSString.c 
-
-OBJS += \
-./src/codec/AbstractDecoderChannel.o \
-./src/codec/AbstractEncoderChannel.o \
-./src/codec/BitDecoderChannel.o \
-./src/codec/BitEncoderChannel.o \
-./src/codec/BitInputStream.o \
-./src/codec/BitOutputStream.o \
-./src/codec/ByteDecoderChannel.o \
-./src/codec/ByteEncoderChannel.o \
-./src/codec/ByteStream.o \
-./src/codec/EXICoder.o \
-./src/codec/EXIDecoder.o \
-./src/codec/EXIEncoder.o \
-./src/codec/EXIHeaderDecoder.o \
-./src/codec/EXIHeaderEncoder.o \
-./src/codec/MethodsBag.o \
-./src/codec/NameTableEntries.o \
-./src/codec/QNames.o \
-./src/codec/StringTable.o \
-./src/codec/UCSString.o 
-
-C_DEPS += \
-./src/codec/AbstractDecoderChannel.d \
-./src/codec/AbstractEncoderChannel.d \
-./src/codec/BitDecoderChannel.d \
-./src/codec/BitEncoderChannel.d \
-./src/codec/BitInputStream.d \
-./src/codec/BitOutputStream.d \
-./src/codec/ByteDecoderChannel.d \
-./src/codec/ByteEncoderChannel.d \
-./src/codec/ByteStream.d \
-./src/codec/EXICoder.d \
-./src/codec/EXIDecoder.d \
-./src/codec/EXIEncoder.d \
-./src/codec/EXIHeaderDecoder.d \
-./src/codec/EXIHeaderEncoder.d \
-./src/codec/MethodsBag.d \
-./src/codec/NameTableEntries.d \
-./src/codec/QNames.d \
-./src/codec/StringTable.d \
-./src/codec/UCSString.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/codec/%.o: ../src/codec/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O0 -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 33
Debug/src/service/subdir.mk

@@ -1,33 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/service/v2g_dataTypes.c \
-../src/service/v2g_serviceClientStubs.c \
-../src/service/v2g_serviceDataSerialization.c \
-../src/service/v2g_serviceDispatcher.c 
-
-OBJS += \
-./src/service/v2g_dataTypes.o \
-./src/service/v2g_serviceClientStubs.o \
-./src/service/v2g_serviceDataSerialization.o \
-./src/service/v2g_serviceDispatcher.o 
-
-C_DEPS += \
-./src/service/v2g_dataTypes.d \
-./src/service/v2g_serviceClientStubs.d \
-./src/service/v2g_serviceDataSerialization.d \
-./src/service/v2g_serviceDispatcher.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/service/%.o: ../src/service/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O0 -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 39
Debug/src/test/subdir.mk

@@ -1,39 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/test/evse_server.c \
-../src/test/evse_serviceMethods.c \
-../src/test/main.c \
-../src/test/main_codec.c \
-../src/test/pev_service.c \
-../src/test/serviceClientDataTransmitter.c 
-
-OBJS += \
-./src/test/evse_server.o \
-./src/test/evse_serviceMethods.o \
-./src/test/main.o \
-./src/test/main_codec.o \
-./src/test/pev_service.o \
-./src/test/serviceClientDataTransmitter.o 
-
-C_DEPS += \
-./src/test/evse_server.d \
-./src/test/evse_serviceMethods.d \
-./src/test/main.d \
-./src/test/main_codec.d \
-./src/test/pev_service.d \
-./src/test/serviceClientDataTransmitter.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/test/%.o: ../src/test/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O0 -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 24
Debug/src/transport/subdir.mk

@@ -1,24 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/transport/v2gtp.c 
-
-OBJS += \
-./src/transport/v2gtp.o 
-
-C_DEPS += \
-./src/transport/v2gtp.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/transport/%.o: ../src/transport/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O0 -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 165
LICENSE.txt

@@ -1,165 +0,0 @@
-                   GNU LESSER GENERAL PUBLIC LICENSE
-                       Version 3, 29 June 2007
-
- Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
-
-  This version of the GNU Lesser General Public License incorporates
-the terms and conditions of version 3 of the GNU General Public
-License, supplemented by the additional permissions listed below.
-
-  0. Additional Definitions.
-
-  As used herein, "this License" refers to version 3 of the GNU Lesser
-General Public License, and the "GNU GPL" refers to version 3 of the GNU
-General Public License.
-
-  "The Library" refers to a covered work governed by this License,
-other than an Application or a Combined Work as defined below.
-
-  An "Application" is any work that makes use of an interface provided
-by the Library, but which is not otherwise based on the Library.
-Defining a subclass of a class defined by the Library is deemed a mode
-of using an interface provided by the Library.
-
-  A "Combined Work" is a work produced by combining or linking an
-Application with the Library.  The particular version of the Library
-with which the Combined Work was made is also called the "Linked
-Version".
-
-  The "Minimal Corresponding Source" for a Combined Work means the
-Corresponding Source for the Combined Work, excluding any source code
-for portions of the Combined Work that, considered in isolation, are
-based on the Application, and not on the Linked Version.
-
-  The "Corresponding Application Code" for a Combined Work means the
-object code and/or source code for the Application, including any data
-and utility programs needed for reproducing the Combined Work from the
-Application, but excluding the System Libraries of the Combined Work.
-
-  1. Exception to Section 3 of the GNU GPL.
-
-  You may convey a covered work under sections 3 and 4 of this License
-without being bound by section 3 of the GNU GPL.
-
-  2. Conveying Modified Versions.
-
-  If you modify a copy of the Library, and, in your modifications, a
-facility refers to a function or data to be supplied by an Application
-that uses the facility (other than as an argument passed when the
-facility is invoked), then you may convey a copy of the modified
-version:
-
-   a) under this License, provided that you make a good faith effort to
-   ensure that, in the event an Application does not supply the
-   function or data, the facility still operates, and performs
-   whatever part of its purpose remains meaningful, or
-
-   b) under the GNU GPL, with none of the additional permissions of
-   this License applicable to that copy.
-
-  3. Object Code Incorporating Material from Library Header Files.
-
-  The object code form of an Application may incorporate material from
-a header file that is part of the Library.  You may convey such object
-code under terms of your choice, provided that, if the incorporated
-material is not limited to numerical parameters, data structure
-layouts and accessors, or small macros, inline functions and templates
-(ten or fewer lines in length), you do both of the following:
-
-   a) Give prominent notice with each copy of the object code that the
-   Library is used in it and that the Library and its use are
-   covered by this License.
-
-   b) Accompany the object code with a copy of the GNU GPL and this license
-   document.
-
-  4. Combined Works.
-
-  You may convey a Combined Work under terms of your choice that,
-taken together, effectively do not restrict modification of the
-portions of the Library contained in the Combined Work and reverse
-engineering for debugging such modifications, if you also do each of
-the following:
-
-   a) Give prominent notice with each copy of the Combined Work that
-   the Library is used in it and that the Library and its use are
-   covered by this License.
-
-   b) Accompany the Combined Work with a copy of the GNU GPL and this license
-   document.
-
-   c) For a Combined Work that displays copyright notices during
-   execution, include the copyright notice for the Library among
-   these notices, as well as a reference directing the user to the
-   copies of the GNU GPL and this license document.
-
-   d) Do one of the following:
-
-       0) Convey the Minimal Corresponding Source under the terms of this
-       License, and the Corresponding Application Code in a form
-       suitable for, and under terms that permit, the user to
-       recombine or relink the Application with a modified version of
-       the Linked Version to produce a modified Combined Work, in the
-       manner specified by section 6 of the GNU GPL for conveying
-       Corresponding Source.
-
-       1) Use a suitable shared library mechanism for linking with the
-       Library.  A suitable mechanism is one that (a) uses at run time
-       a copy of the Library already present on the user's computer
-       system, and (b) will operate properly with a modified version
-       of the Library that is interface-compatible with the Linked
-       Version.
-
-   e) Provide Installation Information, but only if you would otherwise
-   be required to provide such information under section 6 of the
-   GNU GPL, and only to the extent that such information is
-   necessary to install and execute a modified version of the
-   Combined Work produced by recombining or relinking the
-   Application with a modified version of the Linked Version. (If
-   you use option 4d0, the Installation Information must accompany
-   the Minimal Corresponding Source and Corresponding Application
-   Code. If you use option 4d1, you must provide the Installation
-   Information in the manner specified by section 6 of the GNU GPL
-   for conveying Corresponding Source.)
-
-  5. Combined Libraries.
-
-  You may place library facilities that are a work based on the
-Library side by side in a single library together with other library
-facilities that are not Applications and are not covered by this
-License, and convey such a combined library under terms of your
-choice, if you do both of the following:
-
-   a) Accompany the combined library with a copy of the same work based
-   on the Library, uncombined with any other library facilities,
-   conveyed under the terms of this License.
-
-   b) Give prominent notice with the combined library that part of it
-   is a work based on the Library, and explaining where to find the
-   accompanying uncombined form of the same work.
-
-  6. Revised Versions of the GNU Lesser General Public License.
-
-  The Free Software Foundation may publish revised and/or new versions
-of the GNU Lesser General Public License from time to time. Such new
-versions will be similar in spirit to the present version, but may
-differ in detail to address new problems or concerns.
-
-  Each version is given a distinguishing version number. If the
-Library as you received it specifies that a certain numbered version
-of the GNU Lesser General Public License "or any later version"
-applies to it, you have the option of following the terms and
-conditions either of that published version or of any later version
-published by the Free Software Foundation. If the Library as you
-received it does not specify a version number of the GNU Lesser
-General Public License, you may choose any version of the GNU Lesser
-General Public License ever published by the Free Software Foundation.
-
-  If the Library as you received it specifies that a proxy can decide
-whether future versions of the GNU Lesser General Public License shall
-apply, that proxy's public statement of acceptance of any version is
-permanent authorization for you to choose that version for the
-Library.

+ 0 - 103
README.txt

@@ -1,103 +0,0 @@
--------------------------------------------------------------------------
-OpenV2G - an open source project implementing the basic functionality of the ISO IEC 15118 vehicle to grid (V2G) communication interface 
-Version 0.7, released July 2, 2012
-http://openv2g.sourceforge.net/
-
-Please report bugs via the SourceForge bug tracking system at http://sourceforge.net/tracker/?group_id=350113.
-Thank you.
-
-
-Copyright (C) 2007-2012 Siemens AG
-
-This program is free software: you can redistribute it and/or modify
-it under the terms of the GNU Lesser General Public License as published
-by the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU Lesser General Public License for more details.
-
-You should have received a copy of the GNU Lesser General Public License
-along with this program. If not, see <http://www.gnu.org/licenses/>.
-
-
-
--------------------------------------------------------------------------
-CHANGES from version 0.6:
--------------------------------------------------------------------------
-* adaption of V2G schema changes (reflects the 15118 DIS status)
-* reduced memory usage
-* skips schema derivations followed by the EXI Profile
-* bug-fixes
-
--------------------------------------------------------------------------
-CHANGES from version 0.5:
--------------------------------------------------------------------------
-* adaption of V2G schema changes
-* application handshake protocol implementation 
-* asynchronised communication
-* reduced memory usage
-* changed V2GTP byte order from little endian to big endian
-* bug-fixes
-* updated AC demo interaction between EV and EVSE, and
-* updated DC demo interaction between EV and EVSE
-
-
--------------------------------------------------------------------------
-CHANGES from version 0.4:
--------------------------------------------------------------------------
-* adaption of V2G schema changes
-* V2GTP implementation (replaces the DoIP implementation)
-* EXI default coder for the 15118 schema (replaces the strict mode of EXI)
-* AC demo interaction between PEV and EVSE, and
-* DC demo interaction between PEV and EVSE
-
-
--------------------------------------------------------------------------
-CHANGES from version 0.3.1:
--------------------------------------------------------------------------
-* adaption of V2G schema changes
-* supporting of DC messages
-* example program showing the message sequence of AC charging and 
-DC charging
-* bug-fixes
-
--------------------------------------------------------------------------
-CHANGES from version 0.3:
--------------------------------------------------------------------------
-* Bug-fixes
-* reduced memory usage
-* some type changes in the EXI codec and V2G service: 
-** struct v2gService->struct EXIService in v2g_service.h
-** size_t->uint16_t in v2g_serviceClientDataTransmitter.h and doIP.h
-* renaming of some enumeration values in v2g_serviceDataTypes.h
-
--------------------------------------------------------------------------
-CHANGES from version 0.2.2:
--------------------------------------------------------------------------
-* Bug-fixes
-* first DoIP implementation
-* V2G message error handling
-* adaption of V2G schema changes
-* code optimizations
-
--------------------------------------------------------------------------
-CHANGES from version 0.2.1:
--------------------------------------------------------------------------
-* Bug-fixes
-* adaption of V2G schema changes
-* some code optimizations
-
--------------------------------------------------------------------------
-CHANGES from version 0.2:
--------------------------------------------------------------------------
-* Bug-fixes
-* Fixed compiler warnings
-
--------------------------------------------------------------------------
-CHANGES from version 0.1:
--------------------------------------------------------------------------
-* Bug-fixes
-* Service and Client added

+ 0 - 49
Release/makefile

@@ -1,49 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
--include ../makefile.init
-
-RM := rm -rf
-
-# All of the sources participating in the build are defined here
--include sources.mk
--include src/transport/subdir.mk
--include src/test/subdir.mk
--include src/service/subdir.mk
--include src/codec/appHandCodec/subdir.mk
--include src/codec/subdir.mk
--include src/appHandshake/subdir.mk
--include subdir.mk
--include objects.mk
-
-ifneq ($(MAKECMDGOALS),clean)
-ifneq ($(strip $(C_DEPS)),)
--include $(C_DEPS)
-endif
-endif
-
--include ../makefile.defs
-
-# Add inputs and outputs from these tool invocations to the build variables 
-
-# All Target
-all: OpenV2G.exe
-
-# Tool invocations
-OpenV2G.exe: $(OBJS) $(USER_OBJS)
-	@echo 'Building target: $@'
-	@echo 'Invoking: MinGW C Linker'
-	gcc  -o "OpenV2G.exe" $(OBJS) $(USER_OBJS) $(LIBS)
-	@echo 'Finished building target: $@'
-	@echo ' '
-
-# Other Targets
-clean:
-	-$(RM) $(OBJS)$(C_DEPS)$(EXECUTABLES) OpenV2G.exe
-	-@echo ' '
-
-.PHONY: all clean dependents
-.SECONDARY:
-
--include ../makefile.targets

+ 0 - 8
Release/objects.mk

@@ -1,8 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-USER_OBJS :=
-
-LIBS :=
-

+ 0 - 22
Release/sources.mk

@@ -1,22 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-O_SRCS := 
-C_SRCS := 
-S_UPPER_SRCS := 
-OBJ_SRCS := 
-ASM_SRCS := 
-OBJS := 
-C_DEPS := 
-EXECUTABLES := 
-
-# Every subdirectory with source files must be described here
-SUBDIRS := \
-src/transport \
-src/test \
-src/service \
-src/codec/appHandCodec \
-src/codec \
-src/appHandshake \
-

+ 0 - 30
Release/src/appHandshake/subdir.mk

@@ -1,30 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/appHandshake/appHand_DataDeserialization.c \
-../src/appHandshake/appHand_dataSerialization.c \
-../src/appHandshake/appHand_dataTypes.c 
-
-OBJS += \
-./src/appHandshake/appHand_DataDeserialization.o \
-./src/appHandshake/appHand_dataSerialization.o \
-./src/appHandshake/appHand_dataTypes.o 
-
-C_DEPS += \
-./src/appHandshake/appHand_DataDeserialization.d \
-./src/appHandshake/appHand_dataSerialization.d \
-./src/appHandshake/appHand_dataTypes.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/appHandshake/%.o: ../src/appHandshake/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O3 -Os -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 36
Release/src/codec/appHandCodec/subdir.mk

@@ -1,36 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/codec/appHandCodec/appHandEXICoder.c \
-../src/codec/appHandCodec/appHandEXIDecoder.c \
-../src/codec/appHandCodec/appHandEXIEncoder.c \
-../src/codec/appHandCodec/appHandNameTableEntries.c \
-../src/codec/appHandCodec/appHandQNames.c 
-
-OBJS += \
-./src/codec/appHandCodec/appHandEXICoder.o \
-./src/codec/appHandCodec/appHandEXIDecoder.o \
-./src/codec/appHandCodec/appHandEXIEncoder.o \
-./src/codec/appHandCodec/appHandNameTableEntries.o \
-./src/codec/appHandCodec/appHandQNames.o 
-
-C_DEPS += \
-./src/codec/appHandCodec/appHandEXICoder.d \
-./src/codec/appHandCodec/appHandEXIDecoder.d \
-./src/codec/appHandCodec/appHandEXIEncoder.d \
-./src/codec/appHandCodec/appHandNameTableEntries.d \
-./src/codec/appHandCodec/appHandQNames.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/codec/appHandCodec/%.o: ../src/codec/appHandCodec/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O3 -Os -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 78
Release/src/codec/subdir.mk

@@ -1,78 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/codec/AbstractDecoderChannel.c \
-../src/codec/AbstractEncoderChannel.c \
-../src/codec/BitDecoderChannel.c \
-../src/codec/BitEncoderChannel.c \
-../src/codec/BitInputStream.c \
-../src/codec/BitOutputStream.c \
-../src/codec/ByteDecoderChannel.c \
-../src/codec/ByteEncoderChannel.c \
-../src/codec/ByteStream.c \
-../src/codec/EXICoder.c \
-../src/codec/EXIDecoder.c \
-../src/codec/EXIEncoder.c \
-../src/codec/EXIHeaderDecoder.c \
-../src/codec/EXIHeaderEncoder.c \
-../src/codec/MethodsBag.c \
-../src/codec/NameTableEntries.c \
-../src/codec/QNames.c \
-../src/codec/StringTable.c \
-../src/codec/UCSString.c 
-
-OBJS += \
-./src/codec/AbstractDecoderChannel.o \
-./src/codec/AbstractEncoderChannel.o \
-./src/codec/BitDecoderChannel.o \
-./src/codec/BitEncoderChannel.o \
-./src/codec/BitInputStream.o \
-./src/codec/BitOutputStream.o \
-./src/codec/ByteDecoderChannel.o \
-./src/codec/ByteEncoderChannel.o \
-./src/codec/ByteStream.o \
-./src/codec/EXICoder.o \
-./src/codec/EXIDecoder.o \
-./src/codec/EXIEncoder.o \
-./src/codec/EXIHeaderDecoder.o \
-./src/codec/EXIHeaderEncoder.o \
-./src/codec/MethodsBag.o \
-./src/codec/NameTableEntries.o \
-./src/codec/QNames.o \
-./src/codec/StringTable.o \
-./src/codec/UCSString.o 
-
-C_DEPS += \
-./src/codec/AbstractDecoderChannel.d \
-./src/codec/AbstractEncoderChannel.d \
-./src/codec/BitDecoderChannel.d \
-./src/codec/BitEncoderChannel.d \
-./src/codec/BitInputStream.d \
-./src/codec/BitOutputStream.d \
-./src/codec/ByteDecoderChannel.d \
-./src/codec/ByteEncoderChannel.d \
-./src/codec/ByteStream.d \
-./src/codec/EXICoder.d \
-./src/codec/EXIDecoder.d \
-./src/codec/EXIEncoder.d \
-./src/codec/EXIHeaderDecoder.d \
-./src/codec/EXIHeaderEncoder.d \
-./src/codec/MethodsBag.d \
-./src/codec/NameTableEntries.d \
-./src/codec/QNames.d \
-./src/codec/StringTable.d \
-./src/codec/UCSString.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/codec/%.o: ../src/codec/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O3 -Os -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 33
Release/src/service/subdir.mk

@@ -1,33 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/service/v2g_dataTypes.c \
-../src/service/v2g_serviceClientStubs.c \
-../src/service/v2g_serviceDataSerialization.c \
-../src/service/v2g_serviceDispatcher.c 
-
-OBJS += \
-./src/service/v2g_dataTypes.o \
-./src/service/v2g_serviceClientStubs.o \
-./src/service/v2g_serviceDataSerialization.o \
-./src/service/v2g_serviceDispatcher.o 
-
-C_DEPS += \
-./src/service/v2g_dataTypes.d \
-./src/service/v2g_serviceClientStubs.d \
-./src/service/v2g_serviceDataSerialization.d \
-./src/service/v2g_serviceDispatcher.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/service/%.o: ../src/service/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O3 -Os -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 39
Release/src/test/subdir.mk

@@ -1,39 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/test/evse_server.c \
-../src/test/evse_serviceMethods.c \
-../src/test/main.c \
-../src/test/main_codec.c \
-../src/test/pev_service.c \
-../src/test/serviceClientDataTransmitter.c 
-
-OBJS += \
-./src/test/evse_server.o \
-./src/test/evse_serviceMethods.o \
-./src/test/main.o \
-./src/test/main_codec.o \
-./src/test/pev_service.o \
-./src/test/serviceClientDataTransmitter.o 
-
-C_DEPS += \
-./src/test/evse_server.d \
-./src/test/evse_serviceMethods.d \
-./src/test/main.d \
-./src/test/main_codec.d \
-./src/test/pev_service.d \
-./src/test/serviceClientDataTransmitter.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/test/%.o: ../src/test/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O3 -Os -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 24
Release/src/transport/subdir.mk

@@ -1,24 +0,0 @@
-################################################################################
-# Automatically-generated file. Do not edit!
-################################################################################
-
-# Add inputs and outputs from these tool invocations to the build variables 
-C_SRCS += \
-../src/transport/v2gtp.c 
-
-OBJS += \
-./src/transport/v2gtp.o 
-
-C_DEPS += \
-./src/transport/v2gtp.d 
-
-
-# Each subdirectory must supply rules for building sources it contributes
-src/transport/%.o: ../src/transport/%.c
-	@echo 'Building file: $<'
-	@echo 'Invoking: GCC C Compiler'
-	gcc -I"../src/codec" -I"../src/codec/appHandCodec" -I"../src/appHandshake" -I"../src/transport" -I"../src/service" -I"../src/test" -O3 -Os -g3 -pedantic -pedantic-errors -Wall -c -fmessage-length=0 -ansi -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
-	@echo 'Finished building: $<'
-	@echo ' '
-
-

+ 0 - 16
data/test/sessionSetupReq.xml

@@ -1,16 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<v2gci_d:V2G_Message xmlns:v2gci_b="urn:iso:15118:2:2010:MsgBody"
- xmlns:xmlsig="http://www.w3.org/2000/09/xmldsig#"
- xmlns:v2gci_d="urn:iso:15118:2:2010:MsgDef"
- xmlns:v2gci_t="urn:iso:15118:2:2010:MsgDataTypes"
- xmlns:v2gci_h="urn:iso:15118:2:2010:MsgHeader"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
-    <v2gci_d:Header>
-            <v2gci_h:SessionID>0000000000000000</v2gci_h:SessionID>
-    </v2gci_d:Header>
-    <v2gci_d:Body>
-        <v2gci_b:SessionSetupReq>
-            <v2gci_b:EVCCID>01</v2gci_b:EVCCID>
-        </v2gci_b:SessionSetupReq>
-    </v2gci_d:Body>
-</v2gci_d:V2G_Message>

BIN
data/test/sessionSetupReq.xml.exi


+ 0 - 18
data/test/sessionSetupRes.xml

@@ -1,18 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<v2gci_d:V2G_Message xmlns:v2gci_b="urn:iso:15118:2:2010:MsgBody"
- xmlns:xmlsig="http://www.w3.org/2000/09/xmldsig#"
- xmlns:v2gci_d="urn:iso:15118:2:2010:MsgDef"
- xmlns:v2gci_t="urn:iso:15118:2:2010:MsgDataTypes"
- xmlns:v2gci_h="urn:iso:15118:2:2010:MsgHeader"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
-    <v2gci_d:Header>
-           <v2gci_h:SessionID>0000000000000010</v2gci_h:SessionID>
-    </v2gci_d:Header>
-    <v2gci_d:Body>
-        <v2gci_b:SessionSetupRes>
-            <v2gci_b:ResponseCode>OK</v2gci_b:ResponseCode>
-            <v2gci_b:EVSEID>01</v2gci_b:EVSEID>
-            <v2gci_b:DateTimeNow>123456789</v2gci_b:DateTimeNow>
-        </v2gci_b:SessionSetupRes>
-    </v2gci_d:Body>
-</v2gci_d:V2G_Message>

BIN
data/test/sessionSetupRes.xml.exi


+ 0 - 338
src/appHandshake/appHand_DataDeserialization.c

@@ -1,338 +0,0 @@
-
-
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
- 
- #include "appHand_service.h"
- #include "appHand_dataTypes.h"
- #include "EXITypes.h"
- #include "appHandEXIDecoder.h"
- #include "appHandEXIEncoder.h"
- #include "StringTable.h"
- #include "appHandQNameDefines.h"
- #include <string.h>
- 
-uint16_t numberOfLocalStringsDecode[EXI_appHandMAX_NUMBER_OF_QNAMES];
- 
- 
- static int _setUnsignedInt32Value(exi_integer_t* iv, uint32_t* int32) {
-	int errn = 0;
-	switch(iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		*int32 = iv->val.uint8;
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		*int32 = iv->val.uint16;
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		if (iv->val.uint32 <= 2147483647) {
-			*int32 = iv->val.uint32;
-		} else {
-			errn = -1;
-		}
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		errn = -1;
-		break;
-	/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		*int32 = iv->val.int8;
-		break;
-	case EXI_INTEGER_16:
-		*int32 = iv->val.int16;
-		break;
-	case EXI_INTEGER_32:
-		*int32 = iv->val.int32;
-		break;
-	case EXI_INTEGER_64:
-		errn = -1;
-		break;
-	}
-	return errn;
-}
- 
-
- /**
- * Deserialize an element or attribute value of the EXI stream and assign it to the
- * service data structure 
- */
-static int deserializeElementAttributeCharacter(struct EXIDatabinder* service)
-{
-
-	switch(service->qnameID) {
-		case 2: /* ProtocolNamespace */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.supportedAppProtocolReq->AppProtocol[service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol].ProtocolNamespace.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.supportedAppProtocolReq->AppProtocol[service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol].ProtocolNamespace.arraylen.data = service->val.str.miss.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 5: /* VersionNumberMajor */ 
-
-				if(service->val.type == EXI_DATATYPE_UNSIGNED_INTEGER) 
-					{
-						if(_setUnsignedInt32Value(&(service->val.integer),&(service->val.integer.val.uint32)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.supportedAppProtocolReq->AppProtocol[service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol].VersionNumberMajor=service->val.integer.val.uint32;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 6: /* VersionNumberMinor */ 
-
-				if(service->val.type == EXI_DATATYPE_UNSIGNED_INTEGER) 
-					{
-						if(_setUnsignedInt32Value(&(service->val.integer),&(service->val.integer.val.uint32)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.supportedAppProtocolReq->AppProtocol[service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol].VersionNumberMinor=service->val.integer.val.uint32;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 4: /* SchemaID */ 
-
-				if(service->val.type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) 
-					{
-						if( service->idPath.id[0] == 66)
-						{
-							service->exiMsg.supportedAppProtocolRes->SchemaID=service->val.integer.val.uint8;
-							service->exiMsg.supportedAppProtocolRes->isused.SchemaID=1;
-
-						} else if(service->idPath.id[0] == 65)
-						{
-							service->exiMsg.supportedAppProtocolReq->AppProtocol[service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol].SchemaID=service->val.integer.val.uint8;						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 1: /* Priority */ 
-
-				if(service->val.type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) 
-					{
-						service->exiMsg.supportedAppProtocolReq->AppProtocol[service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol].Priority=service->val.integer.val.uint8;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 3: /* ResponseCode */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						service->exiMsg.supportedAppProtocolRes->ResponseCode=service->val.enumeration;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-	
-	} 
-	return 0;
-}
- 
-/**
- * Deserialize an element of the EXI stream
- * @return 0 = 0K; -1 = ERROR
- */
-static int deserializeElement(struct EXIDatabinder* service)
-{
-	switch(service->qnameID) {
-			case 0: /* AppProtocol */ 
-						service->exiMsg.supportedAppProtocolReq->arraylen.AppProtocol++;
-	
-			break;
-		case 65: /* supportedAppProtocolReq */ 
-						service->exiMsg.isused.supportedAppProtocolReq=1;
-	
-			break;
-		case 66: /* supportedAppProtocolRes */ 
-						service->exiMsg.isused.supportedAppProtocolRes=1;
-	
-			break;
-	
-	}
-	return 0;
-}
-
-
- 
- 
-/**
-* Deserialize the appHand EXI stream
-* @return 0 = 0K; -1 = ERROR
-*/
-int deserialize_appHand(struct EXIDatabinder* service, uint8_t* inStream, uint16_t sizeInStream, struct EXIDocumentType_appHand* exiDoc)
-{
- 	exi_name_table_runtime_t runtimeTableDecode;
- 	uint32_t inPos;
- 	exi_string_table_t stringTableDecode = { 0, EXI_appHandMAX_NUMBER_OF_QNAMES, numberOfLocalStringsDecode};
- 	int noEndOfDocument = 1; /* true */
-	int returnCode=0;
-	
-
-	/* assign inStream data to service EXI structure */
-	inPos = service->transportHeaderOffset;
-	service->inStream.data = inStream;
-	service->inStream.size = sizeInStream+inPos;
-	service->inStream.pos = &inPos;
-	service->inStream.buffer=0;
-	service->inStream.capacity=0;
-
-
-	service->exiMsg=*exiDoc;
-
-	exiInitNameTableRuntime(&runtimeTableDecode);
-	exiappHandInitDecoder(&(service->inStream), &(service->stateDecode), runtimeTableDecode,stringTableDecode);
-
-	do {
-		exiappHandDecodeNextEvent(&(service->inStream), &(service->stateDecode), &(service->event));
-			if (returnCode < 0) {
-				return returnCode;
-			}
-
-			switch (service->event) {
-			case EXI_EVENT_START_DOCUMENT:
-
-				returnCode = exiappHandDecodeStartDocument(&(service->inStream), &(service->stateDecode));
-
-				break;
-			case EXI_EVENT_END_DOCUMENT:
-
-				returnCode = exiappHandDecodeEndDocument(&(service->inStream), &(service->stateDecode));
-				noEndOfDocument = 0; /* false */
-				break;
-			case EXI_EVENT_START_ELEMENT:
-				returnCode = exiappHandDecodeStartElement(&(service->inStream), &(service->stateDecode), &(service->qnameID));
-				service->idPath.id[service->idPath.pos++]=service->qnameID;
-				 
-				break;
-			case EXI_EVENT_END_ELEMENT:
-
-				returnCode = exiappHandDecodeEndElement(&(service->inStream), &(service->stateDecode), &(service->qnameID));
-				service->idPath.pos--;
-				 
-				returnCode = deserializeElement(service);
-				break;
-			case EXI_EVENT_CHARACTERS:
-				/* decode */
-				returnCode = exiappHandDecodeCharacters(&(service->inStream), &(service->stateDecode), &(service->val));
-				 
-				/* assign character data to the v2g message structure */
-				returnCode = deserializeElementAttributeCharacter(service);
-				break;
-			case EXI_EVENT_ATTRIBUTE:
-				/* decode */
-				returnCode = exiappHandDecodeAttribute(&(service->inStream), &(service->stateDecode), &(service->qnameID), &(service->val));
-				returnCode = deserializeElementAttributeCharacter(service);
-				break;
-			default:
-				/* ERROR */
-				return -1;
-			}
-
-		} while (noEndOfDocument);
-
-	return 0;
-}
- 
- 
- 
- 
-
-/** 
- * \brief   Initialize the appHand deserializer
- * \param	service  struct EXIDatabinder* Basic databinder structure
- * \param	service_bytes   bytes_t Reserved byte structure buffer 
- * \param	service_string   string_ucs_t* Reserved string structure buffer 
- * \param	transportHeaderOffset   uint16_t Offset of the used transport header (E.g., V2GTP needs 8 bytes)
- * \return  0 = 0K; -1 = ERROR */
-int init_appHandDeserializer(struct EXIDatabinder* service, exi_bytes_t service_bytes, exi_string_ucs_t service_string, uint16_t transportHeaderOffset)
-{
-
-	/* init byte array */
-	 service->val.binary = service_bytes;
-
-	/* init string array */
-	 service->val.str.miss = service_string;
-
-
-	 service->idPath.pos=0;
-
-	 /* init offset for transport protocol */
-	service->transportHeaderOffset=transportHeaderOffset;
-
-
-	return 0;
-}

+ 0 - 415
src/appHandshake/appHand_dataSerialization.c

@@ -1,415 +0,0 @@
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-#include "appHand_service.h"
-#include "appHand_dataTypes.h"
-#include "EXITypes.h"
-#include "StringTable.h"
-#include "appHandEXIEncoder.h"
-#include "appHandQNameDefines.h"
-#include <string.h>
- 
- uint16_t numberOfLocalStringsEncode[EXI_appHandMAX_NUMBER_OF_QNAMES];
- 
- 
-
-
-static int serialize_AppProtocolType(struct AppProtocolType* type, struct EXIDatabinder* service)
-{
-		
-
-
-			/* encode start element ProtocolNamespace */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 2)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ProtocolNamespace.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ProtocolNamespace.data,type->ProtocolNamespace.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ProtocolNamespace */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ProtocolNamespace */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element VersionNumberMajor */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 5)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->VersionNumberMajor;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  VersionNumberMajor */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of VersionNumberMajor */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element VersionNumberMinor */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 6)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->VersionNumberMinor;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  VersionNumberMinor */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of VersionNumberMinor */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element SchemaID */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 4)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint8=type->SchemaID;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_8;
-			
-			/* encode character  SchemaID */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SchemaID */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element Priority */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 1)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint8=type->Priority;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_8;
-			
-			/* encode character  Priority */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of Priority */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_AnonType_supportedAppProtocolReq(struct AnonType_supportedAppProtocolReq* type, struct EXIDatabinder* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.AppProtocol;i_loop++)
-		{
-				
-
-
-			/* encode start element AppProtocol */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 0)) 
-			{
-					return -1;
-			}
-			
-			/* encode children of AppProtocol */
-			if(serialize_AppProtocolType(&(type->AppProtocol[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of AppProtocol */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_AnonType_supportedAppProtocolRes(struct AnonType_supportedAppProtocolRes* type, struct EXIDatabinder* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 3)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.SchemaID)
-		{		
-						
-
-
-			/* encode start element SchemaID */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 4)) 
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint8=type->SchemaID;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_8;
-			
-			/* encode character  SchemaID */	
-			if (exiappHandEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val))) 
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SchemaID */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_EXIDocumentType_appHand(struct EXIDocumentType_appHand* type, struct EXIDatabinder* service)
-{
-
-	if(type->isused.supportedAppProtocolReq)
-		{		
-						
-
-
-			/* encode start element supportedAppProtocolReq */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 65)) 
-			{
-					return -1;
-			}
-						
-			/* encode children of supportedAppProtocolReq */
-			if(serialize_AnonType_supportedAppProtocolReq( (type->supportedAppProtocolReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of supportedAppProtocolReq */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.supportedAppProtocolRes)
-		{		
-						
-
-
-			/* encode start element supportedAppProtocolRes */	
-			if (exiappHandEncodeStartElement(&(service->outStream), &(service->stateEncode), 66)) 
-			{
-					return -1;
-			}
-						
-			/* encode children of supportedAppProtocolRes */
-			if(serialize_AnonType_supportedAppProtocolRes( (type->supportedAppProtocolRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of supportedAppProtocolRes */
-			exiappHandEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
- 
- 
- 
- 
- /* serialize data to EXI stream */
-static int serialize_message(struct EXIDatabinder* service)
- { 
-
-	/* encode start document */ 	
-	if (exiappHandEncodeStartDocument(&(service->outStream), &(service->stateEncode)) ) 
-	{
-	 
-		return -1;
-	}
-
- 	
-	if (serialize_EXIDocumentType_appHand(&(service->exiMsg), service))	 
-	 
-	 
-	{
-			 
-		return -1;
-	}
-
-
-	/* encode end document */
-	if (exiappHandEncodeEndDocument(&(service->outStream), &(service->stateEncode))) {
-	 
-	return -1;
-	}	
- 	
- 	return 0;
- 	
- }
-
- 
- 
-int serialize_appHand(struct EXIDatabinder* service, uint8_t* outStream, size_t* payloadLength, struct EXIDocumentType_appHand* exiDoc)
-{
- 	exi_name_table_runtime_t runtimeTableEncode;
-	exi_string_table_t stringTableEncode = { 0, EXI_appHandMAX_NUMBER_OF_QNAMES, numberOfLocalStringsEncode};
-
- 	uint32_t outPos =service->transportHeaderOffset;
- 
- 	/* assign outStream data to service EXI structure */
-	service->outStream.data = outStream;
-	service->outStream.pos = &outPos;
-	service->outStream.buffer=0;
-	service->outStream.capacity=8;
- 
-  	service->exiMsg = *exiDoc;
- 
-	/* init encoder (write header, set initial state) */
-	exiInitNameTableRuntime(&runtimeTableEncode);
-	exiappHandInitEncoder(&(service->outStream), &(service->stateEncode), runtimeTableEncode,stringTableEncode);
- 
-
-	if(serialize_message(service))
-	{
-		return -1;
-	}
-
-	outPos -= service->transportHeaderOffset;
-	*payloadLength = outPos;
-
-
- 	return 0;
- }
- 
-/* Initialize serializer */
-int init_appHandSerializer(struct EXIDatabinder* service, exi_bytes_t service_bytes, exi_string_ucs_t service_string, size_t max_outStream_size, uint16_t transportHeaderOffset)
-{
-
-	/* init byte array */
-	 service->val.binary = service_bytes;
-
-	/* init string array */
-	 service->val.str.miss = service_string;
-
-	 /* init output stream */
-
-	 service->outStream.size=max_outStream_size;
-
-	 service->transportHeaderOffset=transportHeaderOffset;
-
-
-	return 0;
-}
- 

+ 0 - 70
src/appHandshake/appHand_dataTypes.c

@@ -1,70 +0,0 @@
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-#include "EXITypes.h"
-#include "appHand_dataTypes.h"
-
-
-static  void init_protocolNamespaceType(struct protocolNamespaceType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_AppProtocolType(struct AppProtocolType* type)
-{	
-	init_protocolNamespaceType(&(type->ProtocolNamespace));				
-
-}
-
-void init_AnonType_supportedAppProtocolReq(struct AnonType_supportedAppProtocolReq* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<20;i_loop++)
-	{
-		init_AppProtocolType(&(type->AppProtocol[i_loop]));
-	}
-	
-	type->arraylen.AppProtocol=0;
-
-}
-
-void init_AnonType_supportedAppProtocolRes(struct AnonType_supportedAppProtocolRes* type)
-{			
-	type->isused.SchemaID=0;
-
-}
-
-void init_EXIDocumentType_appHand(struct EXIDocumentType_appHand* type)
-{		
-	type->isused.supportedAppProtocolReq=0;		
-	type->isused.supportedAppProtocolRes=0;
-
-}

+ 0 - 133
src/appHandshake/appHand_dataTypes.h

@@ -1,133 +0,0 @@
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef APPHANDDATATYPES_H
-#define APPHANDDATATYPES_H
-
-#include "EXITypes.h"
-
-
-	
-
-enum responseCodeType_appHand
-{
-	OK_SuccessfulNegotiation_responseCodeType=0, 
-	OK_SuccessfulNegotiationWithMinorDeviation_responseCodeType=1, 
-	Failed_NoNegotiation_responseCodeType=2
-
-}; 
-
-
-
-
-struct arraylen_protocolNamespaceType
-{
-	size_t data;
-
-
-};
-
-struct protocolNamespaceType
-{
-	uint32_t data[100];
-	struct arraylen_protocolNamespaceType arraylen;
-
-};
-
-struct AppProtocolType
-{
-	struct protocolNamespaceType ProtocolNamespace;
-	uint32_t VersionNumberMajor;
-	uint32_t VersionNumberMinor;
-	uint8_t SchemaID;
-	uint8_t Priority;
-
-
-};
-
-struct arraylen_AnonType_supportedAppProtocolReq
-{
-	size_t AppProtocol;
-
-
-};
-
-struct AnonType_supportedAppProtocolReq
-{
-	struct AppProtocolType AppProtocol[20];
-	struct arraylen_AnonType_supportedAppProtocolReq arraylen;
-
-};
-
-struct selection_EXIDocumentType_appHand
-{
-	unsigned int supportedAppProtocolReq:1;
-	unsigned int supportedAppProtocolRes:1;
-
-
-};
-
-struct selection_AnonType_supportedAppProtocolRes
-{
-	unsigned int SchemaID:1;
-
-
-};
-
-struct AnonType_supportedAppProtocolRes
-{
-	enum responseCodeType_appHand ResponseCode;
-	uint8_t SchemaID;
-	struct selection_AnonType_supportedAppProtocolRes isused;
-
-};
-
-struct EXIDocumentType_appHand
-{
-	struct AnonType_supportedAppProtocolReq* supportedAppProtocolReq;
-	struct AnonType_supportedAppProtocolRes* supportedAppProtocolRes;
-	struct selection_EXIDocumentType_appHand isused;
-
-};
-
-
-void init_EXIDocumentType_appHand(struct EXIDocumentType_appHand* type);
-void init_AnonType_supportedAppProtocolRes(struct AnonType_supportedAppProtocolRes* type);
-void init_AnonType_supportedAppProtocolReq(struct AnonType_supportedAppProtocolReq* type);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 87
src/appHandshake/appHand_service.h

@@ -1,87 +0,0 @@
-/*
- * Copyright (C) 2007-2010 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI_DATABINDER_H_
-#define EXI_DATABINDER_H_
-
-#include "appHand_dataTypes.h"
-
-struct uniqueIDPath2
-{
-	int id[10];
-	size_t pos;
-};
-
-
-struct EXIDatabinder
-{
-	/* in-/ out-stream */
-	bitstream_t inStream;
-	bitstream_t outStream;
-
-	/* EXI */
-	exi_state_t stateDecode;
-	exi_state_t stateEncode;
-	exi_event_t event;
-	exi_value_t val;
-	uint16_t qnameID;
-
-	/* main message data structure */
-	struct EXIDocumentType_appHand exiMsg;
-
-	/* unique id for ambiguous elements */
-	struct uniqueIDPath2 idPath;
-
-	uint16_t transportHeaderOffset;
-
-	/* error code */
-	uint8_t errorCode;
-};
-
-int serialize_appHand(struct EXIDatabinder* service, uint8_t* outStream, size_t* payloadLength, struct EXIDocumentType_appHand* exiDoc);
-int deserialize_appHand(struct EXIDatabinder* service, uint8_t* inStream, uint16_t sizeInStream, struct EXIDocumentType_appHand* exiDoc);
-int init_appHandSerializer(struct EXIDatabinder* service, exi_bytes_t service_bytes, exi_string_ucs_t service_string, size_t max_outStream_size, uint16_t transportHeaderOffset);
-int init_appHandDeserializer(struct EXIDatabinder* service, exi_bytes_t bytes, exi_string_ucs_t string, uint16_t transportHeaderOffset);
-
-
-
-/* define error codes */
-#define EXI_NON_VALID_MESSAGE 0x01
-#define EXI_SERIALIZATION_FAILED 0x02
-#define EXI_DESERIALIZATION_FAILED 0x03
-#define EXI_DATATYPE_FAILED 0x04
-#define EXI_VALUE_RANGE_FAILED 0x05
-
-#define EXI_UNKNOWN_ERROR 0xFF
-
-#endif /* EXI_DATABINDER_H_ */
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 700
src/codec/AbstractDecoderChannel.c

@@ -1,700 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
- 
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "DecoderChannel.h"
-#include "CoderChannel.h"
-#include "BitInputStream.h"
-#include "EXIOptions.h"
-#include "EXITypes.h"
-#include "MethodsBag.h"
-#include "EXICoder.h"
-#include "ErrorCodes.h"
-
-
-#ifndef ABSTRACT_DECODER_CHANNEL_C
-#define ABSTRACT_DECODER_CHANNEL_C
-
-/* unsigned long == 64 bits, 10 * 7bits = 70 bits */
-#define MAX_OCTETS_FOR_UNSIGNED_INTEGER_64 10
-/* unsigned int == 32 bits, 5 * 7bits = 35 bits */
-#define MAX_OCTETS_FOR_UNSIGNED_INTEGER_32 5
-
-/* buffer for reading (arbitrary) large integer values */
-static uint8_t maskedOctets[MAX_OCTETS_FOR_UNSIGNED_INTEGER_64];
-
-
-static int _decodeUnsignedInteger(bitstream_t* stream, exi_integer_t* iv, int negative) {
-	int errn = 0;
-	int i, k;
-	uint8_t b;
-
-	for (i = 0; i < MAX_OCTETS_FOR_UNSIGNED_INTEGER_64; i++) {
-		/* Read the next octet */
-		errn = decode(stream, &b);
-		/* If the most significant bit of the octet was 1,
-		   another octet is going to come */
-		if (b < 128) {
-			/* no more octets */
-
-			/* For negative values, the Unsigned Integer holds the
-			 * magnitude of the value minus 1 */
-
-			switch(i) {
-			case 0: /* 7 bits */
-				if (negative) {
-					iv->val.int8 =  - ( b + 1);
-					iv->type = EXI_INTEGER_8;
-				} else {
-					iv->val.uint8 = b;
-					iv->type = EXI_UNSIGNED_INTEGER_8;
-				}
-				return 0;
-			case 1: /* 14 bits */
-				maskedOctets[i] = b;
-				iv->val.uint16 = 0;
-				for (k = i; k >= 0 ; k--) {
-					iv->val.uint16  = (iv->val.uint16 << 7) | maskedOctets[k];
-				}
-				if (negative) {
-					iv->val.int16 = - ( iv->val.uint16 + 1 );
-					iv->type = EXI_INTEGER_16;
-				} else {
-					iv->type = EXI_UNSIGNED_INTEGER_16;
-				}
-				return 0;
-			case 2: /* 21 bits */
-			case 3: /* 28 bits */
-				maskedOctets[i] = b;
-				iv->val.uint32 = 0;
-				for (k = i; k >= 0 ; k--) {
-					iv->val.uint32 = (iv->val.uint32 << 7) | maskedOctets[k];
-				}
-				if (negative) {
-					iv->val.int32 = (-1) * ( iv->val.uint32 + 1 );
-					if (iv->val.int32 <= INT16_MAX && iv->val.int32 >= INT16_MIN ) {
-						iv->type = EXI_INTEGER_16;
-					} else {
-						iv->type = EXI_INTEGER_32;
-					}
-				} else {
-					if (iv->val.uint32 <= UINT16_MAX) {
-						iv->type = EXI_UNSIGNED_INTEGER_16;
-					} else {
-						iv->type = EXI_UNSIGNED_INTEGER_32;
-					}
-				}
-				return 0;
-			case 4: /* 35 bits */
-			case 5: /* 42 bits */
-			case 6: /* 49 bits */
-			case 7: /* 56 bits */
-			case 8: /* 63 bits */
-			case 9: /* 70 bits */
-				maskedOctets[i] = b;
-				iv->val.uint64 = 0;
-				for (k = i; k >= 0 ; k--) {
-					iv->val.uint64  = (iv->val.uint64 << 7) | maskedOctets[k];
-				}
-				if (negative) {
-					if (i > 8) {
-						/* too large */
-						return EXI_UNSUPPORTED_INTEGER_VALUE;
-					}
-					iv->val.int64 = (-1) * ( iv->val.uint64 + 1 );
-					if (iv->val.int64 <= INT32_MAX && iv->val.int64 >= INT32_MIN ) {
-						iv->type = EXI_INTEGER_32;
-					} else {
-						iv->type = EXI_INTEGER_64;
-					}
-				} else {
-					if (iv->val.uint64 <= UINT32_MAX) {
-						iv->type = EXI_UNSIGNED_INTEGER_32;
-						/* iv->val.uint32 = iv->val.uint64;*/
-					} else {
-						iv->type = EXI_UNSIGNED_INTEGER_64;
-					}
-				}
-				return 0;
-			default:
-				return EXI_UNSUPPORTED_INTEGER_VALUE;
-			}
-		} else {
-			/* the 7 least significant bits hold the actual value */
-			maskedOctets[i] = (b & 127);
-		}
-	}
-
-
-	return EXI_UNSUPPORTED_INTEGER_VALUE;
-}
-
-int decodeUnsignedInteger(bitstream_t* stream, exi_integer_t* iv) {
-	return _decodeUnsignedInteger(stream, iv, 0);
-}
-
-int decodeUnsignedInteger16(bitstream_t* stream, uint16_t* uint16) {
-	unsigned int mShift = 0;
-	int errn = 0;
-	uint8_t b;
-	*uint16 = 0;
-
-	do {
-		/* 1. Read the next octet */
-		errn = decode(stream, &b);
-		/* 2. Multiply the value of the unsigned number represented by the 7
-		 * least significant
-		 * bits of the octet by the current multiplier and add the result to
-		 * the current value */
-		*uint16 += (b & 127) << mShift;
-		/* 3. Multiply the multiplier by 128 */
-		mShift += 7;
-		/* 4. If the most significant bit of the octet was 1, go back to step 1 */
-	} while (errn >= 0 && (b >> 7) == 1);
-
-	return errn;
-}
-
-int decodeUnsignedInteger32(bitstream_t* stream, uint32_t* uint32) {
-	/* 0XXXXXXX ... 1XXXXXXX 1XXXXXXX */
-	unsigned int mShift = 0;
-	int errn = 0;
-	uint8_t b;
-	*uint32 = 0;
-
-	do {
-		/* 1. Read the next octet */
-		errn = decode(stream, &b);
-		/* 2. Multiply the value of the unsigned number represented by the 7
-		 * least significant
-		 * bits of the octet by the current multiplier and add the result to
-		 * the current value */
-		*uint32 += (b & 127) << mShift;
-		/* 3. Multiply the multiplier by 128 */
-		mShift += 7;
-		/* 4. If the most significant bit of the octet was 1, go back to step 1 */
-	} while (errn >= 0 && (b >> 7) == 1);
-
-	return errn;
-}
-
-/**
- * Decode an arbitrary precision non negative integer using a sequence of
- * octets. The most significant bit of the last octet is set to zero to
- * indicate sequence termination. Only seven bits per octet are used to
- * store the integer's value.
- */
-int decodeUnsignedInteger64(bitstream_t* stream, uint64_t* uint64) {
-	unsigned int mShift = 0;
-	int errn = 0;
-	uint8_t b;
-	*uint64 = 0L;
-
-	do {
-		errn = decode(stream, &b);
-		*uint64 += ((uint64_t) (b & 127)) << mShift;
-		mShift += 7;
-	} while (errn >= 0 && (b >> 7) == 1);
-
-	return errn;
-}
-
-
-int decodeInteger(bitstream_t* stream, exi_integer_t* iv) {
-	int b;
-	int errn = decodeBoolean(stream, &b);
-	if (errn < 0) {
-		return errn;
-	}
-
-	return _decodeUnsignedInteger(stream, iv, b);
-}
-
-
-/**
- * Decode an arbitrary precision integer using a sign bit followed by a
- * sequence of octets. The most significant bit of the last octet is set to
- * zero to indicate sequence termination. Only seven bits per octet are used
- * to store the integer's value.
- */
-int decodeInteger16(bitstream_t* stream, int16_t* int16) {
-	int b;
-	uint16_t uint16;
-	int errn = decodeBoolean(stream, &b);
-
-	if (errn < 0) {
-		return errn;
-	}
-
-	if (b) {
-		/* For negative values, the Unsigned Integer holds the
-		 * magnitude of the value minus 1 */
-		errn = decodeUnsignedInteger16(stream, &uint16);
-		*int16 = -(uint16 + 1);
-	} else {
-		/* positive */
-		errn = decodeUnsignedInteger16(stream, &uint16);
-		*int16 = (int16_t)(uint16);
-	}
-
-	return errn;
-}
-
-/**
- * Decode an arbitrary precision integer using a sign bit followed by a
- * sequence of octets. The most significant bit of the last octet is set to
- * zero to indicate sequence termination. Only seven bits per octet are used
- * to store the integer's value.
- */
-int decodeInteger32(bitstream_t* stream, int32_t* int32) {
-	int b;
-	uint32_t uint32;
-	int errn = decodeBoolean(stream, &b);
-
-	if (errn < 0) {
-		return errn;
-	}
-
-	if (b) {
-		/* For negative values, the Unsigned Integer holds the
-		 * magnitude of the value minus 1 */
-		errn = decodeUnsignedInteger32(stream, &uint32);
-		*int32 = (-1) * (uint32 + 1);
-	} else {
-		/* positive */
-		errn = decodeUnsignedInteger32(stream, &uint32);
-		*int32 = (int32_t)(uint32);
-	}
-
-	return errn;
-}
-
-/**
- * Decode an arbitrary precision integer using a sign bit followed by a
- * sequence of octets. The most significant bit of the last octet is set to
- * zero to indicate sequence termination. Only seven bits per octet are used
- * to store the integer's value.
- */
-int decodeInteger64(bitstream_t* stream, int64_t* int64) {
-	int b;
-	uint64_t uint64;
-	int errn = decodeBoolean(stream, &b);
-
-	if (errn < 0) {
-		return errn;
-	}
-
-	if (b) {
-		/* For negative values, the Unsigned Integer holds the
-		 * magnitude of the value minus 1 */
-		errn = decodeUnsignedInteger64(stream, &uint64);
-		*int64 = (-1) * (uint64 + 1);
-	} else {
-		/* positive */
-		errn = decodeUnsignedInteger64(stream, &uint64);
-		*int64 = (int64_t)(uint64);
-	}
-
-	return errn;
-}
-
-/**
- * Decode a Float datatype as two consecutive Integers.
- * The first Integer represents the mantissa of the floating point
- * number and the second Integer represents the base-10 exponent
- * of the floating point number.
- */
-int decodeFloat(bitstream_t* stream, exi_float_me_t* f) {
-	int errn = decodeInteger64(stream, &f->mantissa);
-	if (errn < 0) {
-		return errn;
-	}
-	return decodeInteger16(stream, &f->exponent);
-}
-
-/**
- * Decode a decimal represented as a Boolean sign followed by two Unsigned
- * Integers. A sign value of zero (0) is used to represent positive Decimal
- * values and a sign value of one (1) is used to represent negative Decimal
- * values The first Integer represents the integral portion of the Decimal
- * value. The second positive integer represents the fractional portion of
- * the decimal with the digits in reverse order to preserve leading zeros.
- */
-int decodeDecimal(bitstream_t* stream, exi_decimal_t* d) {
-	int errn = decodeBoolean(stream, &d->negative);
-	if (errn < 0) {
-		return errn;
-	}
-	errn = decodeUnsignedInteger(stream, &d->integral);
-	if (errn < 0) {
-		return errn;
-	}
-	errn = decodeUnsignedInteger(stream, &d->reverseFraction);
-
-	return errn;
-}
-
-/**
- * Decode a sequence of characters for a given length.
- */
-int decodeStringOnly(bitstream_t* stream, uint16_t len, exi_string_ucs_t* s) {
-	int errn;
-	if (len > s->size) {
-		/* not enough space */
-		return EXI_ERROR_OUT_OF_STRING_BUFFER;
-	}
-	errn = decodeCharacters(stream, len, s->codepoints);
-	s->len = len;
-	return errn;
-}
-
-/**
- * Decode a length prefixed sequence of characters.
- */
-int decodeString(bitstream_t* stream, exi_string_ucs_t* s) {
-	int errn = decodeUnsignedInteger16(stream, &s->len);
-	if (errn < 0) {
-		return errn;
-	}
-	return decodeStringOnly(stream, s->len, s);
-}
-
-/*
-int decodeStringASCII(bitstream_t* stream, exi_string_ascii_t* s) {
-	uint16_t slen;
-	int errn = decodeUnsignedInteger16(stream, &slen);
-	if (errn < 0) {
-		return errn;
-	}
-	if (s->size < slen) {
-		return EXI_ERROR_OUT_OF_ASCII_BUFFER;
-	}
-
-	return decodeCharactersASCII(stream, slen, s->chars);
-}
-*/
-
-
-
-static int _readStringValueLocalHit(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, uint32_t* localID) {
-	int errn;
-	uint16_t codingLength;
-
-	if(!(state->stringTable.sizeLocalStrings > qnameID)) {
-		return EXI_ERROR_OUT_OF_BOUNDS;
-	}
-
-	errn = exiGetCodingLength(state->stringTable.numberOfLocalStrings[qnameID], &codingLength);
-	if(errn) {
-		return errn;
-	}
-	errn = decodeNBitUnsignedInteger(stream, codingLength, localID);
-
-	return errn;
-}
-
-
-static int _readStringValueGlobalHit(bitstream_t* stream, exi_state_t* state, uint32_t* globalID) {
-	int errn;
-	uint16_t codingLength;
-
-	errn = exiGetCodingLength(state->stringTable.numberOfGlobalStrings, &codingLength);
-	if(errn) {
-		return errn;
-	}
-	errn = decodeNBitUnsignedInteger(stream, codingLength, globalID);
-
-	return errn;
-}
-
-int decodeStringValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, exi_string_value_t* s) {
-	uint16_t L;
-	int errn = decodeUnsignedInteger16(stream, &L);
-	if (errn < 0) {
-		return errn;
-	}
-
-	switch (L) {
-	case 0:
-		/* local value partition */
-		s->type = EXI_STRING_VALUE_LOCAL_HIT;
-		errn = _readStringValueLocalHit(stream, state, qnameID, &s->localID);
-		break;
-	case 1:
-		/* found in global value partition */
-		s->type = EXI_STRING_VALUE_GLOBAL_HIT;
-		errn = _readStringValueGlobalHit(stream, state, &s->globalID);
-		break;
-	default:
-		/* not found in global value (and local value) partition
-		 * ==> string literal is encoded as a String with the length
-		 * incremented by two */
-		s->type = EXI_STRING_VALUE_MISS;
-		s->miss.len = L = L - 2;
-		errn = decodeStringOnly(stream, L, &(s->miss));
-		if(errn) {
-			return errn;
-		}
-#if EXI_VALUE_PARTITION_CAPACITY != 0
-#if EXI_VALUE_MAX_LENGTH != 0
-		/* If length L is greater than zero the string S is added */
-		if(L > 0) {
-			/* After encoding the string value, it is added to both the
-			 * associated "local" value string table partition and the global
-			 * value string table partition */
-#if EXI_VALUE_MAX_LENGTH < 0
-			errn = exi__IncrementStringValueCount(state, qnameID);
-# else /* EXI_VALUE_MAX_LENGTH < 0  */
-			if (L <= EXI_VALUE_MAX_LENGTH) {
-				errn = exi__IncrementStringValueCount(state, qnameID);
-			}
-#endif /* EXI_VALUE_MAX_LENGTH < 0  */
-		}
-#endif /* EXI_VALUE_MAX_LENGTH != 0 */
-#endif /* EXI_VALUE_PARTITION_CAPACITY != 0 */
-		break;
-	}
-
-	return errn;
-}
-
-int decodeRCSStringValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, exi_rcs_t* rcs, exi_string_value_t* s) {
-	unsigned int i;
-	uint32_t cp;
-	uint16_t L;
-	int errn = decodeUnsignedInteger16(stream, &L);
-	if (errn < 0) {
-		return errn;
-	}
-
-	switch (L) {
-	case 0:
-		/* local value partition */
-		s->type = EXI_STRING_VALUE_LOCAL_HIT;
-		errn = _readStringValueLocalHit(stream, state, qnameID, &s->localID);
-		break;
-	case 1:
-		/* found in global value partition */
-		s->type = EXI_STRING_VALUE_GLOBAL_HIT;
-		errn = _readStringValueGlobalHit(stream, state, &s->globalID);
-		break;
-	default:
-		/* not found in global value (and local value) partition
-		 * ==> string literal is encoded as a String with the length
-		 * incremented by two */
-		s->type = EXI_STRING_VALUE_MISS;
-		s->miss.len = L = L - 2;
-
-		if (L > s->miss.size) {
-			/* not enough space */
-			return EXI_ERROR_OUT_OF_STRING_BUFFER;
-		}
-
-		for (i = 0; i < L && errn >= 0; i++) {
-			errn = decodeNBitUnsignedInteger(stream, rcs->codingLength, &cp);
-			if (errn) {
-				return errn;
-			}
-			s->miss.codepoints[i] = rcs->codepoints[cp];
-		}
-#if EXI_VALUE_PARTITION_CAPACITY != 0
-#if EXI_VALUE_MAX_LENGTH != 0
-		/* If length L is greater than zero the string S is added */
-		if(L > 0) {
-			/* After encoding the string value, it is added to both the
-			 * associated "local" value string table partition and the global
-			 * value string table partition */
-#if EXI_VALUE_MAX_LENGTH < 0
-			errn = exi__IncrementStringValueCount(state, qnameID);
-# else /* EXI_VALUE_MAX_LENGTH < 0  */
-			if (L <= EXI_VALUE_MAX_LENGTH) {
-				errn = exi__IncrementStringValueCount(state, qnameID);
-			}
-#endif /* EXI_VALUE_MAX_LENGTH < 0  */
-		}
-#endif /* EXI_VALUE_MAX_LENGTH != 0 */
-#endif /* EXI_VALUE_PARTITION_CAPACITY != 0 */
-		break;
-	}
-
-	return errn;
-}
-
-/**
- * Decode a sequence of characters according to a given length.
- * Each character is represented by its UCS [ISO/IEC 10646]
- * code point encoded as an Unsigned Integer
- */
-int decodeCharacters(bitstream_t* stream, uint16_t len, uint32_t* chars) {
-	unsigned int i;
-	int errn = 0;
-	for (i = 0; i < len && errn >= 0; i++) {
-		errn = decodeUnsignedInteger32(stream, &chars[i]);
-		if (errn < 0) {
-			return errn;
-		}
-	}
-
-	return errn;
-}
-
-/*
-int decodeCharactersASCII(bitstream_t* stream, uint16_t len, char* chars) {
-	unsigned int i;
-	uint32_t c;
-	int errn = 0;
-	for (i = 0; i < len && errn >= 0; i++) {
-		errn = decodeUnsignedInteger32(stream, &c);
-		if (errn < 0) {
-			return errn;
-		}
-		if (c > 127) {
-			return EXI_ERROR_CONVERSION_NO_ASCII_CHARACTERS;
-		}
-		chars[i] = c;
-	}
-	chars[i] = '\0';
-
-	return errn;
-}
-*/
-
-
-/**
- * Decode a binary value as a length-prefixed sequence of octets.
- */
-int decodeBinary(bitstream_t* stream, exi_bytes_t* bytes) {
-	unsigned int i;
-	uint8_t b;
-	int errn = decodeUnsignedInteger16(stream, &bytes->len);
-	if (errn < 0) {
-		return errn;
-	}
-	if (bytes->len > bytes->size) {
-		/* not enough space */
-		return EXI_ERROR_OUT_OF_BYTE_BUFFER;
-	}
-
-	for (i = 0; i < bytes->len && errn >= 0; i++) {
-		errn = decode(stream, &b);
-		if (errn < 0) {
-			return errn;
-		}
-		bytes->data[i] = (uint8_t)b;
-	}
-
-	return errn;
-}
-
-/**
- * Decode Date-Time as sequence of values representing the individual
- * components of the Date-Time.
- */
-int decodeDateTime(bitstream_t* stream, exi_datetime_type_t type, exi_datetime_t* datetime) {
-	int errn;
-
-	datetime->type = type;
-
-	datetime->year = 0;
-	datetime->monthDay = 0;
-	datetime->time = 0;
-	datetime->presenceFractionalSecs = 0;
-	datetime->fractionalSecs = 0;
-	datetime->presenceTimezone = 0;
-	datetime->timezone = 0;
-
-	switch (type) {
-	case EXI_DATETIME_GYEAR: /* Year, [Time-Zone] */
-		errn = decodeInteger32(stream, &datetime->year);
-		if (errn < 0) {
-			return errn;
-		}
-		datetime->year += DATETIME_YEAR_OFFSET;
-		break;
-	case EXI_DATETIME_GYEARMONTH: /* Year, MonthDay, [TimeZone] */
-	case EXI_DATETIME_DATE:
-		errn = decodeInteger32(stream, &datetime->year);
-		if (errn < 0) {
-			return errn;
-		}
-		datetime->year += DATETIME_YEAR_OFFSET;
-		errn = decodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_MONTHDAY, &datetime->monthDay);
-		break;
-	case EXI_DATETIME_DATETIME: /* Year, MonthDay, Time, [FractionalSecs], [TimeZone] */
-		/* e.g. "0001-01-01T00:00:00.111+00:33"  */
-		errn = decodeInteger32(stream, &datetime->year);
-		if (errn < 0) {
-			return errn;
-		}
-		datetime->year += DATETIME_YEAR_OFFSET;
-		errn = decodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_MONTHDAY, &datetime->monthDay);
-		if (errn < 0) {
-			return errn;
-		}
-		/* no break */
-	case EXI_DATETIME_TIME: /* Time, [FractionalSecs], [TimeZone] */
-		/* e.g. "12:34:56.135"  */
-		errn = decodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_TIME, &datetime->time);
-		if (errn < 0) {
-			return errn;
-		}
-		errn = decodeBoolean(stream, &datetime->presenceFractionalSecs);
-		if (errn < 0) {
-			return errn;
-		}
-		if (datetime->presenceFractionalSecs) {
-			errn = decodeUnsignedInteger32(stream, &datetime->fractionalSecs);
-		}
-		break;
-	case EXI_DATETIME_GMONTH: /* MonthDay, [TimeZone] */
-		/* e.g. "--12" */
-	case EXI_DATETIME_GMONTHDAY: /* MonthDay, [TimeZone] */
-		/* e.g. "--01-28"  */
-	case EXI_DATETIME_GDAY: /* MonthDay, [TimeZone] */
-		/* "---16"  */
-		errn = decodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_MONTHDAY, &datetime->monthDay );
-		break;
-	default:
-		return -1;
-	}
-
-	errn = decodeBoolean(stream, &datetime->presenceTimezone );
-	if (errn < 0) {
-		return errn;
-	}
-	if (datetime->presenceTimezone) {
-		errn = decodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_TIMEZONE, &datetime->timezone);
-		datetime->timezone -= DATETIME_TIMEZONE_OFFSET_IN_MINUTES;
-	}
-
-	return errn;
-}
-
-#endif
-

+ 0 - 573
src/codec/AbstractEncoderChannel.c

@@ -1,573 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "EncoderChannel.h"
-#include "CoderChannel.h"
-#include "BitOutputStream.h"
-#include "EXIOptions.h"
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-#include "MethodsBag.h"
-#include "EXICoder.h"
-
-#ifndef ABSTRACT_ENCODER_CHANNEL_C
-#define ABSTRACT_ENCODER_CHANNEL_C
-
-int encodeUnsignedInteger(bitstream_t* stream, exi_integer_t* iv) {
-	int errn = 0;
-	switch (iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		errn = encodeUnsignedInteger32(stream, iv->val.uint8);
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		errn = encodeUnsignedInteger32(stream, iv->val.uint16);
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		errn = encodeUnsignedInteger32(stream, iv->val.uint32);
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		errn = encodeUnsignedInteger64(stream, iv->val.uint64);
-		break;
-		/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		if (iv->val.int8 < 0) {
-			return EXI_NEGATIVE_UNSIGNED_INTEGER_VALUE;
-		}
-		errn = encodeUnsignedInteger32(stream, iv->val.int8);
-		break;
-	case EXI_INTEGER_16:
-		if (iv->val.int16 < 0) {
-			return EXI_NEGATIVE_UNSIGNED_INTEGER_VALUE;
-		}
-		errn = encodeUnsignedInteger32(stream, iv->val.int16);
-		break;
-	case EXI_INTEGER_32:
-		if (iv->val.int32 < 0) {
-			return EXI_NEGATIVE_UNSIGNED_INTEGER_VALUE;
-		}
-		errn = encodeUnsignedInteger32(stream, iv->val.int32);
-		break;
-	case EXI_INTEGER_64:
-		if (iv->val.int64 < 0) {
-			return EXI_NEGATIVE_UNSIGNED_INTEGER_VALUE;
-		}
-		errn = encodeUnsignedInteger64(stream, iv->val.int64);
-		break;
-	default:
-		errn = EXI_UNSUPPORTED_INTEGER_VALUE_TYPE;
-		break;
-	}
-
-	return errn;
-}
-
-/**
- * Encode an arbitrary precision non negative integer using a sequence of
- * octets. The most significant bit of the last octet is set to zero to
- * indicate sequence termination. Only seven bits per octet are used to
- * store the integer's value.
- */
-int encodeUnsignedInteger32(bitstream_t* stream, uint32_t n) {
-	int errn = 0;
-	if (n < 128) {
-		/* write byte as is */
-		errn = encode(stream, (uint8_t) n);
-	} else {
-		uint8_t n7BitBlocks = numberOf7BitBlocksToRepresent(n);
-
-		switch (n7BitBlocks) {
-		case 5:
-			errn = encode(stream, (uint8_t) (128 | n));
-			n = n >> 7;
-			if (errn < 0) {
-				break;
-			}
-			/* no break */
-		case 4:
-			errn = encode(stream, (uint8_t) (128 | n));
-			n = n >> 7;
-			if (errn < 0) {
-				break;
-			}
-			/* no break */
-		case 3:
-			errn = encode(stream, (uint8_t) (128 | n));
-			n = n >> 7;
-			if (errn < 0) {
-				break;
-			}
-			/* no break */
-		case 2:
-			errn = encode(stream, (uint8_t) (128 | n));
-			n = n >> 7;
-			if (errn < 0) {
-				break;
-			}
-			/* no break */
-		case 1:
-			/* 0 .. 7 (last byte) */
-			errn = encode(stream, (uint8_t) (0 | n));
-			/* no break */
-		}
-	}
-
-	return errn;
-}
-
-/**
- * Encode an arbitrary precision non negative integer using a sequence of
- * octets. The most significant bit of the last octet is set to zero to
- * indicate sequence termination. Only seven bits per octet are used to
- * store the integer's value.
- */
-int encodeUnsignedInteger64(bitstream_t* stream, uint64_t n) {
-	int errn = 0;
-	uint8_t lastEncode = (uint8_t) n;
-	n >>= 7;
-
-	while (n != 0) {
-		errn = encode(stream, lastEncode | 128);
-		if (errn < 0) {
-			return errn;
-		}
-		lastEncode = (uint8_t) n;
-		n >>= 7;
-	}
-
-	return encode(stream, lastEncode);
-}
-
-int encodeInteger(bitstream_t* stream, exi_integer_t* iv) {
-	int errn = 0;
-	switch (iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		errn = encodeInteger32(stream, iv->val.uint8);
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		errn = encodeInteger32(stream, iv->val.uint16);
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		errn = encodeInteger64(stream, iv->val.uint32);
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		errn = encodeInteger64(stream, iv->val.uint64);
-		break;
-		/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		errn = encodeInteger32(stream, iv->val.int8);
-		break;
-	case EXI_INTEGER_16:
-		errn = encodeInteger32(stream, iv->val.int16);
-		break;
-	case EXI_INTEGER_32:
-		errn = encodeInteger32(stream, iv->val.int32);
-		break;
-	case EXI_INTEGER_64:
-		errn = encodeInteger64(stream, iv->val.int64);
-		break;
-	default:
-		errn = EXI_UNSUPPORTED_INTEGER_VALUE_TYPE;
-		break;
-	}
-
-	return errn;
-}
-
-/**
- * Encode an arbitrary precision integer using a sign bit followed by a
- * sequence of octets. The most significant bit of the last octet is set to
- * zero to indicate sequence termination. Only seven bits per octet are used
- * to store the integer's value.
- */
-int encodeInteger32(bitstream_t* stream, int32_t n) {
-	int errn;
-	/* signalize sign */
-	if (n < 0) {
-		errn = encodeBoolean(stream, 1);
-		/* For negative values, the Unsigned Integer holds the
-		 * magnitude of the value minus 1 */
-		n = (-n) - 1;
-	} else {
-		errn = encodeBoolean(stream, 0);
-	}
-	if (errn < 0) {
-		return errn;
-	}
-	return encodeUnsignedInteger32(stream, n);
-}
-
-/**
- * Encode an arbitrary precision integer using a sign bit followed by a
- * sequence of octets. The most significant bit of the last octet is set to
- * zero to indicate sequence termination. Only seven bits per octet are used
- * to store the integer's value.
- */
-int encodeInteger64(bitstream_t* stream, int64_t n) {
-	int errn;
-	/* signalize sign */
-	if (n < 0) {
-		errn = encodeBoolean(stream, 1);
-		/* For negative values, the Unsigned Integer holds the
-		 * magnitude of the value minus 1 */
-		n = (-n) - 1;
-	} else {
-		errn = encodeBoolean(stream, 0);
-	}
-	if (errn < 0) {
-		return errn;
-	}
-	return encodeUnsignedInteger64(stream, n);
-}
-
-/**
- * The Float datatype representation is two consecutive Integers.
- * The first Integer represents the mantissa of the floating point
- * number and the second Integer represents the base-10 exponent
- * of the floating point number.
- */
-int encodeFloat(bitstream_t* stream, exi_float_me_t* f) {
-	int errn = encodeInteger64(stream, f->mantissa);
-	if (errn >= 0) {
-		errn = encodeInteger32(stream, f->exponent);
-	}
-	return errn;
-}
-
-/**
- * Encode a decimal represented as a Boolean sign followed by two Unsigned
- * Integers. A sign value of zero (0) is used to represent positive Decimal
- * values and a sign value of one (1) is used to represent negative Decimal
- * values The first Integer represents the integral portion of the Decimal
- * value. The second positive integer represents the fractional portion of
- * the decimal with the digits in reverse order to preserve leading zeros.
- */
-int encodeDecimal(bitstream_t* stream, exi_decimal_t* d) {
-	/* sign, integral, reverse fractional */
-	int errn = encodeBoolean(stream, d->negative);
-	if (errn < 0) {
-		return errn;
-	}
-	errn = encodeUnsignedInteger(stream, &d->integral);
-	if (errn < 0) {
-		return errn;
-	}
-	errn = encodeUnsignedInteger(stream, &d->reverseFraction);
-
-	return errn;
-}
-
-/**
- * Encode a length prefixed sequence of characters.
- */
-/*int encodeASCII(bitstream_t* stream, const char* ascii) {
- int errn;
- uint32_t slen = (uint32_t) strlen(ascii);
- errn = encodeUnsignedInteger32(stream, slen);
- if (errn >= 0) {
- errn = encodeASCIICharacters(stream, ascii, slen);
- }
- return errn;
- }*/
-
-int encodeString(bitstream_t* stream, exi_string_ucs_t* string) {
-	int errn = encodeUnsignedInteger32(stream, string->len);
-	if (errn >= 0) {
-		errn = encodeUCSCharacters(stream, string->codepoints, string->len);
-	}
-	return errn;
-}
-
-static int _writeStringValueLocalHit(bitstream_t* stream, exi_state_t* state,
-		uint16_t qnameID, uint32_t localID) {
-	int errn;
-	uint16_t codingLength;
-
-	if(!(state->stringTable.sizeLocalStrings > qnameID)) {
-		return EXI_ERROR_OUT_OF_BOUNDS;
-	}
-
-	errn = exiGetCodingLength(state->stringTable.numberOfLocalStrings[qnameID],
-			&codingLength);
-	if (errn) {
-		return errn;
-	}
-	errn = encodeNBitUnsignedInteger(stream, codingLength, localID);
-
-	return errn;
-}
-
-static int _writeStringValueGlobalHit(bitstream_t* stream, exi_state_t* state,
-		uint32_t globalID) {
-	int errn;
-	uint16_t codingLength;
-
-	errn = exiGetCodingLength(state->stringTable.numberOfGlobalStrings, &codingLength);
-	if (errn) {
-		return errn;
-	}
-	errn = encodeNBitUnsignedInteger(stream, codingLength, globalID);
-
-	return errn;
-}
-
-int encodeStringValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID,
-		exi_string_value_t* string) {
-	int errn;
-
-	switch (string->type) {
-	case EXI_STRING_VALUE_LOCAL_HIT:
-		errn = encodeUnsignedInteger32(stream, 0);
-		if (errn) {
-			return errn;
-		}
-		errn = _writeStringValueLocalHit(stream, state, qnameID,
-				string->localID);
-		break;
-	case EXI_STRING_VALUE_GLOBAL_HIT:
-		errn = encodeUnsignedInteger32(stream, 1);
-		if (errn) {
-			return errn;
-		}
-		errn = _writeStringValueGlobalHit(stream, state, string->globalID);
-		break;
-	case EXI_STRING_VALUE_MISS:
-		/* encode string as string table miss */
-		errn = encodeUnsignedInteger32(stream, string->miss.len + 2);
-		if (errn >= 0) {
-			errn = encodeUCSCharacters(stream, string->miss.codepoints,
-					string->miss.len);
-		}
-#if EXI_VALUE_PARTITION_CAPACITY != 0
-#if EXI_VALUE_MAX_LENGTH != 0
-		/* If length L is greater than zero the string S is added */
-		if (string->miss.len > 0) {
-			/* After encoding the string value, it is added to both the
-			 * associated "local" value string table partition and the global
-			 * value string table partition */
-#if EXI_VALUE_MAX_LENGTH < 0
-			errn = exi__IncrementStringValueCount(state, qnameID);
-# else /* EXI_VALUE_MAX_LENGTH < 0  */
-			if (string->miss.len <= EXI_VALUE_MAX_LENGTH) {
-				errn = exi__IncrementStringValueCount(state,
-						qnameID);
-			}
-#endif /* EXI_VALUE_MAX_LENGTH < 0  */
-		}
-#endif /* EXI_VALUE_MAX_LENGTH != 0 */
-#endif /* EXI_VALUE_PARTITION_CAPACITY != 0 */
-		break;
-	default:
-		errn = EXI_UNSUPPORTED_STRING_VALUE_TYPE;
-		break;
-	}
-
-	return errn;
-}
-
-int encodeRCSStringValue(bitstream_t* stream, exi_state_t* state,
-		uint16_t qnameID, exi_rcs_t* rcs, exi_string_value_t* string) {
-	unsigned int i;
-	int errn;
-	uint32_t k;
-
-	switch (string->type) {
-	case EXI_STRING_VALUE_LOCAL_HIT:
-		errn = encodeUnsignedInteger32(stream, 0);
-		if (errn) {
-			return errn;
-		}
-		errn = _writeStringValueLocalHit(stream, state, qnameID,
-				string->localID);
-		break;
-	case EXI_STRING_VALUE_GLOBAL_HIT:
-		errn = encodeUnsignedInteger32(stream, 1);
-		if (errn) {
-			return errn;
-		}
-		errn = _writeStringValueGlobalHit(stream, state, string->globalID);
-		break;
-	case EXI_STRING_VALUE_MISS:
-		/* encode string as string table miss */
-		errn = encodeUnsignedInteger32(stream, string->miss.len + 2);
-		if (errn) {
-			return errn;
-		}
-
-		for (i = 0; i < string->miss.len; i++) {
-			for (k = 0; k < rcs->size; k++) {
-				if (rcs->codepoints[k] == string->miss.codepoints[i]) {
-					errn = encodeNBitUnsignedInteger(stream, rcs->codingLength,
-							k);
-					if (errn) {
-						return errn;
-					}
-					break; /* break inner for loop */
-				}
-			}
-		}
-#if EXI_VALUE_PARTITION_CAPACITY != 0
-#if EXI_VALUE_MAX_LENGTH != 0
-		/* If length L is greater than zero the string S is added */
-		if (string->miss.len > 0) {
-			/* After encoding the string value, it is added to both the
-			 * associated "local" value string table partition and the global
-			 * value string table partition */
-#if EXI_VALUE_MAX_LENGTH < 0
-			errn = exi__IncrementStringValueCount(state, qnameID);
-#else /* EXI_VALUE_MAX_LENGTH < 0 */
-			if (string->miss.len <= EXI_VALUE_MAX_LENGTH) {
-				errn = exi__IncrementStringValueCount(state,
-						qnameID);
-			}
-#endif /* EXI_VALUE_MAX_LENGTH < 0 */
-		}
-#endif /* EXI_VALUE_MAX_LENGTH != 0 */
-#endif /* EXI_VALUE_PARTITION_CAPACITY != 0 */
-		break;
-	default:
-		errn = EXI_UNSUPPORTED_STRING_VALUE_TYPE;
-		break;
-	}
-
-	return errn;
-}
-
-/**
- * Encode a sequence of characters according to a given length.
- * Each character is represented by its UCS [ISO/IEC 10646]
- * code point encoded as an Unsigned Integer
- */
-int encodeUCSCharacters(bitstream_t* stream, uint32_t* chars, uint16_t len) {
-	unsigned int i;
-	int errn = 0;
-	for (i = 0; i < len && errn >= 0; i++) {
-		errn = encodeUnsignedInteger32(stream, chars[i]);
-	}
-	return errn;
-}
-
-/*int encodeASCIICharacters(bitstream_t* stream, const char* chars, uint16_t len) {
- unsigned int i;
- int errn = 0;
- for (i = 0; i < len && errn >= 0; i++) {
- errn = encode(stream, chars[i]);
- }
- return errn;
- }*/
-
-/**
- * Encode a binary value as a length-prefixed sequence of octets.
- */
-int encodeBinary(bitstream_t* stream, exi_bytes_t* bytes) {
-	unsigned int i;
-	int errn = encodeUnsignedInteger32(stream, bytes->len);
-
-	for (i = 0; i < bytes->len && errn >= 0; i++) {
-		errn = encode(stream, bytes->data[i]);
-	}
-	return errn;
-}
-
-/**
- * Encode a datetime representation which is a sequence of values
- * representing the individual components of the Date-Time
- */
-int encodeDateTime(bitstream_t* stream, exi_datetime_t* datetime) {
-	int errn = 0;
-	switch (datetime->type) {
-	case EXI_DATETIME_GYEAR: /* Year, [Time-Zone] */
-		errn = encodeInteger32(stream, datetime->year - DATETIME_YEAR_OFFSET);
-		break;
-	case EXI_DATETIME_GYEARMONTH: /* Year, MonthDay, [TimeZone] */
-	case EXI_DATETIME_DATE: /* Year, MonthDay, [TimeZone] */
-		errn = encodeInteger32(stream, datetime->year - DATETIME_YEAR_OFFSET);
-		if (errn < 0) {
-			return errn;
-		}
-		errn = encodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_MONTHDAY,
-				datetime->monthDay);
-		break;
-	case EXI_DATETIME_DATETIME: /* Year, MonthDay, Time, [FractionalSecs], [TimeZone] */
-		errn = encodeInteger32(stream, datetime->year - DATETIME_YEAR_OFFSET);
-		if (errn < 0) {
-			return errn;
-		}
-		errn = encodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_MONTHDAY,
-				datetime->monthDay);
-		if (errn < 0) {
-			return errn;
-		}
-		/* no break */
-	case EXI_DATETIME_TIME: /* Time, [FractionalSecs], [TimeZone] */
-		errn = encodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_TIME,
-				datetime->time);
-		if (errn < 0) {
-			return errn;
-		}
-		if (datetime->presenceFractionalSecs) {
-			encodeBoolean(stream, 1);
-			if (errn < 0) {
-				return errn;
-			}
-			encodeUnsignedInteger32(stream, datetime->fractionalSecs);
-		} else {
-			encodeBoolean(stream, 0);
-		}
-		break;
-	case EXI_DATETIME_GMONTH: /* MonthDay, [TimeZone] */
-	case EXI_DATETIME_GMONTHDAY: /* MonthDay, [TimeZone] */
-	case EXI_DATETIME_GDAY: /* MonthDay, [TimeZone] */
-		errn = encodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_MONTHDAY,
-				datetime->monthDay);
-		break;
-	default:
-		return EXI_UNSUPPORTED_DATETIME_TYPE;
-	}
-	if (errn < 0) {
-		return errn;
-	}
-	/* [TimeZone] */
-	if (datetime->presenceTimezone) {
-		errn = encodeBoolean(stream, 1);
-		if (errn < 0) {
-			return errn;
-		}
-		encodeNBitUnsignedInteger(stream, DATETIME_NUMBER_BITS_TIMEZONE,
-				datetime->timezone + DATETIME_TIMEZONE_OFFSET_IN_MINUTES);
-	} else {
-		encodeBoolean(stream, 0);
-	}
-
-	return errn;
-}
-
-#endif
-

+ 0 - 74
src/codec/BitDecoderChannel.c

@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "DecoderChannel.h"
-#include "BitInputStream.h"
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-
-#ifndef BIT_DECODER_CHANNEL_C
-#define BIT_DECODER_CHANNEL_C
-
-
-#if EXI_ALIGNMENT == BIT_PACKED
-
-int decode(bitstream_t* stream, uint8_t* b) {
-	uint32_t bb;
-	int errn =  readBits(stream, 8, &bb);
-	if (errn < 0) {
-		return errn;
-	}
-	if (bb > 256) {
-		return EXI_ERROR_UNEXPECTED_BYTE_VALUE;
-	} else {
-		*b = (uint8_t)bb;
-	}
-	return errn;
-}
-
-int decodeBoolean(bitstream_t* stream, int* b) {
-	uint32_t ub;
-	int errn = readBits(stream, 1, &ub);
-	*b = (ub == 0) ? 0 : 1;
-	return errn;
-}
-
-int decodeNBitUnsignedInteger(bitstream_t* stream, uint16_t nbits, uint32_t* uint32) {
-	if (nbits == 0) {
-		*uint32 = 0;
-		return 0;
-	} else {
-		return readBits(stream, nbits, uint32);
-	}
-}
-
-#endif
-
-#endif
-

+ 0 - 88
src/codec/BitEncoderChannel.c

@@ -1,88 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "EncoderChannel.h"
-#include "CoderChannel.h"
-#include "BitOutputStream.h"
-#include "EXITypes.h"
-
-#ifndef BIT_ENCODER_CHANNEL_C
-#define BIT_ENCODER_CHANNEL_C
-
-#if EXI_ALIGNMENT == BIT_PACKED
-
-
-int encode(bitstream_t* stream, uint8_t b) {
-	return writeBits(stream, 8, b);
-}
-
-/**
- * Encode a single boolean value. A false value is encoded as bit 0 and true
- * value is encode as bit 1.
- */
-int encodeBoolean(bitstream_t* stream, int b) {
-	uint8_t val = b ? 1 : 0;
-	return writeBits(stream, 1, val);
-}
-
-
-/**
- * Encode n-bit unsigned integer. The n least significant bits of parameter
- * b starting with the most significant, i.e. from left to right.
- */
-int encodeNBitUnsignedInteger(bitstream_t* stream, uint16_t nbits, uint32_t val)  {
-	if (nbits > 0) {
-		return writeBits(stream, nbits, val);
-	}
-	return 0;
-}
-
-/**
- * Flush underlying bit output stream.
- */
-int encodeFinish(bitstream_t* stream) {
-	return flush(stream);
-}
-
-
-#endif /* alignment */
-
-#endif
-
-
-
-
-
-
-
-
-
-
-
-

+ 0 - 111
src/codec/BitInputStream.c

@@ -1,111 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "BitInputStream.h"
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-
-#ifndef BIT_INPUT_STREAM_C
-#define BIT_INPUT_STREAM_C
-
-/* internal method to (re)fill buffer */
-static int readBuffer(bitstream_t* stream)
-{
-	int errn = 0;
-	if(stream->capacity==0)
-	{
-#if EXI_STREAM == BYTE_ARRAY
-		if ( (*stream->pos) < stream->size ) {
-			stream->buffer = stream->data[(*stream->pos)++];
-			stream->capacity = BITS_IN_BYTE;
-		} else {
-			errn = EXI_ERROR_INPUT_STREAM_EOF;
-		}
-#endif
-#if EXI_STREAM == FILE_STREAM
-		stream->buffer = (uint8_t)(getc(stream->file));
-		/* EOF cannot be used, 0xFF valid value */
-		if ( feof(stream->file) || ferror(stream->file) ) {
-			return EXI_ERROR_INPUT_STREAM_EOF;
-		}
-		stream->capacity = BITS_IN_BYTE;
-#endif
-	}
-	return errn;
-}
-
-int readBits(bitstream_t* stream, uint16_t num_bits, uint32_t* b)
-{
-	int errn = readBuffer(stream);
-	if (errn < 0) {
-		return errn;
-	}
-
-	/* read the bits in one step */
-	if(num_bits <= stream->capacity)
-	{
-		stream->capacity -= (uint8_t)num_bits;
-		*b = (stream->buffer >> stream->capacity) & (0xff >> (BITS_IN_BYTE - num_bits));
-	}
-	else
-	{
-		/* read bits as much as possible */
-		*b = stream->buffer & (0xff >> (BITS_IN_BYTE - stream->capacity));
-		num_bits -= stream->capacity;
-		stream->capacity = 0;
-
-		/* read whole bytes */
-		while(num_bits >= 8)
-		{
-			errn = readBuffer(stream);
-			if (errn < 0) {
-				return errn;
-			}
-			*b = ((*b) << BITS_IN_BYTE) | stream->buffer;
-			num_bits -= BITS_IN_BYTE;
-			stream->capacity = 0;
-		}
-
-		/* read the spare bits in the buffer */
-		if(num_bits>0)
-		{
-			errn = readBuffer(stream);
-			if (errn < 0) {
-				return errn;
-			}
-			*b = ((*b) << num_bits) | (stream->buffer >> (BITS_IN_BYTE - num_bits));
-			stream->capacity = (uint8_t)(BITS_IN_BYTE - num_bits);
-		}
-		
-	}
-
-	return errn;
-}
-
-#endif

+ 0 - 66
src/codec/BitInputStream.h

@@ -1,66 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	BitInputStream.h
- * \brief 	Bit Input Stream
- *
- * 			Read bits and bytes from an underlying input stream.
- *
- */
-
-#include "EXITypes.h"
-
-#ifndef BIT_INPUT_STREAM_H
-#define BIT_INPUT_STREAM_H
-
-/**
- * \brief 		Read bits
- *
- * 				Read the next num_bits bits and returns result an integer.
- *
- * \param       stream   		Input Stream
- * \param       num_bits		Number of bits
- * \param       b		   		Integer value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int readBits(bitstream_t* stream, uint16_t num_bits, uint32_t* b);
-
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 118
src/codec/BitOutputStream.c

@@ -1,118 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "BitOutputStream.h"
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-
-#ifndef BIT_OUTPUT_STREAM_C
-#define BIT_OUTPUT_STREAM_C
-
-int writeBits(bitstream_t* stream, uint16_t nbits, uint32_t val) {
-	/*  is there enough space in the buffer */
-	if (nbits <= stream->capacity) {
-		/* all bits fit into the current buffer */
-		stream->buffer = (stream->buffer << (nbits)) | (val & (0xff
-				>> (BITS_IN_BYTE - nbits)));
-		stream->capacity -= (uint8_t)nbits;
-		/* if the buffer is full write byte */
-		if (stream->capacity == 0) {
-#if EXI_STREAM == BYTE_ARRAY
-			if ((*stream->pos) >= stream->size) {
-				return EXI_ERROR_OUTPUT_STREAM_EOF;
-			}
-			stream->data[(*stream->pos)++] = stream->buffer;
-#endif
-#if EXI_STREAM == FILE_STREAM
-			if ( putc(stream->buffer, stream->file) == EOF ) {
-				return EXI_ERROR_OUTPUT_STREAM_EOF;
-			}
-#endif
-			stream->capacity = BITS_IN_BYTE;
-			stream->buffer = 0;
-		}
-	} else {
-		/* the buffer is not enough
-		 * fill the buffer */
-		stream->buffer = (stream->buffer << stream->capacity) | ((val >> (nbits
-				- stream->capacity)) & (0xff >> (BITS_IN_BYTE
-				- stream->capacity)));
-
-		nbits -= stream->capacity;
-#if EXI_STREAM == BYTE_ARRAY
-		if ((*stream->pos) >= stream->size) {
-			return EXI_ERROR_OUTPUT_STREAM_EOF;
-		}
-		stream->data[(*stream->pos)++] = stream->buffer;
-#endif
-#if EXI_STREAM == FILE_STREAM
-		if ( putc(stream->buffer, stream->file) == EOF ) {
-			return EXI_ERROR_OUTPUT_STREAM_EOF;
-		}
-#endif
-		stream->buffer = 0;
-
-		/* write whole bytes */
-		while (nbits >= BITS_IN_BYTE) {
-			nbits -= BITS_IN_BYTE;
-#if EXI_STREAM == BYTE_ARRAY
-			if ((*stream->pos) >= stream->size) {
-				return EXI_ERROR_OUTPUT_STREAM_EOF;
-			}
-			stream->data[(*stream->pos)++] = (val >> (nbits));
-#endif
-#if EXI_STREAM == FILE_STREAM
-			if ( putc((val >> (nbits)), stream->file) == EOF ) {
-				return EXI_ERROR_OUTPUT_STREAM_EOF;
-			}
-#endif
-		}
-
-		/* spared bits are kept in the buffer */
-		stream->buffer = (uint8_t)val; /* Note: the high bits will be shifted out during further filling */
-		stream->capacity = (uint8_t)(BITS_IN_BYTE - (nbits));
-	}
-
-	return 0;
-}
-
-/**
- * Flush output
- */
-int flush(bitstream_t* stream) {
-	if (stream->capacity == BITS_IN_BYTE) {
-		/* nothing to do, no bits in buffer */
-		return 0;
-	} else {
-		return writeBits(stream, stream->capacity, 0);
-	}
-}
-
-#endif
-

+ 0 - 83
src/codec/BitOutputStream.h

@@ -1,83 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	BitOutputStream.h
- * \brief 	Bit Output Stream
- *
- * 			Write bits and bytes to an underlying output stream.
- *
- */
-
-#include <stdint.h>
-
-#include "EXITypes.h"
-
-#ifndef BIT_OUTPUT_STREAM_H
-#define BIT_OUTPUT_STREAM_H
-
-/**
- * \brief 		Write bits
- *
- * 				Write the n least significant bits of parameter b starting
- * 				with the most significant, i.e. from left to right.
- *
- * \param       stream   		Output Stream
- * \param       nbits			Number of bits
- * \param       bits		   	value
- * \return                  	Error-Code <> 0
- *
- */
-int writeBits(bitstream_t* stream, uint16_t nbits, uint32_t bits);
-
-
-/**
- * \brief 		Flush output
- *
- * 				If there are some unwritten bits, pad them if necessary and
- * 				write them out. Note that this method does flush the
- * 				underlying stream.
- *
- * \param       stream   		Output Stream
- * \return                  	Error-Code <> 0
- *
- */
-int flush(bitstream_t* stream);
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 94
src/codec/ByteDecoderChannel.c

@@ -1,94 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "DecoderChannel.h"
-#include "CoderChannel.h"
-#include "BitInputStream.h"
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-
-#ifndef BYTE_DECODER_CHANNEL_C
-#define BYTE_DECODER_CHANNEL_C
-
-
-#if EXI_ALIGNMENT == BYTE_ALIGNMENT
-
-int decode(bitstream_t* stream, uint8_t* b) {
-	int errn = 0;
-#if EXI_STREAM == BYTE_ARRAY
-	if ( (*stream->pos) < stream->size ) {
-		*b = stream->data[(*stream->pos)++];
-	} else {
-		errn = EXI_ERROR_INPUT_STREAM_EOF;
-	}
-#endif /* EXI_STREAM == BYTE_ARRAY */
-#if EXI_STREAM == FILE_STREAM
-	*b = (uint8_t)(getc(stream->file));
-	/* EOF cannot be used, 0xFF valid value */
-	if ( feof(stream->file) || ferror(stream->file) ) {
-		return EXI_ERROR_INPUT_STREAM_EOF;
-	}
-#endif /* EXI_STREAM == FILE_STREAM */
-
-	return errn;
-}
-
-int decodeBoolean(bitstream_t* stream, int* b) {
-	uint8_t bb;
-	int errn = decode(stream, &bb);
-	*b = (bb == 0) ? 0 : 1;
-	return errn;
-}
-
-/**
- * Decodes and returns an n-bit unsigned integer using the minimum number of
- * bytes required for n bits.
- */
-int decodeNBitUnsignedInteger(bitstream_t* stream, uint16_t nbits, uint32_t* uint32) {
-	uint16_t bitsRead = 0;
-	uint8_t b;
-	int errn = 0;
-	*uint32 = 0;
-
-	while (bitsRead < nbits) {
-		errn = decode(stream, &b);
-		if (errn != 0) {
-			return errn;
-		}
-		*uint32 += (b << bitsRead);
-		bitsRead += 8;
-	}
-
-	return errn;
-}
-
-#endif
-
-#endif
-

+ 0 - 128
src/codec/ByteEncoderChannel.c

@@ -1,128 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "EncoderChannel.h"
-#include "CoderChannel.h"
-#include "BitOutputStream.h"
-#include "EXITypes.h"
-#include "MethodsBag.h"
-#include "ErrorCodes.h"
-
-#ifndef BYTE_ENCODER_CHANNEL_C
-#define BYTE_ENCODER_CHANNEL_C
-
-#if EXI_ALIGNMENT == BYTE_ALIGNMENT
-
-
-int encode(bitstream_t* stream, uint8_t b) {
-#if EXI_STREAM == BYTE_ARRAY
-	if ( (*stream->pos) < stream->size ) {
-		stream->data[(*stream->pos)++] = b;
-		return 0;
-	} else {
-		return EXI_ERROR_OUTPUT_STREAM_EOF;
-	}
-#endif /* EXI_STREAM == BYTE_ARRAY */
-#if EXI_STREAM == FILE_STREAM
-	if ( putc(b, stream->file) == EOF ) {
-		return EXI_ERROR_OUTPUT_STREAM_EOF;
-	} else {
-		return 0;
-	}
-#endif /* EXI_STREAM == FILE_STREAM */
-}
-
-/**
- * Encode a single boolean value. A false value is encoded as byte 0 and true
- * value is encode as byte 1.
- */
-int encodeBoolean(bitstream_t* stream, int b) {
-	uint8_t val = b ? 1 : 0;
-	return encode(stream, val);
-}
-
-
-/**
- * Encode n-bit unsigned integer. The n least significant bits of parameter
- * b starting with the most significant, i.e. from left to right.
- */
-int encodeNBitUnsignedInteger(bitstream_t* stream, uint16_t nbits, uint32_t val)  {
-	if (nbits > 0) {
-		if (nbits < 9) {
-			/* 1 byte */
-			encode(stream, val & 0xff);
-		} else if (nbits < 17) {
-			/* 2 bytes */
-			encode(stream, val & 0x00ff);
-			encode(stream, (val & 0xff00) >> 8);
-		} else if (nbits < 25) {
-			/* 3 bytes */
-			encode(stream, val & 0x0000ff);
-			encode(stream, (val & 0x00ff00) >> 8);
-			encode(stream, (uint8_t)((val & 0xff0000) >> 16));
-		} else if (nbits < 33) {
-			/* 4 bytes */
-			encode(stream, val & 0x000000ff);
-			encode(stream, (val & 0x0000ff00) >> 8);
-			encode(stream, (uint8_t)((val & 0x00ff0000) >> 16));
-			encode(stream, (uint8_t)((val & 0xff000000) >> 24));
-		} else {
-			/* TODO Currently not more than 4 Bytes allowed for NBitUnsignedInteger */
-			return EXI_UNSUPPORTED_NBIT_INTEGER_LENGTH;
-		}
-	}
-	return 0;
-}
-
-
-/**
- * Flush underlying bit output stream.
- */
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'stream' */
-int encodeFinish(bitstream_t* stream) {
-	/* no pending bits in byte-aligned mode */
-	return 0;
-}
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'stream' */
-
-#endif /* alignment */
-
-#endif
-
-
-
-
-
-
-
-
-
-
-
-

+ 0 - 82
src/codec/ByteStream.c

@@ -1,82 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-/* Avoid VS warning, put before your included header files */
-/* warning C4996: ‘fopen’: This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. */
-#define _CRT_SECURE_NO_DEPRECATE
-
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-
-#ifndef BYTE_STREAM_C
-#define BYTE_STREAM_C
-
-int readBytesFromFile(const char * filename, uint8_t* data, uint32_t size, uint32_t pos) {
-	FILE* f;
-	int character;
-
-	f = fopen(filename, "rb");
-
-	if (f == NULL) {
-		return EXI_ERROR_INPUT_FILE_HANDLE;
-	} else {
-		/* read bytes */
-		while ((character = getc(f)) != EOF) {
-			if (pos >= size) {
-				return EXI_ERROR_OUT_OF_BYTE_BUFFER;
-			}
-			data[pos++] = (uint8_t) character;
-		}
-		fclose(f);
-	}
-
-	return pos;
-}
-
-int writeBytesToFile(uint8_t* data, uint32_t len, const char * filename) {
-	size_t rlen;
-	FILE* f = fopen(filename, "wb+");
-
-	if (f == NULL) {
-		return -1;
-	} else {
-		rlen = fwrite(data, sizeof(uint8_t), len, f);
-		fflush(f);
-		fclose(f);
-		if(rlen == len) {
-			return 0;
-		} else {
-			return EXI_ERROR_OUTPUT_FILE;
-		}
-	}
-}
-
-
-#endif
-

+ 0 - 74
src/codec/ByteStream.h

@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include "EXITypes.h"
-
-/**
- * \file 	ByteStream.h
- * \brief 	Byte Stream utilities
- *
- */
-
-#ifndef BYTE_STREAM_H
-#define BYTE_STREAM_H
-
-/**
- * \brief 		Write bytes to file
- *
- * \param       data	   		byte array
- * \param       len				length
- * \param       filename		File name
- * \return                  	Error-Code <> 0
- *
- */
-int writeBytesToFile(uint8_t* data, uint32_t len, const char * filename);
-
-
-/**
- * \brief 		Read bytes from file
- *
- * \param       filename   		File name
- * \param       data			byte array
- * \param       size		   	byte array size
- * \param       pos			   	byte array position
- * \return                  	Error-Code <> 0
- *
- */
-int readBytesFromFile(const char * filename, uint8_t* data, uint32_t size, uint32_t pos);
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 51
src/codec/CoderChannel.h

@@ -1,51 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include "EXITypes.h"
-
-#ifndef CODER_CHANNEL_H
-#define CODER_CHANNEL_H
-
-/** EXI alignment mode - Option bit-packed */
-#define BIT_PACKED 1
-/** EXI alignment mode - Option byte-packed */
-#define BYTE_ALIGNMENT  2
-/** EXI alignment mode */
-#define EXI_ALIGNMENT BIT_PACKED
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 356
src/codec/DecoderChannel.h

@@ -1,356 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	DecoderChannel.h
- * \brief 	EXI Decoder Channel
- *
- */
-
-#include "EXITypes.h"
-#include "CoderChannel.h"
-
-#ifndef DECODER_CHANNEL_H
-#define DECODER_CHANNEL_H
-
-
-/**
- * \brief 		Decode byte value
- *
- * \param       stream   		Input Stream
- * \param       b		   		byte (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decode(bitstream_t* stream, uint8_t* b);
-
-
-/**
- * \brief 		Decode boolean
- *
- * 				Decode a single boolean value. The value false is
- * 				represented by 0, and the value true is represented by 1.
- *
- * \param       stream   		Input Stream
- * \param       b		   		boolean (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeBoolean(bitstream_t* stream, int* b);
-
-
-/**
- * \brief 		Decode n-bit unsigned integer
- *
- * 				Decodes and returns an n-bit unsigned integer.
- *
- * \param       stream   		Input Stream
- * \param       nbits		   	Number of bits
- * \param       uint32		   	Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeNBitUnsignedInteger(bitstream_t* stream, uint16_t nbits, uint32_t* uint32);
-
-
-/**
- * \brief 		Decode unsigned integer
- *
- * 				Decode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       iv		   		Unsigned Integer Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeUnsignedInteger(bitstream_t* stream, exi_integer_t* iv);
-
-
-/**
- * \brief 		Decode unsigned integer
- *
- * 				Decode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       uint16		   	Unsigned Integer Value 16 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeUnsignedInteger16(bitstream_t* stream, uint16_t* uint16);
-
-
-/**
- * \brief 		Decode unsigned integer
- *
- * 				Decode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       uint32		   	Unsigned Integer Value 32 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeUnsignedInteger32(bitstream_t* stream, uint32_t* uint32);
-
-
-/**
- * \brief 		Decode unsigned integer
- *
- * 				Decode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       uint64		   	Unsigned Integer Value 64 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeUnsignedInteger64(bitstream_t* stream, uint64_t* uint64);
-
-
-/**
- * \brief 		Decode integer
- *
- * 				Decode an arbitrary precision integer using a sign bit
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       iv		   		Integer Value 64 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeInteger(bitstream_t* stream, exi_integer_t* iv);
-
-
-/**
- * \brief 		Decode integer
- *
- * 				Decode an arbitrary precision integer using a sign bit
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       int16		   	Integer Value 16 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeInteger16(bitstream_t* stream, int16_t* int16);
-
-
-/**
- * \brief 		Decode integer
- *
- * 				Decode an arbitrary precision integer using a sign bit
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       int32		   	Integer Value 32 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeInteger32(bitstream_t* stream, int32_t* int32);
-
-
-/**
- * \brief 		Decode integer
- *
- * 				Decode an arbitrary precision integer using a sign bit
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Input Stream
- * \param       int64		   	Integer Value 64 bits (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeInteger64(bitstream_t* stream, int64_t* int64);
-
-
-/**
- * \brief 		Decode float
- *
- * 				Decode a Float datatype as two consecutive Integers. The
- * 				first Integer represents the mantissa of the floating point
- * 				number and the second Integer represents the base-10 exponent
- * 				of the floating point number.
- *
- * \param       stream   		Input Stream
- * \param       f			   	Float Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeFloat(bitstream_t* stream, exi_float_me_t* f);
-
-
-/**
- * \brief 		Decode decimal
- *
- * 				Decode a decimal represented as a Boolean sign followed by two
- * 				Unsigned Integers. A sign value of zero (0) is used to represent
- * 				positive Decimal values and a sign value of one (1) is used to
- * 				represent negative Decimal values The first Integer represents
- * 				the integral portion of the Decimal value. The second positive
- * 				integer represents the fractional portion of the decimal with
- * 				the digits in reverse order to preserve leading zeros.
- *
- * \param       stream   		Input Stream
- * \param       d			   	Decimal Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeDecimal(bitstream_t* stream, exi_decimal_t* d);
-
-
-/**
- * \brief 		Decode String (no length prefix)
- *
- * 				Decode a sequence of characters for a given length.
- *
- * \param       stream   		Input Stream
- * \param       len			   	Characters length
- * \param       s			   	String Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeStringOnly(bitstream_t* stream, uint16_t len, exi_string_ucs_t* s);
-
-
-/**
- * \brief 		Decode String
- *
- * 				Decode a length prefixed sequence of characters.
- *
- * \param       stream   		Input Stream
- * \param       s			   	String Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeString(bitstream_t* stream, exi_string_ucs_t* s);
-
-
-
-/**
- * \brief 		Decode String value
- *
- * 				Decode a length prefixed sequence of characters in the sense of string tables.
- * 				length == 0: local value partition hit.
- * 				length == 1: global value partition hit.
- * 				length > 1: string literal is encoded as a String with the length incremented by two
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       s			   	String Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeStringValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, exi_string_value_t* s);
-
-
-/**
- * \brief 		Decode Restricted characters set string value
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       rcs		   		Restricted character set
- * \param       s			   	String Value (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeRCSStringValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, exi_rcs_t* rcs, exi_string_value_t* s);
-
-
-/**
- * \brief 		Decode characters
- *
- * 				Decode a sequence of characters according to a given length.
- *
- * \param       stream   		Input Stream
- * \param       len		   		Length
- * \param       chars   		Characters (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeCharacters(bitstream_t* stream, uint16_t len, uint32_t* chars);
-
-
-/**
- * \brief 		Decode Binary
- *
- * 				Decode a binary value as a length-prefixed sequence of octets.
- *
- * \param       stream   		Input Stream
- * \param       bytes   		Bytes (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeBinary(bitstream_t* stream, exi_bytes_t* bytes);
-
-
-/**
- * \brief 		Decode DateTime
- *
- * 				Decode Date-Time as sequence of values representing the
- * 				individual components of the Date-Time.
- *
- * \param       stream   		Input Stream
- * \param       type   			Datetime type
- * \param       datetime   		Datetime (out)
- * \return                  	Error-Code <> 0
- *
- */
-int decodeDateTime(bitstream_t* stream, exi_datetime_type_t type, exi_datetime_t* datetime);
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif
-

تفاوت فایلی نمایش داده نمی شود زیرا این فایل بسیار بزرگ است
+ 0 - 1861
src/codec/EXICoder.c


+ 0 - 70
src/codec/EXICoder.h

@@ -1,70 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI__CODER_H
-#define EXI__CODER_H
-
-#include "EXITypes.h"
-
-#define DOCUMENT 0
-#define DOC_CONTENT 126
-#define DOC_END 127
-#define UR_TYPE_GRAMMAR_0 227
-#define UR_TYPE_GRAMMAR_1 228
-
-
-/* increments global and local string count */
-int exi__IncrementStringValueCount(exi_state_t* state, uint16_t qnameID);
-
-int exi__PushStack(exi_state_t* state, int16_t newState, uint16_t qnameID);
-
-int exi__PopStack(exi_state_t* state);
-
-int exi__HandleXsiNilTrue(exi_state_t* state);
-
-int exi__HandleXsiType(exi_state_t* state, exi_eqname_t* xsiType);
-
-int exi__RetrieveAndPushGlobalGrammar(exi_state_t* state, uint16_t qnameID);
-
-int exi__LearnAttribute(exi_state_t* state, uint16_t qnameID, uint16_t uriID, uint16_t localID);
-
-int exi__IsStartContent(int16_t ruleID);
-
-int exi__MoveToElementContentRule(exi_state_t* state);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

تفاوت فایلی نمایش داده نمی شود زیرا این فایل بسیار بزرگ است
+ 0 - 933
src/codec/EXIDecoder.c


+ 0 - 222
src/codec/EXIDecoder.h

@@ -1,222 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI__DECODER_H
-#define EXI__DECODER_H
-
-/**
-* \file 	EXIDecoder.h
-* \brief 	EXI Decoder
-*
-*/
-
-#include "EXITypes.h"
-
-/**
- * \brief 		Initialize EXI decoder
- *
- *         		Resets & initializes the EXI decoder.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       runtimeTable   	Runtime name-tables
- * \param       stringTable   	String table
- * \return                  	Error-Code <> 0
- *
- */
-int exiInitDecoder(bitstream_t* stream, exi_state_t* state,
-		exi_name_table_runtime_t runtimeTable, exi_string_table_t stringTable);
-
-
-/**
- * \brief 		Reports last decoded qualified name
- *
- *         		Note: Qualified name only available for previously unknown qname. Otherwise make use of name table entries.
- *
- * \param       qname   		Qualified name
- * \return                  	Error-Code <> 0
- *
- */
-int exiGetLastQName(exi_qname_t** qname);
-
-
-/**
- * \brief 		Decodes next event
- *
- * 				Inspects EXI stream and decodes next EXI event.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       nextEvent   	Next event
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeNextEvent(bitstream_t* stream,
-		exi_state_t* state, exi_event_t* nextEvent);
-
-
-/**
- * \brief 		Decodes StartDocument (SD) event
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeStartDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief 		Decodes EndDocument (ED) event
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeEndDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief 		Decodes StartElemnt (SE) event
- *
- * 				Note: The first time a qnameID is larger than schema-informed NUMBER_OF_QNAMES it is possible to retrieve the qname by calling GetLastQName(...).
- * 				It is up to the caller to track qnames.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \return                  	Error-Code <> 0
- *
- */
-int
-exiDecodeStartElement(bitstream_t* stream,
-		exi_state_t* state, uint16_t* qnameID);
-
-
-/**
- * \brief 		Decodes EndElement (EE) event
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeEndElement(bitstream_t* stream,
-		exi_state_t* state, uint16_t* qnameID);
-
-
-/**
- * \brief 		Decodes Characters (CH) event.
- *
- * 				Reports characters value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeCharacters(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes Attribute (AT) event.
- *
- * 				Reports attribute qname and value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeAttribute(bitstream_t* stream,
-		exi_state_t* state, uint16_t* qnameID, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes attribute xsi:nil
- *
- * 				Reports value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeAttributeXsiNil(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes attribute xsi:type
- *
- * 				Reports value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeAttributeXsiType(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes attribute/characters list value
- *
- * 				List values are special and are processed one by one.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       val		   		List value
- * \param       lt		   		List type
- * \return                  	Error-Code <> 0
- *
- */
-int exiDecodeListValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID,
-		exi_value_t* val, exi_list_t lt);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

تفاوت فایلی نمایش داده نمی شود زیرا این فایل بسیار بزرگ است
+ 0 - 1010
src/codec/EXIEncoder.c


+ 0 - 271
src/codec/EXIEncoder.h

@@ -1,271 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI__ENCODER_H
-#define EXI__ENCODER_H
-
-/**
-* \file 	EXIEncoder.h
-* \brief 	EXI Encoder
-*
-*/
-
-#include "EXITypes.h"
-#include "EXIEncoder.h"
-
-/**
- * \brief 	Initialize EXI encoder
- *
- *         	Resets & initializes the EXI encoder.
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       runtimeTable   	Runtime name-tables
- * \param       stringTable   	String table
- * \return                  	Error-Code <> 0
- *
- */
-int exiInitEncoder(bitstream_t* stream, exi_state_t* state,
-		exi_name_table_runtime_t runtimeTable, exi_string_table_t stringTable);
-
-/**
- * \brief  	Reports the beginning of a set of XML events
- *
- *			see EXI StartDocument (SD) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeStartDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief  	Reports the end of a set of XML events
- *
- *			see EXI EndDocument (ED) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeEndDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief  	Supplies the start of a known element
- *
- *			Provides access to the namespace URI and local name of the start tag by providing qnameID.
- *			Note: Both, namespace URI and local name are known (schema-informed) or have been encoded before.
- *			see EXI StartElement (SE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		qualified name ID
- * \return                  	Error-Code <> 0
- *
- */
-int
-exiEncodeStartElement(bitstream_t* stream,
-		exi_state_t* state, uint16_t qnameID);
-
-/**
- * \brief  	Supplies the start of an element where the namespace is known
- *
- *			Note: Namespace URI is known (schema-informed) or has been encoded before while local name is unknown.
- *			see EXI StartElement (SE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUriID  namespace URI ID
- * \param       localName  		local name as string
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeStartElementNS(bitstream_t* stream,
-		exi_state_t* state, uint16_t namespaceUriID,
-		exi_string_ucs_t* localName);
-
-/**
- * \brief  	Supplies the start of an element where the namespace and the local name is unknown
- *
- *			Note: Neither namespace URI nor local name is known.
- *			see EXI StartElement (SE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUri  	namespace URI as string
- * \param       localName  		local name as string
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeStartElementGeneric(bitstream_t* stream,
-		exi_state_t* state, exi_string_ucs_t* namespaceUri,
-		exi_string_ucs_t* localName);
-
-/**
- * \brief  	Supplies the end tag of an element
- *
- *			see EXI EndElement (EE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeEndElement(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief  	Supplies characters value
- *
- *			Note: Special handling for list value.
- *			see EXI Characters (CH) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       val   			Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeCharacters(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-/**
- * \brief  	Supplies an attribute qname and value
- *
- *			Note: Special handling for list value.
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		qualified name ID
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeAttribute(bitstream_t* stream,
-		exi_state_t* state, uint16_t qnameID, exi_value_t* val);
-
-
-
-
-/**
- * \brief  	Supplies an attribute qname and value where the namespace is known
- *
- *			Note: Special handling for list value.
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUriID  Qualified namespace URI ID
- * \param       localName  		Qualified localname as String
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeAttributeNS(bitstream_t* stream,
-		exi_state_t* state, uint16_t namespaceUriID,
-		exi_string_ucs_t* localName, exi_value_t* val);
-
-
-/**
- * \brief  	Supplies an attribute qname and value where the namespace and the local name is unknown
- *
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUri  	namespace URI as string
- * \param       localName  		local name as string
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeAttributeGeneric(bitstream_t* stream,
-		exi_state_t* state, exi_string_ucs_t* namespaceUri,
-		exi_string_ucs_t* localName, exi_value_t* val);
-
-
-
-/**
- * \brief  	Supplies an xsi:nil attribute
- *
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeAttributeXsiNil(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-/**
- * \brief  	Supplies an xsi:type attribute
- *
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeAttributeXsiType(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-/**
- * \brief  	Supplies list value for characters and attribute event
- *
- *			List values are special given that first the number and type of entry needs to be passed (element/attribute event) and then one by one the actual values.
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		qualified name ID
- * \param       val   			one list value
- * \param       lt   			list type
- * \return                  	Error-Code <> 0
- *
- */
-int exiEncodeListValue(bitstream_t* stream,
-		exi_state_t* state, uint16_t qnameID, exi_value_t* val, exi_list_t lt);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 60
src/codec/EXIHeaderDecoder.c

@@ -1,60 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "EXIHeaderDecoder.h"
-#include "BitInputStream.h"
-#include "DecoderChannel.h"
-#include "ErrorCodes.h"
-
-#ifndef EXI_HEADER_DECODER_C
-#define EXI_HEADER_DECODER_C
-
-int readEXIHeader(bitstream_t* stream) {
-	uint32_t header = 0;
-	int errn = readBits(stream, 8, &header);
-	if (errn < 0) {
-		return errn;
-	}
-	if(header == '$') {
-		/*	we do not support "EXI Cookie" */
-		errn = EXI_UNSUPPORTED_HEADER_COOKIE;
-	} else if ( header & 0x20 ) {
-		/* we do not support "Presence Bit for EXI Options" */
-		errn = EXI_UNSUPPORTED_HEADER_OPTIONS;
-	} else {
-		/* Yes, a *simple* header */
-		errn = 0;
-	}
-	return errn;
-}
-
-
-#endif
-
-

+ 0 - 59
src/codec/EXIHeaderDecoder.h

@@ -1,59 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include "EXITypes.h"
-
-/**
- * \file 	EXIHeaderDecoder.h
- * \brief 	EXI Header Decoder
- *
- */
-
-#ifndef EXI_HEADER_DECODER_H
-#define EXI_HEADER_DECODER_H
-
-/**
- * \brief 		Reads EXI header
- *
- * \param       stream   		Input Stream
- * \return                  	Error-Code <> 0
- *
- */
-int readEXIHeader(bitstream_t* stream);
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 44
src/codec/EXIHeaderEncoder.c

@@ -1,44 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include "EXIHeaderEncoder.h"
-#include "BitOutputStream.h"
-#include "EncoderChannel.h"
-
-#ifndef EXI_HEADER_ENCODER_C
-#define EXI_HEADER_ENCODER_C
-
-int writeEXIHeader(bitstream_t* stream) {
-	return writeBits(stream, 8, 128);
-}
-
-
-#endif
-
-

+ 0 - 60
src/codec/EXIHeaderEncoder.h

@@ -1,60 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include "EXITypes.h"
-
-/**
- * \file 	EXIHeaderEncoder.h
- * \brief 	EXI Header Encoder
- *
- */
-
-#ifndef EXI_HEADER_ENCODER_H
-#define EXI_HEADER_ENCODER_H
-
-
-/**
- * \brief 		Writes EXI header
- *
- * \param       stream   		Output Stream
- * \return                  	Error-Code <> 0
- *
- */
-int writeEXIHeader(bitstream_t* stream);
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 75
src/codec/EXIOptions.h

@@ -1,75 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	EXIOptions.h
- * \brief 	EXI Options
- *
- */
-
-#ifndef EXI__OPTIONS_H
-#define EXI__OPTIONS_H
-
-
-/**
- * \brief 		Option 'strict'
- *
- *				Strict interpretation of schemas is used to achieve better compactness.
- *				Default Value: false
- */
-#define EXI_STRICT 0
-
-
-/**
- * \brief 		Option 'valueMaxLength'
- *
- *				Specifies the maximum string length of value content items to be
- *				considered for addition to the string table.
- *				Default Value: unbounded (-1)
- */
-#define EXI_VALUE_MAX_LENGTH -1
-
-
-/**
- * \brief 		Option 'valuePartitionCapacity'
- *
- *				Specifies the total capacity of value partitions in a string table.
- *				 Default Value: unbounded (-1)
- */
-#define EXI_VALUE_PARTITION_CAPACITY 0
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 535
src/codec/EXITypes.h

@@ -1,535 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	EXITypes.h
- * \brief 	Basic type definitions and structs
- *
- */
-
-#include <stdint.h>
-#include <stdio.h>
-
-#ifndef EXI_TYPES_H
-#define EXI_TYPES_H
-
-/** Number of bits for each byte */
-#define BITS_IN_BYTE 8
-
-/** EXI Date-Time offset for year */
-#define DATETIME_YEAR_OFFSET 2000
-/** EXI Date-Time number of bits for monthDay */
-#define DATETIME_NUMBER_BITS_MONTHDAY 9
-/** EXI Date-Time number of bits for time */
-#define DATETIME_NUMBER_BITS_TIME 17
-/** EXI Date-Time number of bits for timezone */
-#define DATETIME_NUMBER_BITS_TIMEZONE 11
-/** EXI Date-Time month multiplicator */
-#define DATETIME_MONTH_MULTIPLICATOR 32
-/** EXI Date-Time offset for timzone minutes */
-#define DATETIME_TIMEZONE_OFFSET_IN_MINUTES 896
-
-/** Maximum integer value for uint */
-#define UINT_MAX_VALUE 65535
-
-/** EXI stream - Option Byte Array */
-#define BYTE_ARRAY 1
-/** EXI stream - Option File */
-#define FILE_STREAM 2
-#define EXI_STREAM BYTE_ARRAY
-/** \brief 	EXI stream
- *
- * 			Byte array or file
- * */
-/* #define EXI_STREAM FILE_STREAM */
-
-/** Maximum number of cascading elements, XML tree depth */
-#define EXI_ELEMENT_STACK_SIZE 24
-
-/** EXI Float exponent special values */
-#define FLOAT_EXPONENT_SPECIAL_VALUES -16384
-/** EXI Float mantissa infinity */
-#define FLOAT_MANTISSA_INFINITY 1
-/** EXI Float minus mantissa infinity */
-#define FLOAT_MANTISSA_MINUS_INFINITY -1
-/** EXI Float not a number */
-#define FLOAT_MANTISSA_NOT_A_NUMBER 0
-
-/** \brief EXI Events */
-typedef enum {
-	/** Start Document SD */
-	EXI_EVENT_START_DOCUMENT,
-	/** End Document ED */
-	EXI_EVENT_END_DOCUMENT,
-	/** Start Element SE(qname) */
-	EXI_EVENT_START_ELEMENT,
-	/** Start Element SE(uri:*) */
-	EXI_EVENT_START_ELEMENT_NS,
-	/** Start Element SE(*) generic */
-	EXI_EVENT_START_ELEMENT_GENERIC,
-	/** Start Element SE(*) generic undeclared */
-	EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED,
-	/** End Element EE */
-	EXI_EVENT_END_ELEMENT,
-	/** End Element EE undeclared*/
-	EXI_EVENT_END_ELEMENT_UNDECLARED,
-	/** Characters CH */
-	EXI_EVENT_CHARACTERS,
-	/** Characters CH generic */
-	EXI_EVENT_CHARACTERS_GENERIC,
-	/** Characters CH generic undeclared */
-	EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED,
-	/** Attribute AT(xsi:type) */
-	EXI_EVENT_ATTRIBUTE_XSI_TYPE,
-	/** Attribute AT(xsi:nil) */
-	EXI_EVENT_ATTRIBUTE_XSI_NIL,
-	/** Attribute AT(qname) */
-	EXI_EVENT_ATTRIBUTE,
-	/** Attribute AT(uri:*) */
-	EXI_EVENT_ATTRIBUTE_NS,
-	/** Attribute AT(*) generic */
-	EXI_EVENT_ATTRIBUTE_GENERIC,
-	/** Attribute AT(*) invalid value */
-	EXI_EVENT_ATTRIBUTE_INVALID_VALUE,
-	/** Attribute AT(*) any invalid value */
-	EXI_EVENT_ATTRIBUTE_ANY_INVALID_VALUE,
-	/** Attribute AT(*) generic undeclared */
-	EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED,
-	/* error state */
-	EXI_EVENT_ERROR
-} exi_event_t;
-
-
-/**
- * \brief 	Bit stream container
- *
- *			Structure for byteArray/file stream.
- */
-typedef struct {
-#if EXI_STREAM == BYTE_ARRAY
-	/**	byte array size */
-	uint32_t size;
-	/**	byte array data */
-	uint8_t* data;
-	/**	byte array next position in array */
-	uint32_t* pos;
-#endif
-#if EXI_STREAM == FILE_STREAM
-	/** file pointer */
-	FILE *file;
-#endif
-	/** Current byte buffer*/
-	uint8_t buffer;
-	/** Remaining bit capacity in current byte buffer*/
-	uint8_t capacity;
-} bitstream_t;
-
-
-/** \brief EXI Value Datatypes */
-typedef enum {
-	/** Binary Base64 */
-	EXI_DATATYPE_BINARY_BASE64,
-	/** Binary Hex */
-	EXI_DATATYPE_BINARY_HEX,
-	/** Boolean */
-	EXI_DATATYPE_BOOLEAN,
-	/** Boolean with Facets */
-	EXI_DATATYPE_BOOLEAN_FACET,
-	/** Decimal */
-	EXI_DATATYPE_DECIMAL,
-	/** Float & Double */
-	EXI_DATATYPE_FLOAT,
-	/** N-Bit Unsigned Integer */
-	EXI_DATATYPE_NBIT_UNSIGNED_INTEGER,
-	/** Unsigned Integer */
-	EXI_DATATYPE_UNSIGNED_INTEGER,
-	/** (Signed) Integer */
-	EXI_DATATYPE_INTEGER,
-	/** Datetime */
-	EXI_DATATYPE_DATETIME,
-	/** String */
-	EXI_DATATYPE_STRING,
-	/** Restricted Character Set String */
-	EXI_DATATYPE_RCS_STRING,
-	/** Enumeration */
-	EXI_DATATYPE_ENUMERATION,
-	/** List */
-	EXI_DATATYPE_LIST,
-	/** QName (e.g. xsi:type) */
-	EXI_DATATYPE_QNAME
-} exi_datatype_t;
-
-
-/** \brief EXI Integer Value types */
-typedef enum {
-	/** Unsigned Integer 8 bits */
-	EXI_UNSIGNED_INTEGER_8,
-	/** Unsigned Integer 16 bits */
-	EXI_UNSIGNED_INTEGER_16,
-	/** Unsigned Integer 32 bits */
-	EXI_UNSIGNED_INTEGER_32,
-	/** Unsigned Integer 64 bits */
-	EXI_UNSIGNED_INTEGER_64,
-	/** (Signed) Integer 8 bits */
-	EXI_INTEGER_8,
-	/** (Signed) Integer 16 bits */
-	EXI_INTEGER_16,
-	/** (Signed) Integer 32 bits */
-	EXI_INTEGER_32,
-	/** (Signed) Integer 64 bits */
-	EXI_INTEGER_64
-} exi_integer_type_t;
-
-
-/** \brief EXI Datetime types */
-typedef enum {
-	/** gYear */
-	EXI_DATETIME_GYEAR,
-	/** gYearMonth */
-	EXI_DATETIME_GYEARMONTH,
-	/** date */
-	EXI_DATETIME_DATE,
-	/** datetime */
-	EXI_DATETIME_DATETIME,
-	/** gMonth */
-	EXI_DATETIME_GMONTH,
-	/** gMonthDay */
-	EXI_DATETIME_GMONTHDAY,
-	/** gDay */
-	EXI_DATETIME_GDAY,
-	/** time */
-	EXI_DATETIME_TIME
-} exi_datetime_type_t;
-
-
-/** \brief String value type */
-typedef enum {
-	/** value miss */
-	EXI_STRING_VALUE_MISS,
-	/** value local-hit */
-	EXI_STRING_VALUE_LOCAL_HIT,
-	/** value global-hit */
-	EXI_STRING_VALUE_GLOBAL_HIT
-} exi_string_value_type_t;
-
-
-/** \brief Universal Character Set (UCS) strings */
-typedef struct {
-	/** UCS size  */
-	uint16_t size;
-	/** UCS character container */
-	uint32_t* codepoints;
-	/** UCS  current length == number of code-points, (len <= size) */
-	uint16_t len;
-} exi_string_ucs_t;
-
-
-/** \brief String value */
-typedef struct {
-	/** value type (e.g., miss, local-hit, global-hit) */
-	exi_string_value_type_t type;
-	/** miss entry */
-	exi_string_ucs_t miss;
-	/** (local) hit entry */
-	uint32_t localID;
-	/** (global) hit entry */
-	uint32_t globalID;
-} exi_string_value_t;
-
-
-/** \brief Restricted Characeter Set */
-typedef struct {
-	/** size */
-	uint16_t size;
-	/** rcs codepoints */
-	uint32_t* codepoints;
-	/** character coding length (less than 256 characters) */
-	uint8_t codingLength;
-} exi_rcs_t;
-
-
-/** \brief Byte value container */
-typedef struct {
-	/** bytes array size */
-	uint16_t size;
-	/** bytes array data container */
-	uint8_t* data;
-	/** bytes array length (len <= size) */
-	uint16_t len;
-} exi_bytes_t;
-
-
-/** \brief Integer value container */
-typedef struct {
-	/** type */
-	exi_integer_type_t type;
-	union {
-		/* (signed) values */
-		/** (signed) int 8 bits */
-		int8_t int8;
-		/** (signed) int 16 bits */
-		int16_t int16;
-		/** (signed) int 32 bits */
-		int32_t int32;
-		/** (signed) int 64 bits */
-		int64_t int64;
-		/* unsigned values */
-		/** unsigned int 8 bits */
-		uint8_t uint8;
-		/** unsigned int 16 bits */
-		uint16_t uint16;
-		/** unsigned int 32 bits */
-		uint32_t uint32;
-		/** unsigned int 64 bits */
-		uint64_t uint64;
-	} val;
-} exi_integer_t;
-
-
-/** \brief Float value container */
-typedef struct {
-	/** range of the mantissa is -(2^63) to 2^63-1 */
-	int64_t mantissa;
-	/** range of the exponent is - (2^14-1) to 2^14-1 */
-	int16_t exponent; /* base-10 */
-} exi_float_me_t;
-
-
-/** \brief Decimal value container */
-typedef struct {
-	/** a sign value */
-	int negative;
-	/** represents the integral portion of the Decimal */
-	exi_integer_t integral;
-	/** represents the fractional portion of the Decimal with the digits in reverse order to preserve leading zeros */
-	exi_integer_t reverseFraction;
-} exi_decimal_t;
-
-
-/** \brief Datetime value container */
-typedef struct {
-	/** datetime type */
-	exi_datetime_type_t type;
-	/** Datetime value for year */
-	int32_t year;
-	/** Datetime value for monthDay */
-	uint32_t monthDay;
-	/** Datetime value for time */
-	uint32_t time;
-	/** Datetime value for presenceFractionalSecs */
-	int presenceFractionalSecs;
-	/** Datetime value for fractionalSecs */
-	uint32_t fractionalSecs;
-	/** Datetime value for presenceTimezone */
-	int presenceTimezone;
-	/** Datetime value for timezone */
-	uint32_t timezone;
-} exi_datetime_t;
-
-
-/** \brief List value container */
-typedef struct {
-	/** list item type */
-	exi_datatype_t type;
-	/** number of items */
-	uint16_t len;
-	/* Special datatype: integer */
-	/* exi_integer_type_t intType;*/
-	/** Special datatype: datetime */
-	exi_datetime_type_t datetimeType;
-} exi_list_t;
-
-
-/** \brief Efficient qname */
-typedef struct {
-	/** namespace URI ID*/
-	uint16_t namespaceURI;
-	/** local name ID*/
-	uint16_t localPart;
-} exi_eqname_t;
-
-
-/** \brief Name entry type */
-typedef enum {
-	/** As known IDs */
-	EXI_NAME_ENTRY_TYPE_ID,
-	/** As String */
-	EXI_NAME_ENTRY_TYPE_STRING_AND_ID
-} exi_name_entry_type_t;
-
-
-/** \brief Name entry */
-typedef struct {
-	/** type */
-	exi_name_entry_type_t type;
-	/** entry ID */
-	uint16_t id;
-	/** entry string */
-	exi_string_ucs_t str;
-} exi_name_entry_t;
-
-
-/** \brief Qualified name */
-typedef struct {
-	/** Uri */
-	exi_name_entry_t uri;
-	/** LocalName */
-	exi_name_entry_t localName;
-} exi_qname_t;
-
-
-/*TODO Doxygen Documentation */
-
-/* ==================================== */
-/* URI and LocalName Entries */
-typedef struct exiNameTablePrepopulated {
-	/* number of namespaces AND length name-partitions array */
-	uint16_t len;
-	/* number of localName entries divided by URI */
-	uint16_t * localNames;
-} exi_name_table_prepopulated_t;
-
-#define EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_ENTRIES 25
-
-typedef enum {
-	EXI_NAME_PARTITION_URI, EXI_NAME_PARTITION_LOCALNAME
-} exi_name_partition_type_t;
-
-typedef struct {
-	char* uri;
-	uint16_t uriID;
-} exi_uri_partition_t;
-
-typedef struct {
-	char* localName;
-	uint16_t localNameID;
-	uint16_t uriID;
-} exi_localname_partition_t;
-
-typedef struct {
-	exi_name_partition_type_t namePartitionType;
-	struct {
-		exi_uri_partition_t uriPartition;
-		exi_localname_partition_t localNamePartition;
-	} entry;
-} exi_name_partition_t;
-
-typedef struct exiNameTableRuntime {
-	/* maximum number of characters in the name partitions entries PLUS null terminators */
-	/* char characters[EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_CHARACTERS + EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_ENTRIES]; */
-	/* uint16_t numberOfUsedCharacters; *//* initially zero <= EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_CHARACTERS */
-	/* maximum number of name partitions entries. Name partitions entries consist in all uri, and local-name partition entries */
-	exi_name_partition_t
-			namePartitionsEntries[EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_ENTRIES];
-	/* uint16_t numberOfUsedNamePartitions; *//* initially zero */
-	/* added entries */
-	uint16_t addedUriEntries; /* initially zero */
-	uint16_t addedLocalNameEntries; /* initially zero */
-} exi_name_table_runtime_t;
-
-
-/* StartTagContent grammar initially empty */
-/* ElementContent grammar has EE per default */
-typedef struct {
-	uint16_t qnameID;
-	uint16_t numberOfProductions;
-	int hasXsiType; /* StartTagContent only */
-	int hasEE; /* ElementContentper default TRUE */
-} exi_runtime_element_t;
-
-/* Note: We do have twice as many runtime grammars (StartTagContent and ElementContent)*/
-#define MAX_NUMBER_OF_RUNTIME_ELEMENTS 30
-
-typedef struct {
-	/** number of global strings */
-	uint16_t numberOfGlobalStrings;
-	/** size of local-names container */
-	uint16_t sizeLocalStrings;
-	/** number of local strings container */
-	uint16_t* numberOfLocalStrings;
-} exi_string_table_t;
-
-typedef struct {
-	/** stack of grammar states */
-	int16_t grammarStack[EXI_ELEMENT_STACK_SIZE];
-	/** stack of grammar elements / qnameIDs */
-	uint16_t elementStack[EXI_ELEMENT_STACK_SIZE];
-	/** stack index for both stacks */
-	uint16_t stackIndex;
-
-	/** event-code */
-	uint32_t eventCode;
-
-	/** name table entries, pre-populated */
-	exi_name_table_prepopulated_t nameTablePrepopulated;
-	/** name table entries, at runtime */
-	exi_name_table_runtime_t nameTableRuntime;
-
-	/** next qname ID */
-	uint16_t nextQNameID;
-
-	/** string table entries */
-	exi_string_table_t stringTable;
-
-	/** runtime built-in element grammars - numbers */
-	uint16_t numberOfRuntimeGrammars;
-	/** runtime built-in element grammars */
-	exi_runtime_element_t runtimeGrammars[MAX_NUMBER_OF_RUNTIME_ELEMENTS * 2];
-} exi_state_t;
-
-typedef struct {
-	/* type of value */
-	exi_datatype_t type;
-
-	/* base types */
-	int boolean;
-	uint32_t enumeration;
-
-	/* complex types: Integers, Bytes, Strings and Lists are not native types anymore */
-	exi_integer_t integer;
-	exi_bytes_t binary;
-	exi_string_value_t str;
-	exi_float_me_t float_me;
-	exi_decimal_t decimal;
-	exi_datetime_t datetime;
-	exi_list_t list;
-	exi_eqname_t eqname;
-} exi_value_t;
-
-
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 320
src/codec/EncoderChannel.h

@@ -1,320 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include "EXITypes.h"
-
-/**
- * \file 	EncoderChannel.h
- * \brief 	EXI Encoder Channel
- *
- */
-
-#ifndef ENCODER_CHANNEL_H
-#define ENCODER_CHANNEL_H
-
-/**
- * \brief 		Encode byte value
- *
- * \param       stream   		Output Stream
- * \param       b		   		byte
- * \return                  	Error-Code <> 0
- *
- */
-int encode(bitstream_t* stream, uint8_t b);
-
-
-/**
- * \brief 		Encode a single boolean value
- *
- * 				A false value is encoded as 0 and true value is encode as 1.
- *
- * \param       stream   		Output Stream
- * \param       b		   		boolean
- * \return                  	Error-Code <> 0
- *
- */
-int encodeBoolean(bitstream_t* stream, int b);
-
-
-/**
- * \brief 		Encode n-bit unsigned integer
- *
- * 				The n least significant bits of parameter b starting with the
- * 				most significant, i.e. from left to right.
- *
- * \param       stream   		Output Stream
- * \param       nbits		   	number of bits
- * \param       val		   		value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeNBitUnsignedInteger(bitstream_t* stream, uint16_t nbits, uint32_t val);
-
-
-/**
- * \brief 		Encode unsigned integer
- *
- * 				Encode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Output Stream
- * \param       iv		   		Unsigned integer value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeUnsignedInteger(bitstream_t* stream, exi_integer_t* iv);
-
-
-/**
- * \brief 		Encode unsigned integer
- *
- * 				Encode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Output Stream
- * \param       n		   		Unsigned integer value 32 bits
- * \return                  	Error-Code <> 0
- *
- */
-int encodeUnsignedInteger32(bitstream_t* stream, uint32_t n);
-
-
-/**
- * \brief 		Encode unsigned integer
- *
- * 				Encode an arbitrary precision non negative integer using
- * 				a sequence of octets. The most significant bit of the last
- * 				octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Output Stream
- * \param       n		   		Unsigned integer value 64 bits
- * \return                  	Error-Code <> 0
- *
- */
-int encodeUnsignedInteger64(bitstream_t* stream, uint64_t n);
-
-
-/**
- * \brief 		Encode integer
- *
- * 				Encode an arbitrary precision integer using a sign boolean
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Output Stream
- * \param       iv		   		Integer value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeInteger(bitstream_t* stream, exi_integer_t* iv);
-
-
-/**
- * \brief 		Encode integer
- *
- * 				Encode an arbitrary precision integer using a sign boolean
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Output Stream
- * \param       n		   		Integer value 32 bits
- * \return                  	Error-Code <> 0
- *
- */
-int encodeInteger32(bitstream_t* stream, int32_t n);
-
-
-/**
- * \brief 		Encode integer
- *
- * 				Encode an arbitrary precision integer using a sign boolean
- * 				followed by a sequence of octets. The most significant bit
- * 				of the last octet is set to zero to indicate sequence termination.
- * 				Only seven bits per octet are used to store the integer's value.
- *
- * \param       stream   		Output Stream
- * \param       n		   		Integer value 64 bits
- * \return                  	Error-Code <> 0
- *
- */
-int encodeInteger64(bitstream_t* stream, int64_t n);
-
-
-/**
- * \brief 		Encode float
- *
- * 				Encode a Float datatype as two consecutive Integers. The first
- * 				Integer represents the mantissa of the floating point number
- * 				and the second Integer represents the base-10 exponent of the
- * 				floating point number.
- *
- * \param       stream   		Output Stream
- * \param       f		   		Float value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeFloat(bitstream_t* stream, exi_float_me_t* f);
-
-
-/**
- * \brief 		Encode decimal
- *
- * 				Encode a decimal represented as a Boolean sign followed by two
- * 				Unsigned Integers. A sign value of zero (0) is used to represent
- * 				positive Decimal values and a sign value of one (1) is used to
- * 				represent negative Decimal values The first Integer represents
- * 				the integral portion of the Decimal value. The second positive
- * 				integer represents the fractional portion of the decimal with
- * 				the digits in reverse order to preserve leading zeros.
- *
- * \param       stream   		Output Stream
- * \param       d		   		Decimal value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeDecimal(bitstream_t* stream, exi_decimal_t* d);
-
-
-/**
- * \brief 		Encode string
- *
- * 				Encode a length prefixed sequence of characters.
- *
- * \param       stream   		Output Stream
- * \param       string		   	String
- * \return                  	Error-Code <> 0
- *
- */
-int encodeString(bitstream_t* stream, exi_string_ucs_t* string);
-
-
-/**
- * \brief 		Encode string value
- *
- * 				 Encode a length prefixed sequence of characters
- * 				 in the sense of string tables
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       string		   	String value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeStringValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID,
-		exi_string_value_t* string);
-
-
-/**
- * \brief 		Encode restricted character set value
- *
- * 				 Encode a length prefixed sequence of characters
- * 				 in the sense of string tables
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       rcs   			Restricted character set
- * \param       string		   	String value
- * \return                  	Error-Code <> 0
- *
- */
-int encodeRCSStringValue(bitstream_t* stream, exi_state_t* state,
-		uint16_t qnameID, exi_rcs_t* rcs, exi_string_value_t* string);
-
-
-/**
- * \brief 		Encode characters
- *
- * 				Encode a sequence of characters according to a given length.
- * 				Each character is represented by its UCS [ISO/IEC 10646]
- * 				code point encoded as an Unsigned Integer.
- *
- * \param       stream   		Output Stream
- * \param       chars   		Characters
- * \param       len				Numbr of characters
- * \return                  	Error-Code <> 0
- *
- */
-int encodeUCSCharacters(bitstream_t* stream, uint32_t* chars, uint16_t len);
-
-
-/**
- * \brief 		Encode binary
- *
- * 				Encode a binary value as a length-prefixed sequence of octets.
- *
- * \param       stream   		Output Stream
- * \param       bytes   		Byte values
- * \return                  	Error-Code <> 0
- *
- */
-int encodeBinary(bitstream_t* stream, exi_bytes_t* bytes);
-
-
-/**
- * \brief 		Encode datetime
- *
- * 				Encode a datetime representation which is a sequence of values
- * 				representing the individual components of the Date-Time.
- *
- * \param       stream   		Output Stream
- * \param       datetime   		Datetime values
- * \return                  	Error-Code <> 0
- *
- */
-int encodeDateTime(bitstream_t* stream, exi_datetime_t* datetime);
-
-
-/**
- * \brief 		Flush underlying bit output stream
- *
- * \param       stream   		Output Stream
- * \return                  	Error-Code <> 0
- *
- */
-int encodeFinish(bitstream_t* stream);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 108
src/codec/ErrorCodes.h

@@ -1,108 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	ErrorCodes.h
- * \brief 	Error Codes descriptions
- *
- */
-
-#ifndef EXI_ERROR_CODES_H
-#define EXI_ERROR_CODES_H
-
-
-#define EXI_ERROR_INPUT_STREAM_EOF -10
-#define EXI_ERROR_OUTPUT_STREAM_EOF -11
-#define EXI_ERROR_INPUT_FILE_HANDLE -12
-#define EXI_ERROR_OUTPUT_FILE -13
-
-#define EXI_ERROR_OUT_OF_BOUNDS -100
-#define EXI_ERROR_OUT_OF_STRING_BUFFER -101
-#define EXI_ERROR_OUT_OF_ASCII_BUFFER -102
-#define EXI_ERROR_OUT_OF_BYTE_BUFFER -103
-#define EXI_ERROR_OUT_OF_GRAMMAR_STACK -104
-#define EXI_ERROR_OUT_OF_RUNTIME_GRAMMAR_STACK -105
-#define EXI_ERROR_OUT_OF_QNAMES -106
-
-#define EXI_ERROR_UNKOWN_EVENT -109
-#define EXI_ERROR_UNKOWN_EVENT_CODE -110
-#define EXI_ERROR_UNEXPECTED_EVENT_LEVEL1 -111
-#define EXI_ERROR_UNEXPECTED_EVENT_LEVEL2 -112
-
-#define EXI_ERROR_UNEXPECTED_START_DOCUMENT -113
-#define EXI_ERROR_UNEXPECTED_END_DOCUMENT -114
-#define EXI_ERROR_UNEXPECTED_START_ELEMENT -115
-#define EXI_ERROR_UNEXPECTED_START_ELEMENT_NS -116
-#define EXI_ERROR_UNEXPECTED_START_ELEMENT_GENERIC -117
-#define EXI_ERROR_UNEXPECTED_START_ELEMENT_GENERIC_UNDECLARED -118
-#define EXI_ERROR_UNEXPECTED_END_ELEMENT -119
-#define EXI_ERROR_UNEXPECTED_CHARACTERS -120
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE -121
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE_NS -122
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE_GENERIC -123
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE_GENERIC_UNDECLARED -124
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE_XSI_TYPE -125
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE_XSI_NIL -126
-#define EXI_ERROR_UNEXPECTED_GRAMMAR_ID -127
-#define EXI_ERROR_UNEXPECTED_ATTRIBUTE_MOVE_TO_CONTENT_RULE -128
-
-#define EXI_UNSUPPORTED_NBIT_INTEGER_LENGTH -132
-#define EXI_UNSUPPORTED_EVENT_CODE_CHARACTERISTICS -133
-#define EXI_UNSUPPORTED_INTEGER_VALUE -134
-#define EXI_NEGATIVE_UNSIGNED_INTEGER_VALUE -135
-#define EXI_UNSUPPORTED_LIST_VALUE_TYPE -136
-#define EXI_UNSUPPORTED_HEADER_COOKIE -137
-#define EXI_UNSUPPORTED_HEADER_OPTIONS -138
-
-#define EXI_UNSUPPORTED_GLOBAL_ATTRIBUTE_VALUE_TYPE -139
-#define EXI_UNSUPPORTED_STRING_VALUE_TYPE -140
-#define EXI_UNSUPPORTED_INTEGER_VALUE_TYPE -141
-#define EXI_UNSUPPORTED_DATETIME_TYPE -142
-
-#define EXI_UNSUPPORTED_GRAMMAR_LEARNING_CH -150
-
-#define EXI_ERROR_UNEXPECTED_BYTE_VALUE -200
-
-
-#define EXI_ERROR_CONVERSION_NO_ASCII_CHARACTERS -300
-#define EXI_ERROR_CONVERSION_TYPE_TO_STRING -301
-
-
-#define EXI_DEVIANT_SUPPORT_NOT_DEPLOYED -500
-
-
-#endif /* EXI_ERROR_CODES_H */
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 133
src/codec/MethodsBag.c

@@ -1,133 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef METHODS_BAG_C
-#define METHODS_BAG_C
-
-#include "MethodsBag.h"
-#include "ErrorCodes.h"
-
-static const uint16_t smallLengths[] = { 0, 0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4,
-		4, 4, 4 };
-
-int exiGetCodingLength(uint32_t characteristics, uint16_t* codingLength) {
-	/* Note: we could use range expressions in switch statements but those are non-standard */
-	/* e.g., case 1 ... 5: */
-
-	if (characteristics < 17) {
-		*codingLength = smallLengths[characteristics];
-		return 0;
-	} else if (characteristics < 33) {
-		/* 17 .. 32 */
-		*codingLength = 5;
-		return 0;
-	} else if (characteristics < 65) {
-		/* 33 .. 64 */
-		*codingLength = 6;
-		return 0;
-	} else if (characteristics < 129) {
-		/* 65 .. 128 */
-		*codingLength = 7;
-		return 0;
-	} else if (characteristics < 257) {
-		/* 129 .. 256 */
-		*codingLength = 8;
-		return 0;
-	} else if (characteristics < 513) {
-		/* 257 .. 512 */
-		*codingLength = 9;
-		return 0;
-	} else if (characteristics < 1025) {
-		/* 513 .. 1024 */
-		*codingLength = 10;
-		return 0;
-	} else if (characteristics < 2049) {
-		/* 1025 .. 2048 */
-		*codingLength = 11;
-		return 0;
-	} else if (characteristics < 4097) {
-		/* 2049 .. 4096 */
-		*codingLength = 12;
-		return 0;
-	} else if (characteristics < 8193) {
-		/* 4097 .. 8192 */
-		*codingLength = 13;
-		return 0;
-	} else if (characteristics < 16385) {
-		/* 8193 .. 16384 */
-		*codingLength = 14;
-		return 0;
-	} else if (characteristics < 32769) {
-		/* 16385 .. 32768 */
-		*codingLength = 15;
-		return 0;
-	} else if (characteristics < 65537) {
-		/* 32769 .. 65536 */
-		*codingLength = 16;
-		return 0;
-	} else {
-		/*
-		return (int) Math.ceil(Math.log((double) (characteristics))
-				/ Math.log(2.0)); */
-		return EXI_UNSUPPORTED_EVENT_CODE_CHARACTERISTICS;
-	}
-
-}
-
-
-uint8_t numberOf7BitBlocksToRepresent(uint32_t n) {
-	/* assert (n >= 0); */
-
-	/* 7 bits */
-	if (n < 128) {
-		return 1;
-	}
-	/* 14 bits */
-	else if (n < 16384) {
-		return 2;
-	}
-	/* 21 bits */
-	else if (n < 2097152) {
-		return 3;
-	}
-	/* 28 bits */
-	else if (n < 268435456) {
-		return 4;
-	}
-	/* 35 bits */
-	else {
-		/* int, 32 bits */
-		return 5;
-	}
-}
-
-
-
-#endif
-

+ 0 - 70
src/codec/MethodsBag.h

@@ -1,70 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef METHODS_BAG_H
-#define METHODS_BAG_H
-
-/**
-* \file 	MethodsBag.h
-* \brief 	Method bag for bit and octet functions
-*
-*/
-
-
-#include <stdio.h>
-#include <stdint.h>
-#include <string.h>
-#include <stdlib.h>
-
-
-/**
- * \brief  	Returns the number of bits to identify the characteristics.
- *
- * \param       characteristics	number of characteristics
- * \param       codingLength   	number of bits
- * \return                  	Error-Code <> 0
- *
- */
-int exiGetCodingLength(uint32_t characteristics, uint16_t* codingLength);
-
-
-/**
- * \brief  	Returns the least number of 7 bit-blocks that is needed to represent the passed integer value
- *
- *			Note: Returns 1 if passed parameter is 0.
- *
- * \param       n				integer value
- * \return                  	Error-Code <> 0
- *
- */
-uint8_t numberOf7BitBlocksToRepresent(uint32_t n);
-
-
-#endif
-

+ 0 - 200
src/codec/NameTableEntries.c

@@ -1,200 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI__NAME_TABLE_ENTRIES_C
-#define EXI__NAME_TABLE_ENTRIES_C
-
-#include "NameTableEntries.h"
-
-
-
-/* ==================================== */
-/* String Table Population */
-
-/* localName entries for URI '', id = 0 */
-/* 
-  "Algorithm",  "Encoding",  "Id",  "MimeType",  "Name",
-  "Target",  "Type",  "URI",  "ValueType"
- */
-
-/* localName entries for URI 'http://www.w3.org/XML/1998/namespace', id = 1 */
-/* 
-  "base",  "id",  "lang",  "space"
- */
-
-/* localName entries for URI 'http://www.w3.org/2001/XMLSchema-instance', id = 2 */
-/* 
-  "nil",  "type"
- */
-
-/* localName entries for URI 'http://www.w3.org/2001/XMLSchema', id = 3 */
-/* 
-  "ENTITIES",  "ENTITY",  "ID",  "IDREF",  "IDREFS",
-  "NCName",  "NMTOKEN",  "NMTOKENS",  "NOTATION",  "Name",
-  "QName",  "anySimpleType",  "anyType",  "anyURI",  "base64Binary",
-  "boolean",  "byte",  "date",  "dateTime",  "decimal",
-  "double",  "duration",  "float",  "gDay",  "gMonth",
-  "gMonthDay",  "gYear",  "gYearMonth",  "hexBinary",  "int",
-  "integer",  "language",  "long",  "negativeInteger",  "nonNegativeInteger",
-  "nonPositiveInteger",  "normalizedString",  "positiveInteger",  "short",  "string",
-  "time",  "token",  "unsignedByte",  "unsignedInt",  "unsignedLong",
-  "unsignedShort"
- */
-
-/* localName entries for URI 'http://www.w3.org/2000/09/xmldsig#', id = 4 */
-/* 
-  "CanonicalizationMethod",  "CanonicalizationMethodType",  "CryptoBinary",  "DSAKeyValue",  "DSAKeyValueType",
-  "DigestMethod",  "DigestMethodType",  "DigestValue",  "DigestValueType",  "Exponent",
-  "G",  "HMACOutputLength",  "HMACOutputLengthType",  "J",  "KeyInfo",
-  "KeyInfoType",  "KeyName",  "KeyValue",  "KeyValueType",  "Manifest",
-  "ManifestType",  "MgmtData",  "Modulus",  "Object",  "ObjectType",
-  "P",  "PGPData",  "PGPDataType",  "PGPKeyID",  "PGPKeyPacket",
-  "PgenCounter",  "Q",  "RSAKeyValue",  "RSAKeyValueType",  "Reference",
-  "ReferenceType",  "RetrievalMethod",  "RetrievalMethodType",  "SPKIData",  "SPKIDataType",
-  "SPKISexp",  "Seed",  "Signature",  "SignatureMethod",  "SignatureMethodType",
-  "SignatureProperties",  "SignaturePropertiesType",  "SignatureProperty",  "SignaturePropertyType",  "SignatureType",
-  "SignatureValue",  "SignatureValueType",  "SignedInfo",  "SignedInfoType",  "Transform",
-  "TransformType",  "Transforms",  "TransformsType",  "X509CRL",  "X509Certificate",
-  "X509Data",  "X509DataType",  "X509IssuerName",  "X509IssuerSerial",  "X509IssuerSerialType",
-  "X509SKI",  "X509SerialNumber",  "X509SubjectName",  "XPath",  "Y"
-
- */
-
-/* localName entries for URI 'urn:iso:15118:2:2010:MsgBody', id = 5 */
-/* 
-  "AC_EVSEStatus",  "BulkChargingComplete",  "CableCheckReq",  "CableCheckReqType",  "CableCheckRes",
-  "CableCheckResType",  "CertificateInstallationReq",  "CertificateInstallationReqType",  "CertificateInstallationRes",  "CertificateInstallationResType",
-  "CertificateUpdateReq",  "CertificateUpdateReqType",  "CertificateUpdateRes",  "CertificateUpdateResType",  "ChargeParameterDiscoveryReq",
-  "ChargeParameterDiscoveryReqType",  "ChargeParameterDiscoveryRes",  "ChargeParameterDiscoveryResType",  "ChargeService",  "ChargingComplete",
-  "ChargingProfile",  "ChargingStatusReq",  "ChargingStatusReqType",  "ChargingStatusRes",  "ChargingStatusResType",
-  "ContractAuthenticationReq",  "ContractAuthenticationReqType",  "ContractAuthenticationRes",  "ContractAuthenticationResType",  "ContractID",
-  "ContractSignatureCertChain",  "ContractSignatureEncryptedPrivateKey",  "CurrentDemandReq",  "CurrentDemandReqType",  "CurrentDemandRes",
-  "CurrentDemandResType",  "DC_EVSEStatus",  "DC_EVStatus",  "DHParams",  "DateTimeNow",
-  "EVCCID",  "EVMaximumCurrentLimit",  "EVMaximumPowerLimit",  "EVMaximumVoltageLimit",  "EVRequestedEnergyTransferType",
-  "EVSECurrentLimitAchieved",  "EVSEID",  "EVSEMaxCurrent",  "EVSEMaximumCurrentLimit",  "EVSEMaximumPowerLimit",
-  "EVSEMaximumVoltageLimit",  "EVSEPowerLimitAchieved",  "EVSEPresentCurrent",  "EVSEPresentVoltage",  "EVSEProcessing",
-  "EVSEVoltageLimitAchieved",  "EVTargetCurrent",  "EVTargetVoltage",  "GenChallenge",  "ListOfRootCertificateIDs",
-  "MeterInfo",  "MeteringReceiptReq",  "MeteringReceiptReqType",  "MeteringReceiptRes",  "MeteringReceiptResType",
-  "OEMProvisioningCert",  "PaymentDetailsReq",  "PaymentDetailsReqType",  "PaymentDetailsRes",  "PaymentDetailsResType",
-  "PaymentOptions",  "PowerDeliveryReq",  "PowerDeliveryReqType",  "PowerDeliveryRes",  "PowerDeliveryResType",
-  "PreChargeReq",  "PreChargeReqType",  "PreChargeRes",  "PreChargeResType",  "ReadyToChargeState",
-  "ReceiptRequired",  "RemainingTimeToBulkSoC",  "RemainingTimeToFullSoC",  "ResponseCode",  "RetryCounter",
-  "SAScheduleTupleID",  "SelectedPaymentOption",  "SelectedServiceList",  "ServiceCategory",  "ServiceDetailReq",
-  "ServiceDetailReqType",  "ServiceDetailRes",  "ServiceDetailResType",  "ServiceDiscoveryReq",  "ServiceDiscoveryReqType",
-  "ServiceDiscoveryRes",  "ServiceDiscoveryResType",  "ServiceID",  "ServiceList",  "ServiceParameterList",
-  "ServicePaymentSelectionReq",  "ServicePaymentSelectionReqType",  "ServicePaymentSelectionRes",  "ServicePaymentSelectionResType",  "ServiceScope",
-  "SessionID",  "SessionSetupReq",  "SessionSetupReqType",  "SessionSetupRes",  "SessionSetupResType",
-  "SessionStopReq",  "SessionStopRes",  "SessionStopResType",  "SessionStopType",  "WeldingDetectionReq",
-  "WeldingDetectionReqType",  "WeldingDetectionRes",  "WeldingDetectionResType"
- */
-
-/* localName entries for URI 'urn:iso:15118:2:2010:MsgDataTypes', id = 6 */
-/* 
-  "AC_EVChargeParameter",  "AC_EVChargeParameterType",  "AC_EVSEChargeParameter",  "AC_EVSEChargeParameterType",  "AC_EVSEStatus",
-  "AC_EVSEStatusType",  "BulkChargingComplete",  "BulkSOC",  "Certificate",  "CertificateChainType",
-  "ChargingComplete",  "ChargingProfileEntryMaxPower",  "ChargingProfileEntryStart",  "ChargingProfileType",  "ConsumptionCost",
-  "ConsumptionCostType",  "Cost",  "CostType",  "DC_EVChargeParameter",  "DC_EVChargeParameterType",
-  "DC_EVErrorCodeType",  "DC_EVPowerDeliveryParameter",  "DC_EVPowerDeliveryParameterType",  "DC_EVSEChargeParameter",  "DC_EVSEChargeParameterType",
-  "DC_EVSEStatus",  "DC_EVSEStatusCodeType",  "DC_EVSEStatusType",  "DC_EVStatus",  "DC_EVStatusType",
-  "DepartureTime",  "EAmount",  "EPriceLevel",  "EVCabinConditioning",  "EVChargeParameter",
-  "EVChargeParameterType",  "EVEnergyCapacity",  "EVEnergyRequest",  "EVErrorCode",  "EVMaxCurrent",
-  "EVMaxVoltage",  "EVMaximumCurrentLimit",  "EVMaximumPowerLimit",  "EVMaximumVoltageLimit",  "EVMinCurrent",
-  "EVPowerDeliveryParameter",  "EVPowerDeliveryParameterType",  "EVRESSConditioning",  "EVRESSSOC",  "EVReady",
-  "EVRequestedEnergyTransferType",  "EVSEChargeParameter",  "EVSEChargeParameterType",  "EVSECurrentRegulationTolerance",  "EVSEEnergyToBeDelivered",
-  "EVSEIsolationStatus",  "EVSEMaxCurrent",  "EVSEMaxVoltage",  "EVSEMaximumCurrentLimit",  "EVSEMaximumPowerLimit",
-  "EVSEMaximumVoltageLimit",  "EVSEMinCurrent",  "EVSEMinimumCurrentLimit",  "EVSEMinimumVoltageLimit",  "EVSENotification",
-  "EVSENotificationType",  "EVSEPeakCurrentRipple",  "EVSEProcessingType",  "EVSEStatus",  "EVSEStatusCode",
-  "EVSEStatusType",  "EVSESupportedEnergyTransferType",  "EVStatus",  "EVStatusType",  "EnergyTransferType",
-  "Entry",  "EntryType",  "FaultCode",  "FaultMsg",  "FreeService",
-  "FullSOC",  "IntervalType",  "ListOfRootCertificateIDsType",  "MeterID",  "MeterInfoType",
-  "MeterReading",  "MeterStatus",  "Multiplier",  "NotificationMaxDelay",  "NotificationType",
-  "NumEPriceLevels",  "PMax",  "PMaxSchedule",  "PMaxScheduleEntry",  "PMaxScheduleEntryType",
-  "PMaxScheduleID",  "PMaxScheduleType",  "PMaxType",  "Parameter",  "ParameterSet",
-  "ParameterSetID",  "ParameterSetType",  "ParameterType",  "PaymentOption",  "PaymentOptionsType",
-  "PhysicalValueType",  "PowerSwitchClosed",  "ProfileEntry",  "ProfileEntryType",  "RCD",
-  "RelativeTimeInterval",  "RelativeTimeIntervalType",  "RootCertificateID",  "SAIDType",  "SAScheduleList",
-  "SAScheduleListType",  "SAScheduleTuple",  "SAScheduleTupleID",  "SAScheduleTupleType",  "SASchedules",
-  "SASchedulesType",  "SalesTariff",  "SalesTariffDescription",  "SalesTariffEntry",  "SalesTariffEntryType",
-  "SalesTariffID",  "SalesTariffType",  "SelectedService",  "SelectedServiceListType",  "SelectedServiceType",
-  "Service",  "ServiceCategory",  "ServiceCharge",  "ServiceChargeType",  "ServiceID",
-  "ServiceName",  "ServiceParameterListType",  "ServiceScope",  "ServiceTag",  "ServiceTagListType",
-  "ServiceTagType",  "ServiceType",  "SigMeterReading",  "SubCertificates",  "SubCertificatesType",
-  "TMeter",  "TimeInterval",  "Unit",  "Value",  "amount",
-  "amountMultiplier",  "boolValue",  "byteValue",  "certificateType",  "contractIDType",
-  "costKind",  "costKindType",  "dHParamsType",  "duration",  "evccIDType",
-  "evseIDType",  "faultCodeType",  "faultMsgType",  "genChallengeType",  "intValue",
-  "isolationLevelType",  "meterIDType",  "meterStatusType",  "paymentOptionType",  "percentValueType",
-  "physicalValue",  "privateKeyType",  "responseCodeType",  "rootCertificateIDType",  "serviceCategoryType",
-  "serviceIDType",  "serviceNameType",  "serviceScopeType",  "sessionIDType",  "shortValue",
-  "sigMeterReadingType",  "start",  "startValue",  "stringValue",  "tariffDescriptionType",
-  "unitMultiplierType",  "unitSymbolType",  "valueType"
- */
-
-/* localName entries for URI 'urn:iso:15118:2:2010:MsgDef', id = 7 */
-/* 
-  "Body",  "BodyBaseType",  "BodyElement",  "BodyType",  "Header",
-  "V2G_Message"
- */
-
-/* localName entries for URI 'urn:iso:15118:2:2010:MsgHeader', id = 8 */
-/* 
-  "MessageHeaderType",  "Notification",  "SessionID"
- */
-
-
-/* number of local-name entries per URI */
-static uint16_t localNames[9] = {
-	/* '' */
-	9,
-	/* 'http://www.w3.org/XML/1998/namespace' */
-	4,
-	/* 'http://www.w3.org/2001/XMLSchema-instance' */
-	2,
-	/* 'http://www.w3.org/2001/XMLSchema' */
-	46,
-	/* 'http://www.w3.org/2000/09/xmldsig#' */
-	70,
-	/* 'urn:iso:15118:2:2010:MsgBody' */
-	118,
-	/* 'urn:iso:15118:2:2010:MsgDataTypes' */
-	188,
-	/* 'urn:iso:15118:2:2010:MsgDef' */
-	6,
-	/* 'urn:iso:15118:2:2010:MsgHeader' */
-	3
-};
-
-
-exi_name_table_prepopulated_t exiNameTablePrepopulated = { 9, localNames };
-
-
-
-
-#endif
-

+ 0 - 41
src/codec/NameTableEntries.h

@@ -1,41 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI__NAME_TABLE_ENTRIES_H
-#define EXI__NAME_TABLE_ENTRIES_H
-
-#include "EXITypes.h"
-
-/* ==================================== */
-/* String Table Population */
-
-extern exi_name_table_prepopulated_t exiNameTablePrepopulated;
-
-#endif
-

+ 0 - 51
src/codec/QNameDefines.h

@@ -1,51 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI__QNAME_DEFINES_H
-#define EXI__QNAME_DEFINES_H
-
-/** Number of pre-populated qnames */
-#define EXI_NUMBER_OF_PREPOPULATED_QNAMES 446
-
-/** Number of runtime qnames */
-#define EXI_MAX_NUMBER_OF_SUPPORTED_RUNTIMES_QNAMES 100
-
-/** Number of overall qnames (pre-populated from schema and runtime qnames) */
-#define EXI_MAX_NUMBER_OF_QNAMES (EXI_NUMBER_OF_PREPOPULATED_QNAMES + EXI_MAX_NUMBER_OF_SUPPORTED_RUNTIMES_QNAMES)
-
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 981
src/codec/QNames.c

@@ -1,981 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI__QNAMES_C
-#define EXI__QNAMES_C
-
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-#include "QNameDefines.h"
-
-/* qname is a composition of namespaceURI(ID) and localPart(ID) */
-static exi_eqname_t qnames[EXI_MAX_NUMBER_OF_QNAMES] = {
-	/* qnameID == 0: Algorithm */
-	{0, 0},
-	/* qnameID == 1: Encoding */
-	{0, 1},
-	/* qnameID == 2: Id */
-	{0, 2},
-	/* qnameID == 3: MimeType */
-	{0, 3},
-	/* qnameID == 4: Name */
-	{0, 4},
-	/* qnameID == 5: Target */
-	{0, 5},
-	/* qnameID == 6: Type */
-	{0, 6},
-	/* qnameID == 7: URI */
-	{0, 7},
-	/* qnameID == 8: ValueType */
-	{0, 8},
-	/* qnameID == 9: {http://www.w3.org/XML/1998/namespace}base */
-	{1, 0},
-	/* qnameID == 10: {http://www.w3.org/XML/1998/namespace}id */
-	{1, 1},
-	/* qnameID == 11: {http://www.w3.org/XML/1998/namespace}lang */
-	{1, 2},
-	/* qnameID == 12: {http://www.w3.org/XML/1998/namespace}space */
-	{1, 3},
-	/* qnameID == 13: {http://www.w3.org/2001/XMLSchema-instance}nil */
-	{2, 0},
-	/* qnameID == 14: {http://www.w3.org/2001/XMLSchema-instance}type */
-	{2, 1},
-	/* qnameID == 15: {http://www.w3.org/2001/XMLSchema}ENTITIES */
-	{3, 0},
-	/* qnameID == 16: {http://www.w3.org/2001/XMLSchema}ENTITY */
-	{3, 1},
-	/* qnameID == 17: {http://www.w3.org/2001/XMLSchema}ID */
-	{3, 2},
-	/* qnameID == 18: {http://www.w3.org/2001/XMLSchema}IDREF */
-	{3, 3},
-	/* qnameID == 19: {http://www.w3.org/2001/XMLSchema}IDREFS */
-	{3, 4},
-	/* qnameID == 20: {http://www.w3.org/2001/XMLSchema}NCName */
-	{3, 5},
-	/* qnameID == 21: {http://www.w3.org/2001/XMLSchema}NMTOKEN */
-	{3, 6},
-	/* qnameID == 22: {http://www.w3.org/2001/XMLSchema}NMTOKENS */
-	{3, 7},
-	/* qnameID == 23: {http://www.w3.org/2001/XMLSchema}NOTATION */
-	{3, 8},
-	/* qnameID == 24: {http://www.w3.org/2001/XMLSchema}Name */
-	{3, 9},
-	/* qnameID == 25: {http://www.w3.org/2001/XMLSchema}QName */
-	{3, 10},
-	/* qnameID == 26: {http://www.w3.org/2001/XMLSchema}anySimpleType */
-	{3, 11},
-	/* qnameID == 27: {http://www.w3.org/2001/XMLSchema}anyType */
-	{3, 12},
-	/* qnameID == 28: {http://www.w3.org/2001/XMLSchema}anyURI */
-	{3, 13},
-	/* qnameID == 29: {http://www.w3.org/2001/XMLSchema}base64Binary */
-	{3, 14},
-	/* qnameID == 30: {http://www.w3.org/2001/XMLSchema}boolean */
-	{3, 15},
-	/* qnameID == 31: {http://www.w3.org/2001/XMLSchema}byte */
-	{3, 16},
-	/* qnameID == 32: {http://www.w3.org/2001/XMLSchema}date */
-	{3, 17},
-	/* qnameID == 33: {http://www.w3.org/2001/XMLSchema}dateTime */
-	{3, 18},
-	/* qnameID == 34: {http://www.w3.org/2001/XMLSchema}decimal */
-	{3, 19},
-	/* qnameID == 35: {http://www.w3.org/2001/XMLSchema}double */
-	{3, 20},
-	/* qnameID == 36: {http://www.w3.org/2001/XMLSchema}duration */
-	{3, 21},
-	/* qnameID == 37: {http://www.w3.org/2001/XMLSchema}float */
-	{3, 22},
-	/* qnameID == 38: {http://www.w3.org/2001/XMLSchema}gDay */
-	{3, 23},
-	/* qnameID == 39: {http://www.w3.org/2001/XMLSchema}gMonth */
-	{3, 24},
-	/* qnameID == 40: {http://www.w3.org/2001/XMLSchema}gMonthDay */
-	{3, 25},
-	/* qnameID == 41: {http://www.w3.org/2001/XMLSchema}gYear */
-	{3, 26},
-	/* qnameID == 42: {http://www.w3.org/2001/XMLSchema}gYearMonth */
-	{3, 27},
-	/* qnameID == 43: {http://www.w3.org/2001/XMLSchema}hexBinary */
-	{3, 28},
-	/* qnameID == 44: {http://www.w3.org/2001/XMLSchema}int */
-	{3, 29},
-	/* qnameID == 45: {http://www.w3.org/2001/XMLSchema}integer */
-	{3, 30},
-	/* qnameID == 46: {http://www.w3.org/2001/XMLSchema}language */
-	{3, 31},
-	/* qnameID == 47: {http://www.w3.org/2001/XMLSchema}long */
-	{3, 32},
-	/* qnameID == 48: {http://www.w3.org/2001/XMLSchema}negativeInteger */
-	{3, 33},
-	/* qnameID == 49: {http://www.w3.org/2001/XMLSchema}nonNegativeInteger */
-	{3, 34},
-	/* qnameID == 50: {http://www.w3.org/2001/XMLSchema}nonPositiveInteger */
-	{3, 35},
-	/* qnameID == 51: {http://www.w3.org/2001/XMLSchema}normalizedString */
-	{3, 36},
-	/* qnameID == 52: {http://www.w3.org/2001/XMLSchema}positiveInteger */
-	{3, 37},
-	/* qnameID == 53: {http://www.w3.org/2001/XMLSchema}short */
-	{3, 38},
-	/* qnameID == 54: {http://www.w3.org/2001/XMLSchema}string */
-	{3, 39},
-	/* qnameID == 55: {http://www.w3.org/2001/XMLSchema}time */
-	{3, 40},
-	/* qnameID == 56: {http://www.w3.org/2001/XMLSchema}token */
-	{3, 41},
-	/* qnameID == 57: {http://www.w3.org/2001/XMLSchema}unsignedByte */
-	{3, 42},
-	/* qnameID == 58: {http://www.w3.org/2001/XMLSchema}unsignedInt */
-	{3, 43},
-	/* qnameID == 59: {http://www.w3.org/2001/XMLSchema}unsignedLong */
-	{3, 44},
-	/* qnameID == 60: {http://www.w3.org/2001/XMLSchema}unsignedShort */
-	{3, 45},
-	/* qnameID == 61: {http://www.w3.org/2000/09/xmldsig#}CanonicalizationMethod */
-	{4, 0},
-	/* qnameID == 62: {http://www.w3.org/2000/09/xmldsig#}CanonicalizationMethodType */
-	{4, 1},
-	/* qnameID == 63: {http://www.w3.org/2000/09/xmldsig#}CryptoBinary */
-	{4, 2},
-	/* qnameID == 64: {http://www.w3.org/2000/09/xmldsig#}DSAKeyValue */
-	{4, 3},
-	/* qnameID == 65: {http://www.w3.org/2000/09/xmldsig#}DSAKeyValueType */
-	{4, 4},
-	/* qnameID == 66: {http://www.w3.org/2000/09/xmldsig#}DigestMethod */
-	{4, 5},
-	/* qnameID == 67: {http://www.w3.org/2000/09/xmldsig#}DigestMethodType */
-	{4, 6},
-	/* qnameID == 68: {http://www.w3.org/2000/09/xmldsig#}DigestValue */
-	{4, 7},
-	/* qnameID == 69: {http://www.w3.org/2000/09/xmldsig#}DigestValueType */
-	{4, 8},
-	/* qnameID == 70: {http://www.w3.org/2000/09/xmldsig#}Exponent */
-	{4, 9},
-	/* qnameID == 71: {http://www.w3.org/2000/09/xmldsig#}G */
-	{4, 10},
-	/* qnameID == 72: {http://www.w3.org/2000/09/xmldsig#}HMACOutputLength */
-	{4, 11},
-	/* qnameID == 73: {http://www.w3.org/2000/09/xmldsig#}HMACOutputLengthType */
-	{4, 12},
-	/* qnameID == 74: {http://www.w3.org/2000/09/xmldsig#}J */
-	{4, 13},
-	/* qnameID == 75: {http://www.w3.org/2000/09/xmldsig#}KeyInfo */
-	{4, 14},
-	/* qnameID == 76: {http://www.w3.org/2000/09/xmldsig#}KeyInfoType */
-	{4, 15},
-	/* qnameID == 77: {http://www.w3.org/2000/09/xmldsig#}KeyName */
-	{4, 16},
-	/* qnameID == 78: {http://www.w3.org/2000/09/xmldsig#}KeyValue */
-	{4, 17},
-	/* qnameID == 79: {http://www.w3.org/2000/09/xmldsig#}KeyValueType */
-	{4, 18},
-	/* qnameID == 80: {http://www.w3.org/2000/09/xmldsig#}Manifest */
-	{4, 19},
-	/* qnameID == 81: {http://www.w3.org/2000/09/xmldsig#}ManifestType */
-	{4, 20},
-	/* qnameID == 82: {http://www.w3.org/2000/09/xmldsig#}MgmtData */
-	{4, 21},
-	/* qnameID == 83: {http://www.w3.org/2000/09/xmldsig#}Modulus */
-	{4, 22},
-	/* qnameID == 84: {http://www.w3.org/2000/09/xmldsig#}Object */
-	{4, 23},
-	/* qnameID == 85: {http://www.w3.org/2000/09/xmldsig#}ObjectType */
-	{4, 24},
-	/* qnameID == 86: {http://www.w3.org/2000/09/xmldsig#}P */
-	{4, 25},
-	/* qnameID == 87: {http://www.w3.org/2000/09/xmldsig#}PGPData */
-	{4, 26},
-	/* qnameID == 88: {http://www.w3.org/2000/09/xmldsig#}PGPDataType */
-	{4, 27},
-	/* qnameID == 89: {http://www.w3.org/2000/09/xmldsig#}PGPKeyID */
-	{4, 28},
-	/* qnameID == 90: {http://www.w3.org/2000/09/xmldsig#}PGPKeyPacket */
-	{4, 29},
-	/* qnameID == 91: {http://www.w3.org/2000/09/xmldsig#}PgenCounter */
-	{4, 30},
-	/* qnameID == 92: {http://www.w3.org/2000/09/xmldsig#}Q */
-	{4, 31},
-	/* qnameID == 93: {http://www.w3.org/2000/09/xmldsig#}RSAKeyValue */
-	{4, 32},
-	/* qnameID == 94: {http://www.w3.org/2000/09/xmldsig#}RSAKeyValueType */
-	{4, 33},
-	/* qnameID == 95: {http://www.w3.org/2000/09/xmldsig#}Reference */
-	{4, 34},
-	/* qnameID == 96: {http://www.w3.org/2000/09/xmldsig#}ReferenceType */
-	{4, 35},
-	/* qnameID == 97: {http://www.w3.org/2000/09/xmldsig#}RetrievalMethod */
-	{4, 36},
-	/* qnameID == 98: {http://www.w3.org/2000/09/xmldsig#}RetrievalMethodType */
-	{4, 37},
-	/* qnameID == 99: {http://www.w3.org/2000/09/xmldsig#}SPKIData */
-	{4, 38},
-	/* qnameID == 100: {http://www.w3.org/2000/09/xmldsig#}SPKIDataType */
-	{4, 39},
-	/* qnameID == 101: {http://www.w3.org/2000/09/xmldsig#}SPKISexp */
-	{4, 40},
-	/* qnameID == 102: {http://www.w3.org/2000/09/xmldsig#}Seed */
-	{4, 41},
-	/* qnameID == 103: {http://www.w3.org/2000/09/xmldsig#}Signature */
-	{4, 42},
-	/* qnameID == 104: {http://www.w3.org/2000/09/xmldsig#}SignatureMethod */
-	{4, 43},
-	/* qnameID == 105: {http://www.w3.org/2000/09/xmldsig#}SignatureMethodType */
-	{4, 44},
-	/* qnameID == 106: {http://www.w3.org/2000/09/xmldsig#}SignatureProperties */
-	{4, 45},
-	/* qnameID == 107: {http://www.w3.org/2000/09/xmldsig#}SignaturePropertiesType */
-	{4, 46},
-	/* qnameID == 108: {http://www.w3.org/2000/09/xmldsig#}SignatureProperty */
-	{4, 47},
-	/* qnameID == 109: {http://www.w3.org/2000/09/xmldsig#}SignaturePropertyType */
-	{4, 48},
-	/* qnameID == 110: {http://www.w3.org/2000/09/xmldsig#}SignatureType */
-	{4, 49},
-	/* qnameID == 111: {http://www.w3.org/2000/09/xmldsig#}SignatureValue */
-	{4, 50},
-	/* qnameID == 112: {http://www.w3.org/2000/09/xmldsig#}SignatureValueType */
-	{4, 51},
-	/* qnameID == 113: {http://www.w3.org/2000/09/xmldsig#}SignedInfo */
-	{4, 52},
-	/* qnameID == 114: {http://www.w3.org/2000/09/xmldsig#}SignedInfoType */
-	{4, 53},
-	/* qnameID == 115: {http://www.w3.org/2000/09/xmldsig#}Transform */
-	{4, 54},
-	/* qnameID == 116: {http://www.w3.org/2000/09/xmldsig#}TransformType */
-	{4, 55},
-	/* qnameID == 117: {http://www.w3.org/2000/09/xmldsig#}Transforms */
-	{4, 56},
-	/* qnameID == 118: {http://www.w3.org/2000/09/xmldsig#}TransformsType */
-	{4, 57},
-	/* qnameID == 119: {http://www.w3.org/2000/09/xmldsig#}X509CRL */
-	{4, 58},
-	/* qnameID == 120: {http://www.w3.org/2000/09/xmldsig#}X509Certificate */
-	{4, 59},
-	/* qnameID == 121: {http://www.w3.org/2000/09/xmldsig#}X509Data */
-	{4, 60},
-	/* qnameID == 122: {http://www.w3.org/2000/09/xmldsig#}X509DataType */
-	{4, 61},
-	/* qnameID == 123: {http://www.w3.org/2000/09/xmldsig#}X509IssuerName */
-	{4, 62},
-	/* qnameID == 124: {http://www.w3.org/2000/09/xmldsig#}X509IssuerSerial */
-	{4, 63},
-	/* qnameID == 125: {http://www.w3.org/2000/09/xmldsig#}X509IssuerSerialType */
-	{4, 64},
-	/* qnameID == 126: {http://www.w3.org/2000/09/xmldsig#}X509SKI */
-	{4, 65},
-	/* qnameID == 127: {http://www.w3.org/2000/09/xmldsig#}X509SerialNumber */
-	{4, 66},
-	/* qnameID == 128: {http://www.w3.org/2000/09/xmldsig#}X509SubjectName */
-	{4, 67},
-	/* qnameID == 129: {http://www.w3.org/2000/09/xmldsig#}XPath */
-	{4, 68},
-	/* qnameID == 130: {http://www.w3.org/2000/09/xmldsig#}Y */
-	{4, 69},
-	/* qnameID == 131: {urn:iso:15118:2:2010:MsgBody}AC_EVSEStatus */
-	{5, 0},
-	/* qnameID == 132: {urn:iso:15118:2:2010:MsgBody}BulkChargingComplete */
-	{5, 1},
-	/* qnameID == 133: {urn:iso:15118:2:2010:MsgBody}CableCheckReq */
-	{5, 2},
-	/* qnameID == 134: {urn:iso:15118:2:2010:MsgBody}CableCheckReqType */
-	{5, 3},
-	/* qnameID == 135: {urn:iso:15118:2:2010:MsgBody}CableCheckRes */
-	{5, 4},
-	/* qnameID == 136: {urn:iso:15118:2:2010:MsgBody}CableCheckResType */
-	{5, 5},
-	/* qnameID == 137: {urn:iso:15118:2:2010:MsgBody}CertificateInstallationReq */
-	{5, 6},
-	/* qnameID == 138: {urn:iso:15118:2:2010:MsgBody}CertificateInstallationReqType */
-	{5, 7},
-	/* qnameID == 139: {urn:iso:15118:2:2010:MsgBody}CertificateInstallationRes */
-	{5, 8},
-	/* qnameID == 140: {urn:iso:15118:2:2010:MsgBody}CertificateInstallationResType */
-	{5, 9},
-	/* qnameID == 141: {urn:iso:15118:2:2010:MsgBody}CertificateUpdateReq */
-	{5, 10},
-	/* qnameID == 142: {urn:iso:15118:2:2010:MsgBody}CertificateUpdateReqType */
-	{5, 11},
-	/* qnameID == 143: {urn:iso:15118:2:2010:MsgBody}CertificateUpdateRes */
-	{5, 12},
-	/* qnameID == 144: {urn:iso:15118:2:2010:MsgBody}CertificateUpdateResType */
-	{5, 13},
-	/* qnameID == 145: {urn:iso:15118:2:2010:MsgBody}ChargeParameterDiscoveryReq */
-	{5, 14},
-	/* qnameID == 146: {urn:iso:15118:2:2010:MsgBody}ChargeParameterDiscoveryReqType */
-	{5, 15},
-	/* qnameID == 147: {urn:iso:15118:2:2010:MsgBody}ChargeParameterDiscoveryRes */
-	{5, 16},
-	/* qnameID == 148: {urn:iso:15118:2:2010:MsgBody}ChargeParameterDiscoveryResType */
-	{5, 17},
-	/* qnameID == 149: {urn:iso:15118:2:2010:MsgBody}ChargeService */
-	{5, 18},
-	/* qnameID == 150: {urn:iso:15118:2:2010:MsgBody}ChargingComplete */
-	{5, 19},
-	/* qnameID == 151: {urn:iso:15118:2:2010:MsgBody}ChargingProfile */
-	{5, 20},
-	/* qnameID == 152: {urn:iso:15118:2:2010:MsgBody}ChargingStatusReq */
-	{5, 21},
-	/* qnameID == 153: {urn:iso:15118:2:2010:MsgBody}ChargingStatusReqType */
-	{5, 22},
-	/* qnameID == 154: {urn:iso:15118:2:2010:MsgBody}ChargingStatusRes */
-	{5, 23},
-	/* qnameID == 155: {urn:iso:15118:2:2010:MsgBody}ChargingStatusResType */
-	{5, 24},
-	/* qnameID == 156: {urn:iso:15118:2:2010:MsgBody}ContractAuthenticationReq */
-	{5, 25},
-	/* qnameID == 157: {urn:iso:15118:2:2010:MsgBody}ContractAuthenticationReqType */
-	{5, 26},
-	/* qnameID == 158: {urn:iso:15118:2:2010:MsgBody}ContractAuthenticationRes */
-	{5, 27},
-	/* qnameID == 159: {urn:iso:15118:2:2010:MsgBody}ContractAuthenticationResType */
-	{5, 28},
-	/* qnameID == 160: {urn:iso:15118:2:2010:MsgBody}ContractID */
-	{5, 29},
-	/* qnameID == 161: {urn:iso:15118:2:2010:MsgBody}ContractSignatureCertChain */
-	{5, 30},
-	/* qnameID == 162: {urn:iso:15118:2:2010:MsgBody}ContractSignatureEncryptedPrivateKey */
-	{5, 31},
-	/* qnameID == 163: {urn:iso:15118:2:2010:MsgBody}CurrentDemandReq */
-	{5, 32},
-	/* qnameID == 164: {urn:iso:15118:2:2010:MsgBody}CurrentDemandReqType */
-	{5, 33},
-	/* qnameID == 165: {urn:iso:15118:2:2010:MsgBody}CurrentDemandRes */
-	{5, 34},
-	/* qnameID == 166: {urn:iso:15118:2:2010:MsgBody}CurrentDemandResType */
-	{5, 35},
-	/* qnameID == 167: {urn:iso:15118:2:2010:MsgBody}DC_EVSEStatus */
-	{5, 36},
-	/* qnameID == 168: {urn:iso:15118:2:2010:MsgBody}DC_EVStatus */
-	{5, 37},
-	/* qnameID == 169: {urn:iso:15118:2:2010:MsgBody}DHParams */
-	{5, 38},
-	/* qnameID == 170: {urn:iso:15118:2:2010:MsgBody}DateTimeNow */
-	{5, 39},
-	/* qnameID == 171: {urn:iso:15118:2:2010:MsgBody}EVCCID */
-	{5, 40},
-	/* qnameID == 172: {urn:iso:15118:2:2010:MsgBody}EVMaximumCurrentLimit */
-	{5, 41},
-	/* qnameID == 173: {urn:iso:15118:2:2010:MsgBody}EVMaximumPowerLimit */
-	{5, 42},
-	/* qnameID == 174: {urn:iso:15118:2:2010:MsgBody}EVMaximumVoltageLimit */
-	{5, 43},
-	/* qnameID == 175: {urn:iso:15118:2:2010:MsgBody}EVRequestedEnergyTransferType */
-	{5, 44},
-	/* qnameID == 176: {urn:iso:15118:2:2010:MsgBody}EVSECurrentLimitAchieved */
-	{5, 45},
-	/* qnameID == 177: {urn:iso:15118:2:2010:MsgBody}EVSEID */
-	{5, 46},
-	/* qnameID == 178: {urn:iso:15118:2:2010:MsgBody}EVSEMaxCurrent */
-	{5, 47},
-	/* qnameID == 179: {urn:iso:15118:2:2010:MsgBody}EVSEMaximumCurrentLimit */
-	{5, 48},
-	/* qnameID == 180: {urn:iso:15118:2:2010:MsgBody}EVSEMaximumPowerLimit */
-	{5, 49},
-	/* qnameID == 181: {urn:iso:15118:2:2010:MsgBody}EVSEMaximumVoltageLimit */
-	{5, 50},
-	/* qnameID == 182: {urn:iso:15118:2:2010:MsgBody}EVSEPowerLimitAchieved */
-	{5, 51},
-	/* qnameID == 183: {urn:iso:15118:2:2010:MsgBody}EVSEPresentCurrent */
-	{5, 52},
-	/* qnameID == 184: {urn:iso:15118:2:2010:MsgBody}EVSEPresentVoltage */
-	{5, 53},
-	/* qnameID == 185: {urn:iso:15118:2:2010:MsgBody}EVSEProcessing */
-	{5, 54},
-	/* qnameID == 186: {urn:iso:15118:2:2010:MsgBody}EVSEVoltageLimitAchieved */
-	{5, 55},
-	/* qnameID == 187: {urn:iso:15118:2:2010:MsgBody}EVTargetCurrent */
-	{5, 56},
-	/* qnameID == 188: {urn:iso:15118:2:2010:MsgBody}EVTargetVoltage */
-	{5, 57},
-	/* qnameID == 189: {urn:iso:15118:2:2010:MsgBody}GenChallenge */
-	{5, 58},
-	/* qnameID == 190: {urn:iso:15118:2:2010:MsgBody}ListOfRootCertificateIDs */
-	{5, 59},
-	/* qnameID == 191: {urn:iso:15118:2:2010:MsgBody}MeterInfo */
-	{5, 60},
-	/* qnameID == 192: {urn:iso:15118:2:2010:MsgBody}MeteringReceiptReq */
-	{5, 61},
-	/* qnameID == 193: {urn:iso:15118:2:2010:MsgBody}MeteringReceiptReqType */
-	{5, 62},
-	/* qnameID == 194: {urn:iso:15118:2:2010:MsgBody}MeteringReceiptRes */
-	{5, 63},
-	/* qnameID == 195: {urn:iso:15118:2:2010:MsgBody}MeteringReceiptResType */
-	{5, 64},
-	/* qnameID == 196: {urn:iso:15118:2:2010:MsgBody}OEMProvisioningCert */
-	{5, 65},
-	/* qnameID == 197: {urn:iso:15118:2:2010:MsgBody}PaymentDetailsReq */
-	{5, 66},
-	/* qnameID == 198: {urn:iso:15118:2:2010:MsgBody}PaymentDetailsReqType */
-	{5, 67},
-	/* qnameID == 199: {urn:iso:15118:2:2010:MsgBody}PaymentDetailsRes */
-	{5, 68},
-	/* qnameID == 200: {urn:iso:15118:2:2010:MsgBody}PaymentDetailsResType */
-	{5, 69},
-	/* qnameID == 201: {urn:iso:15118:2:2010:MsgBody}PaymentOptions */
-	{5, 70},
-	/* qnameID == 202: {urn:iso:15118:2:2010:MsgBody}PowerDeliveryReq */
-	{5, 71},
-	/* qnameID == 203: {urn:iso:15118:2:2010:MsgBody}PowerDeliveryReqType */
-	{5, 72},
-	/* qnameID == 204: {urn:iso:15118:2:2010:MsgBody}PowerDeliveryRes */
-	{5, 73},
-	/* qnameID == 205: {urn:iso:15118:2:2010:MsgBody}PowerDeliveryResType */
-	{5, 74},
-	/* qnameID == 206: {urn:iso:15118:2:2010:MsgBody}PreChargeReq */
-	{5, 75},
-	/* qnameID == 207: {urn:iso:15118:2:2010:MsgBody}PreChargeReqType */
-	{5, 76},
-	/* qnameID == 208: {urn:iso:15118:2:2010:MsgBody}PreChargeRes */
-	{5, 77},
-	/* qnameID == 209: {urn:iso:15118:2:2010:MsgBody}PreChargeResType */
-	{5, 78},
-	/* qnameID == 210: {urn:iso:15118:2:2010:MsgBody}ReadyToChargeState */
-	{5, 79},
-	/* qnameID == 211: {urn:iso:15118:2:2010:MsgBody}ReceiptRequired */
-	{5, 80},
-	/* qnameID == 212: {urn:iso:15118:2:2010:MsgBody}RemainingTimeToBulkSoC */
-	{5, 81},
-	/* qnameID == 213: {urn:iso:15118:2:2010:MsgBody}RemainingTimeToFullSoC */
-	{5, 82},
-	/* qnameID == 214: {urn:iso:15118:2:2010:MsgBody}ResponseCode */
-	{5, 83},
-	/* qnameID == 215: {urn:iso:15118:2:2010:MsgBody}RetryCounter */
-	{5, 84},
-	/* qnameID == 216: {urn:iso:15118:2:2010:MsgBody}SAScheduleTupleID */
-	{5, 85},
-	/* qnameID == 217: {urn:iso:15118:2:2010:MsgBody}SelectedPaymentOption */
-	{5, 86},
-	/* qnameID == 218: {urn:iso:15118:2:2010:MsgBody}SelectedServiceList */
-	{5, 87},
-	/* qnameID == 219: {urn:iso:15118:2:2010:MsgBody}ServiceCategory */
-	{5, 88},
-	/* qnameID == 220: {urn:iso:15118:2:2010:MsgBody}ServiceDetailReq */
-	{5, 89},
-	/* qnameID == 221: {urn:iso:15118:2:2010:MsgBody}ServiceDetailReqType */
-	{5, 90},
-	/* qnameID == 222: {urn:iso:15118:2:2010:MsgBody}ServiceDetailRes */
-	{5, 91},
-	/* qnameID == 223: {urn:iso:15118:2:2010:MsgBody}ServiceDetailResType */
-	{5, 92},
-	/* qnameID == 224: {urn:iso:15118:2:2010:MsgBody}ServiceDiscoveryReq */
-	{5, 93},
-	/* qnameID == 225: {urn:iso:15118:2:2010:MsgBody}ServiceDiscoveryReqType */
-	{5, 94},
-	/* qnameID == 226: {urn:iso:15118:2:2010:MsgBody}ServiceDiscoveryRes */
-	{5, 95},
-	/* qnameID == 227: {urn:iso:15118:2:2010:MsgBody}ServiceDiscoveryResType */
-	{5, 96},
-	/* qnameID == 228: {urn:iso:15118:2:2010:MsgBody}ServiceID */
-	{5, 97},
-	/* qnameID == 229: {urn:iso:15118:2:2010:MsgBody}ServiceList */
-	{5, 98},
-	/* qnameID == 230: {urn:iso:15118:2:2010:MsgBody}ServiceParameterList */
-	{5, 99},
-	/* qnameID == 231: {urn:iso:15118:2:2010:MsgBody}ServicePaymentSelectionReq */
-	{5, 100},
-	/* qnameID == 232: {urn:iso:15118:2:2010:MsgBody}ServicePaymentSelectionReqType */
-	{5, 101},
-	/* qnameID == 233: {urn:iso:15118:2:2010:MsgBody}ServicePaymentSelectionRes */
-	{5, 102},
-	/* qnameID == 234: {urn:iso:15118:2:2010:MsgBody}ServicePaymentSelectionResType */
-	{5, 103},
-	/* qnameID == 235: {urn:iso:15118:2:2010:MsgBody}ServiceScope */
-	{5, 104},
-	/* qnameID == 236: {urn:iso:15118:2:2010:MsgBody}SessionID */
-	{5, 105},
-	/* qnameID == 237: {urn:iso:15118:2:2010:MsgBody}SessionSetupReq */
-	{5, 106},
-	/* qnameID == 238: {urn:iso:15118:2:2010:MsgBody}SessionSetupReqType */
-	{5, 107},
-	/* qnameID == 239: {urn:iso:15118:2:2010:MsgBody}SessionSetupRes */
-	{5, 108},
-	/* qnameID == 240: {urn:iso:15118:2:2010:MsgBody}SessionSetupResType */
-	{5, 109},
-	/* qnameID == 241: {urn:iso:15118:2:2010:MsgBody}SessionStopReq */
-	{5, 110},
-	/* qnameID == 242: {urn:iso:15118:2:2010:MsgBody}SessionStopRes */
-	{5, 111},
-	/* qnameID == 243: {urn:iso:15118:2:2010:MsgBody}SessionStopResType */
-	{5, 112},
-	/* qnameID == 244: {urn:iso:15118:2:2010:MsgBody}SessionStopType */
-	{5, 113},
-	/* qnameID == 245: {urn:iso:15118:2:2010:MsgBody}WeldingDetectionReq */
-	{5, 114},
-	/* qnameID == 246: {urn:iso:15118:2:2010:MsgBody}WeldingDetectionReqType */
-	{5, 115},
-	/* qnameID == 247: {urn:iso:15118:2:2010:MsgBody}WeldingDetectionRes */
-	{5, 116},
-	/* qnameID == 248: {urn:iso:15118:2:2010:MsgBody}WeldingDetectionResType */
-	{5, 117},
-	/* qnameID == 249: {urn:iso:15118:2:2010:MsgDataTypes}AC_EVChargeParameter */
-	{6, 0},
-	/* qnameID == 250: {urn:iso:15118:2:2010:MsgDataTypes}AC_EVChargeParameterType */
-	{6, 1},
-	/* qnameID == 251: {urn:iso:15118:2:2010:MsgDataTypes}AC_EVSEChargeParameter */
-	{6, 2},
-	/* qnameID == 252: {urn:iso:15118:2:2010:MsgDataTypes}AC_EVSEChargeParameterType */
-	{6, 3},
-	/* qnameID == 253: {urn:iso:15118:2:2010:MsgDataTypes}AC_EVSEStatus */
-	{6, 4},
-	/* qnameID == 254: {urn:iso:15118:2:2010:MsgDataTypes}AC_EVSEStatusType */
-	{6, 5},
-	/* qnameID == 255: {urn:iso:15118:2:2010:MsgDataTypes}BulkChargingComplete */
-	{6, 6},
-	/* qnameID == 256: {urn:iso:15118:2:2010:MsgDataTypes}BulkSOC */
-	{6, 7},
-	/* qnameID == 257: {urn:iso:15118:2:2010:MsgDataTypes}Certificate */
-	{6, 8},
-	/* qnameID == 258: {urn:iso:15118:2:2010:MsgDataTypes}CertificateChainType */
-	{6, 9},
-	/* qnameID == 259: {urn:iso:15118:2:2010:MsgDataTypes}ChargingComplete */
-	{6, 10},
-	/* qnameID == 260: {urn:iso:15118:2:2010:MsgDataTypes}ChargingProfileEntryMaxPower */
-	{6, 11},
-	/* qnameID == 261: {urn:iso:15118:2:2010:MsgDataTypes}ChargingProfileEntryStart */
-	{6, 12},
-	/* qnameID == 262: {urn:iso:15118:2:2010:MsgDataTypes}ChargingProfileType */
-	{6, 13},
-	/* qnameID == 263: {urn:iso:15118:2:2010:MsgDataTypes}ConsumptionCost */
-	{6, 14},
-	/* qnameID == 264: {urn:iso:15118:2:2010:MsgDataTypes}ConsumptionCostType */
-	{6, 15},
-	/* qnameID == 265: {urn:iso:15118:2:2010:MsgDataTypes}Cost */
-	{6, 16},
-	/* qnameID == 266: {urn:iso:15118:2:2010:MsgDataTypes}CostType */
-	{6, 17},
-	/* qnameID == 267: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVChargeParameter */
-	{6, 18},
-	/* qnameID == 268: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVChargeParameterType */
-	{6, 19},
-	/* qnameID == 269: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVErrorCodeType */
-	{6, 20},
-	/* qnameID == 270: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVPowerDeliveryParameter */
-	{6, 21},
-	/* qnameID == 271: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVPowerDeliveryParameterType */
-	{6, 22},
-	/* qnameID == 272: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVSEChargeParameter */
-	{6, 23},
-	/* qnameID == 273: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVSEChargeParameterType */
-	{6, 24},
-	/* qnameID == 274: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVSEStatus */
-	{6, 25},
-	/* qnameID == 275: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVSEStatusCodeType */
-	{6, 26},
-	/* qnameID == 276: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVSEStatusType */
-	{6, 27},
-	/* qnameID == 277: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVStatus */
-	{6, 28},
-	/* qnameID == 278: {urn:iso:15118:2:2010:MsgDataTypes}DC_EVStatusType */
-	{6, 29},
-	/* qnameID == 279: {urn:iso:15118:2:2010:MsgDataTypes}DepartureTime */
-	{6, 30},
-	/* qnameID == 280: {urn:iso:15118:2:2010:MsgDataTypes}EAmount */
-	{6, 31},
-	/* qnameID == 281: {urn:iso:15118:2:2010:MsgDataTypes}EPriceLevel */
-	{6, 32},
-	/* qnameID == 282: {urn:iso:15118:2:2010:MsgDataTypes}EVCabinConditioning */
-	{6, 33},
-	/* qnameID == 283: {urn:iso:15118:2:2010:MsgDataTypes}EVChargeParameter */
-	{6, 34},
-	/* qnameID == 284: {urn:iso:15118:2:2010:MsgDataTypes}EVChargeParameterType */
-	{6, 35},
-	/* qnameID == 285: {urn:iso:15118:2:2010:MsgDataTypes}EVEnergyCapacity */
-	{6, 36},
-	/* qnameID == 286: {urn:iso:15118:2:2010:MsgDataTypes}EVEnergyRequest */
-	{6, 37},
-	/* qnameID == 287: {urn:iso:15118:2:2010:MsgDataTypes}EVErrorCode */
-	{6, 38},
-	/* qnameID == 288: {urn:iso:15118:2:2010:MsgDataTypes}EVMaxCurrent */
-	{6, 39},
-	/* qnameID == 289: {urn:iso:15118:2:2010:MsgDataTypes}EVMaxVoltage */
-	{6, 40},
-	/* qnameID == 290: {urn:iso:15118:2:2010:MsgDataTypes}EVMaximumCurrentLimit */
-	{6, 41},
-	/* qnameID == 291: {urn:iso:15118:2:2010:MsgDataTypes}EVMaximumPowerLimit */
-	{6, 42},
-	/* qnameID == 292: {urn:iso:15118:2:2010:MsgDataTypes}EVMaximumVoltageLimit */
-	{6, 43},
-	/* qnameID == 293: {urn:iso:15118:2:2010:MsgDataTypes}EVMinCurrent */
-	{6, 44},
-	/* qnameID == 294: {urn:iso:15118:2:2010:MsgDataTypes}EVPowerDeliveryParameter */
-	{6, 45},
-	/* qnameID == 295: {urn:iso:15118:2:2010:MsgDataTypes}EVPowerDeliveryParameterType */
-	{6, 46},
-	/* qnameID == 296: {urn:iso:15118:2:2010:MsgDataTypes}EVRESSConditioning */
-	{6, 47},
-	/* qnameID == 297: {urn:iso:15118:2:2010:MsgDataTypes}EVRESSSOC */
-	{6, 48},
-	/* qnameID == 298: {urn:iso:15118:2:2010:MsgDataTypes}EVReady */
-	{6, 49},
-	/* qnameID == 299: {urn:iso:15118:2:2010:MsgDataTypes}EVRequestedEnergyTransferType */
-	{6, 50},
-	/* qnameID == 300: {urn:iso:15118:2:2010:MsgDataTypes}EVSEChargeParameter */
-	{6, 51},
-	/* qnameID == 301: {urn:iso:15118:2:2010:MsgDataTypes}EVSEChargeParameterType */
-	{6, 52},
-	/* qnameID == 302: {urn:iso:15118:2:2010:MsgDataTypes}EVSECurrentRegulationTolerance */
-	{6, 53},
-	/* qnameID == 303: {urn:iso:15118:2:2010:MsgDataTypes}EVSEEnergyToBeDelivered */
-	{6, 54},
-	/* qnameID == 304: {urn:iso:15118:2:2010:MsgDataTypes}EVSEIsolationStatus */
-	{6, 55},
-	/* qnameID == 305: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMaxCurrent */
-	{6, 56},
-	/* qnameID == 306: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMaxVoltage */
-	{6, 57},
-	/* qnameID == 307: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMaximumCurrentLimit */
-	{6, 58},
-	/* qnameID == 308: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMaximumPowerLimit */
-	{6, 59},
-	/* qnameID == 309: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMaximumVoltageLimit */
-	{6, 60},
-	/* qnameID == 310: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMinCurrent */
-	{6, 61},
-	/* qnameID == 311: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMinimumCurrentLimit */
-	{6, 62},
-	/* qnameID == 312: {urn:iso:15118:2:2010:MsgDataTypes}EVSEMinimumVoltageLimit */
-	{6, 63},
-	/* qnameID == 313: {urn:iso:15118:2:2010:MsgDataTypes}EVSENotification */
-	{6, 64},
-	/* qnameID == 314: {urn:iso:15118:2:2010:MsgDataTypes}EVSENotificationType */
-	{6, 65},
-	/* qnameID == 315: {urn:iso:15118:2:2010:MsgDataTypes}EVSEPeakCurrentRipple */
-	{6, 66},
-	/* qnameID == 316: {urn:iso:15118:2:2010:MsgDataTypes}EVSEProcessingType */
-	{6, 67},
-	/* qnameID == 317: {urn:iso:15118:2:2010:MsgDataTypes}EVSEStatus */
-	{6, 68},
-	/* qnameID == 318: {urn:iso:15118:2:2010:MsgDataTypes}EVSEStatusCode */
-	{6, 69},
-	/* qnameID == 319: {urn:iso:15118:2:2010:MsgDataTypes}EVSEStatusType */
-	{6, 70},
-	/* qnameID == 320: {urn:iso:15118:2:2010:MsgDataTypes}EVSESupportedEnergyTransferType */
-	{6, 71},
-	/* qnameID == 321: {urn:iso:15118:2:2010:MsgDataTypes}EVStatus */
-	{6, 72},
-	/* qnameID == 322: {urn:iso:15118:2:2010:MsgDataTypes}EVStatusType */
-	{6, 73},
-	/* qnameID == 323: {urn:iso:15118:2:2010:MsgDataTypes}EnergyTransferType */
-	{6, 74},
-	/* qnameID == 324: {urn:iso:15118:2:2010:MsgDataTypes}Entry */
-	{6, 75},
-	/* qnameID == 325: {urn:iso:15118:2:2010:MsgDataTypes}EntryType */
-	{6, 76},
-	/* qnameID == 326: {urn:iso:15118:2:2010:MsgDataTypes}FaultCode */
-	{6, 77},
-	/* qnameID == 327: {urn:iso:15118:2:2010:MsgDataTypes}FaultMsg */
-	{6, 78},
-	/* qnameID == 328: {urn:iso:15118:2:2010:MsgDataTypes}FreeService */
-	{6, 79},
-	/* qnameID == 329: {urn:iso:15118:2:2010:MsgDataTypes}FullSOC */
-	{6, 80},
-	/* qnameID == 330: {urn:iso:15118:2:2010:MsgDataTypes}IntervalType */
-	{6, 81},
-	/* qnameID == 331: {urn:iso:15118:2:2010:MsgDataTypes}ListOfRootCertificateIDsType */
-	{6, 82},
-	/* qnameID == 332: {urn:iso:15118:2:2010:MsgDataTypes}MeterID */
-	{6, 83},
-	/* qnameID == 333: {urn:iso:15118:2:2010:MsgDataTypes}MeterInfoType */
-	{6, 84},
-	/* qnameID == 334: {urn:iso:15118:2:2010:MsgDataTypes}MeterReading */
-	{6, 85},
-	/* qnameID == 335: {urn:iso:15118:2:2010:MsgDataTypes}MeterStatus */
-	{6, 86},
-	/* qnameID == 336: {urn:iso:15118:2:2010:MsgDataTypes}Multiplier */
-	{6, 87},
-	/* qnameID == 337: {urn:iso:15118:2:2010:MsgDataTypes}NotificationMaxDelay */
-	{6, 88},
-	/* qnameID == 338: {urn:iso:15118:2:2010:MsgDataTypes}NotificationType */
-	{6, 89},
-	/* qnameID == 339: {urn:iso:15118:2:2010:MsgDataTypes}NumEPriceLevels */
-	{6, 90},
-	/* qnameID == 340: {urn:iso:15118:2:2010:MsgDataTypes}PMax */
-	{6, 91},
-	/* qnameID == 341: {urn:iso:15118:2:2010:MsgDataTypes}PMaxSchedule */
-	{6, 92},
-	/* qnameID == 342: {urn:iso:15118:2:2010:MsgDataTypes}PMaxScheduleEntry */
-	{6, 93},
-	/* qnameID == 343: {urn:iso:15118:2:2010:MsgDataTypes}PMaxScheduleEntryType */
-	{6, 94},
-	/* qnameID == 344: {urn:iso:15118:2:2010:MsgDataTypes}PMaxScheduleID */
-	{6, 95},
-	/* qnameID == 345: {urn:iso:15118:2:2010:MsgDataTypes}PMaxScheduleType */
-	{6, 96},
-	/* qnameID == 346: {urn:iso:15118:2:2010:MsgDataTypes}PMaxType */
-	{6, 97},
-	/* qnameID == 347: {urn:iso:15118:2:2010:MsgDataTypes}Parameter */
-	{6, 98},
-	/* qnameID == 348: {urn:iso:15118:2:2010:MsgDataTypes}ParameterSet */
-	{6, 99},
-	/* qnameID == 349: {urn:iso:15118:2:2010:MsgDataTypes}ParameterSetID */
-	{6, 100},
-	/* qnameID == 350: {urn:iso:15118:2:2010:MsgDataTypes}ParameterSetType */
-	{6, 101},
-	/* qnameID == 351: {urn:iso:15118:2:2010:MsgDataTypes}ParameterType */
-	{6, 102},
-	/* qnameID == 352: {urn:iso:15118:2:2010:MsgDataTypes}PaymentOption */
-	{6, 103},
-	/* qnameID == 353: {urn:iso:15118:2:2010:MsgDataTypes}PaymentOptionsType */
-	{6, 104},
-	/* qnameID == 354: {urn:iso:15118:2:2010:MsgDataTypes}PhysicalValueType */
-	{6, 105},
-	/* qnameID == 355: {urn:iso:15118:2:2010:MsgDataTypes}PowerSwitchClosed */
-	{6, 106},
-	/* qnameID == 356: {urn:iso:15118:2:2010:MsgDataTypes}ProfileEntry */
-	{6, 107},
-	/* qnameID == 357: {urn:iso:15118:2:2010:MsgDataTypes}ProfileEntryType */
-	{6, 108},
-	/* qnameID == 358: {urn:iso:15118:2:2010:MsgDataTypes}RCD */
-	{6, 109},
-	/* qnameID == 359: {urn:iso:15118:2:2010:MsgDataTypes}RelativeTimeInterval */
-	{6, 110},
-	/* qnameID == 360: {urn:iso:15118:2:2010:MsgDataTypes}RelativeTimeIntervalType */
-	{6, 111},
-	/* qnameID == 361: {urn:iso:15118:2:2010:MsgDataTypes}RootCertificateID */
-	{6, 112},
-	/* qnameID == 362: {urn:iso:15118:2:2010:MsgDataTypes}SAIDType */
-	{6, 113},
-	/* qnameID == 363: {urn:iso:15118:2:2010:MsgDataTypes}SAScheduleList */
-	{6, 114},
-	/* qnameID == 364: {urn:iso:15118:2:2010:MsgDataTypes}SAScheduleListType */
-	{6, 115},
-	/* qnameID == 365: {urn:iso:15118:2:2010:MsgDataTypes}SAScheduleTuple */
-	{6, 116},
-	/* qnameID == 366: {urn:iso:15118:2:2010:MsgDataTypes}SAScheduleTupleID */
-	{6, 117},
-	/* qnameID == 367: {urn:iso:15118:2:2010:MsgDataTypes}SAScheduleTupleType */
-	{6, 118},
-	/* qnameID == 368: {urn:iso:15118:2:2010:MsgDataTypes}SASchedules */
-	{6, 119},
-	/* qnameID == 369: {urn:iso:15118:2:2010:MsgDataTypes}SASchedulesType */
-	{6, 120},
-	/* qnameID == 370: {urn:iso:15118:2:2010:MsgDataTypes}SalesTariff */
-	{6, 121},
-	/* qnameID == 371: {urn:iso:15118:2:2010:MsgDataTypes}SalesTariffDescription */
-	{6, 122},
-	/* qnameID == 372: {urn:iso:15118:2:2010:MsgDataTypes}SalesTariffEntry */
-	{6, 123},
-	/* qnameID == 373: {urn:iso:15118:2:2010:MsgDataTypes}SalesTariffEntryType */
-	{6, 124},
-	/* qnameID == 374: {urn:iso:15118:2:2010:MsgDataTypes}SalesTariffID */
-	{6, 125},
-	/* qnameID == 375: {urn:iso:15118:2:2010:MsgDataTypes}SalesTariffType */
-	{6, 126},
-	/* qnameID == 376: {urn:iso:15118:2:2010:MsgDataTypes}SelectedService */
-	{6, 127},
-	/* qnameID == 377: {urn:iso:15118:2:2010:MsgDataTypes}SelectedServiceListType */
-	{6, 128},
-	/* qnameID == 378: {urn:iso:15118:2:2010:MsgDataTypes}SelectedServiceType */
-	{6, 129},
-	/* qnameID == 379: {urn:iso:15118:2:2010:MsgDataTypes}Service */
-	{6, 130},
-	/* qnameID == 380: {urn:iso:15118:2:2010:MsgDataTypes}ServiceCategory */
-	{6, 131},
-	/* qnameID == 381: {urn:iso:15118:2:2010:MsgDataTypes}ServiceCharge */
-	{6, 132},
-	/* qnameID == 382: {urn:iso:15118:2:2010:MsgDataTypes}ServiceChargeType */
-	{6, 133},
-	/* qnameID == 383: {urn:iso:15118:2:2010:MsgDataTypes}ServiceID */
-	{6, 134},
-	/* qnameID == 384: {urn:iso:15118:2:2010:MsgDataTypes}ServiceName */
-	{6, 135},
-	/* qnameID == 385: {urn:iso:15118:2:2010:MsgDataTypes}ServiceParameterListType */
-	{6, 136},
-	/* qnameID == 386: {urn:iso:15118:2:2010:MsgDataTypes}ServiceScope */
-	{6, 137},
-	/* qnameID == 387: {urn:iso:15118:2:2010:MsgDataTypes}ServiceTag */
-	{6, 138},
-	/* qnameID == 388: {urn:iso:15118:2:2010:MsgDataTypes}ServiceTagListType */
-	{6, 139},
-	/* qnameID == 389: {urn:iso:15118:2:2010:MsgDataTypes}ServiceTagType */
-	{6, 140},
-	/* qnameID == 390: {urn:iso:15118:2:2010:MsgDataTypes}ServiceType */
-	{6, 141},
-	/* qnameID == 391: {urn:iso:15118:2:2010:MsgDataTypes}SigMeterReading */
-	{6, 142},
-	/* qnameID == 392: {urn:iso:15118:2:2010:MsgDataTypes}SubCertificates */
-	{6, 143},
-	/* qnameID == 393: {urn:iso:15118:2:2010:MsgDataTypes}SubCertificatesType */
-	{6, 144},
-	/* qnameID == 394: {urn:iso:15118:2:2010:MsgDataTypes}TMeter */
-	{6, 145},
-	/* qnameID == 395: {urn:iso:15118:2:2010:MsgDataTypes}TimeInterval */
-	{6, 146},
-	/* qnameID == 396: {urn:iso:15118:2:2010:MsgDataTypes}Unit */
-	{6, 147},
-	/* qnameID == 397: {urn:iso:15118:2:2010:MsgDataTypes}Value */
-	{6, 148},
-	/* qnameID == 398: {urn:iso:15118:2:2010:MsgDataTypes}amount */
-	{6, 149},
-	/* qnameID == 399: {urn:iso:15118:2:2010:MsgDataTypes}amountMultiplier */
-	{6, 150},
-	/* qnameID == 400: {urn:iso:15118:2:2010:MsgDataTypes}boolValue */
-	{6, 151},
-	/* qnameID == 401: {urn:iso:15118:2:2010:MsgDataTypes}byteValue */
-	{6, 152},
-	/* qnameID == 402: {urn:iso:15118:2:2010:MsgDataTypes}certificateType */
-	{6, 153},
-	/* qnameID == 403: {urn:iso:15118:2:2010:MsgDataTypes}contractIDType */
-	{6, 154},
-	/* qnameID == 404: {urn:iso:15118:2:2010:MsgDataTypes}costKind */
-	{6, 155},
-	/* qnameID == 405: {urn:iso:15118:2:2010:MsgDataTypes}costKindType */
-	{6, 156},
-	/* qnameID == 406: {urn:iso:15118:2:2010:MsgDataTypes}dHParamsType */
-	{6, 157},
-	/* qnameID == 407: {urn:iso:15118:2:2010:MsgDataTypes}duration */
-	{6, 158},
-	/* qnameID == 408: {urn:iso:15118:2:2010:MsgDataTypes}evccIDType */
-	{6, 159},
-	/* qnameID == 409: {urn:iso:15118:2:2010:MsgDataTypes}evseIDType */
-	{6, 160},
-	/* qnameID == 410: {urn:iso:15118:2:2010:MsgDataTypes}faultCodeType */
-	{6, 161},
-	/* qnameID == 411: {urn:iso:15118:2:2010:MsgDataTypes}faultMsgType */
-	{6, 162},
-	/* qnameID == 412: {urn:iso:15118:2:2010:MsgDataTypes}genChallengeType */
-	{6, 163},
-	/* qnameID == 413: {urn:iso:15118:2:2010:MsgDataTypes}intValue */
-	{6, 164},
-	/* qnameID == 414: {urn:iso:15118:2:2010:MsgDataTypes}isolationLevelType */
-	{6, 165},
-	/* qnameID == 415: {urn:iso:15118:2:2010:MsgDataTypes}meterIDType */
-	{6, 166},
-	/* qnameID == 416: {urn:iso:15118:2:2010:MsgDataTypes}meterStatusType */
-	{6, 167},
-	/* qnameID == 417: {urn:iso:15118:2:2010:MsgDataTypes}paymentOptionType */
-	{6, 168},
-	/* qnameID == 418: {urn:iso:15118:2:2010:MsgDataTypes}percentValueType */
-	{6, 169},
-	/* qnameID == 419: {urn:iso:15118:2:2010:MsgDataTypes}physicalValue */
-	{6, 170},
-	/* qnameID == 420: {urn:iso:15118:2:2010:MsgDataTypes}privateKeyType */
-	{6, 171},
-	/* qnameID == 421: {urn:iso:15118:2:2010:MsgDataTypes}responseCodeType */
-	{6, 172},
-	/* qnameID == 422: {urn:iso:15118:2:2010:MsgDataTypes}rootCertificateIDType */
-	{6, 173},
-	/* qnameID == 423: {urn:iso:15118:2:2010:MsgDataTypes}serviceCategoryType */
-	{6, 174},
-	/* qnameID == 424: {urn:iso:15118:2:2010:MsgDataTypes}serviceIDType */
-	{6, 175},
-	/* qnameID == 425: {urn:iso:15118:2:2010:MsgDataTypes}serviceNameType */
-	{6, 176},
-	/* qnameID == 426: {urn:iso:15118:2:2010:MsgDataTypes}serviceScopeType */
-	{6, 177},
-	/* qnameID == 427: {urn:iso:15118:2:2010:MsgDataTypes}sessionIDType */
-	{6, 178},
-	/* qnameID == 428: {urn:iso:15118:2:2010:MsgDataTypes}shortValue */
-	{6, 179},
-	/* qnameID == 429: {urn:iso:15118:2:2010:MsgDataTypes}sigMeterReadingType */
-	{6, 180},
-	/* qnameID == 430: {urn:iso:15118:2:2010:MsgDataTypes}start */
-	{6, 181},
-	/* qnameID == 431: {urn:iso:15118:2:2010:MsgDataTypes}startValue */
-	{6, 182},
-	/* qnameID == 432: {urn:iso:15118:2:2010:MsgDataTypes}stringValue */
-	{6, 183},
-	/* qnameID == 433: {urn:iso:15118:2:2010:MsgDataTypes}tariffDescriptionType */
-	{6, 184},
-	/* qnameID == 434: {urn:iso:15118:2:2010:MsgDataTypes}unitMultiplierType */
-	{6, 185},
-	/* qnameID == 435: {urn:iso:15118:2:2010:MsgDataTypes}unitSymbolType */
-	{6, 186},
-	/* qnameID == 436: {urn:iso:15118:2:2010:MsgDataTypes}valueType */
-	{6, 187},
-	/* qnameID == 437: {urn:iso:15118:2:2010:MsgDef}Body */
-	{7, 0},
-	/* qnameID == 438: {urn:iso:15118:2:2010:MsgDef}BodyBaseType */
-	{7, 1},
-	/* qnameID == 439: {urn:iso:15118:2:2010:MsgDef}BodyElement */
-	{7, 2},
-	/* qnameID == 440: {urn:iso:15118:2:2010:MsgDef}BodyType */
-	{7, 3},
-	/* qnameID == 441: {urn:iso:15118:2:2010:MsgDef}Header */
-	{7, 4},
-	/* qnameID == 442: {urn:iso:15118:2:2010:MsgDef}V2G_Message */
-	{7, 5},
-	/* qnameID == 443: {urn:iso:15118:2:2010:MsgHeader}MessageHeaderType */
-	{8, 0},
-	/* qnameID == 444: {urn:iso:15118:2:2010:MsgHeader}Notification */
-	{8, 1},
-	/* qnameID == 445: {urn:iso:15118:2:2010:MsgHeader}SessionID */
-	{8, 2}
-
-};
-
-
-int exiGetEQName(exi_state_t* state, uint16_t qnameID, uint16_t* namespaceURI, uint16_t* localPart) {
-	int errn = 0;
-	/* EXI_NUMBER_OF_QNAMES */
-	if (qnameID < state->nextQNameID) {
-		*namespaceURI = qnames[qnameID].namespaceURI;
-		*localPart = qnames[qnameID].localPart;
-	} else {
-		errn = EXI_ERROR_OUT_OF_BOUNDS;
-	}
-	return errn;
-}
-
-
-int exiGetQNameID(exi_state_t* state, uint16_t namespaceURI, uint16_t localPart, uint16_t* qnameID) {
-	uint16_t i;
-	/* TODO Do something more efficient than just walk over the entire list */
-	/* EXI_NUMBER_OF_QNAMES */
-	for(i=0; i<state->nextQNameID; i++) {
-		if(qnames[i].localPart == localPart && qnames[i].namespaceURI == namespaceURI) {
-			*qnameID = i;
-			return 0;
-		}
-	}
-
-	return EXI_ERROR_OUT_OF_BOUNDS;
-}
-
-
-int exiAddEQName(exi_state_t* state, uint16_t* qnameID, uint16_t namespaceURI, uint16_t localPart) {
-	int errn = 0;
-	if(state->nextQNameID < (EXI_MAX_NUMBER_OF_QNAMES -1)) {
-		/* store IDs */
-		qnames[state->nextQNameID].namespaceURI = namespaceURI;
-		qnames[state->nextQNameID].localPart = localPart;
-		/* increment counter */
-		*qnameID = state->nextQNameID++;
-	} else {
-		errn = EXI_ERROR_OUT_OF_BOUNDS;
-	}
-
-
-	return errn;
-}
-
-
-#endif
-

+ 0 - 74
src/codec/QNames.h

@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI__QNAMES_H
-#define EXI__QNAMES_H
-
-#include "EXITypes.h"
-
-/**
- * \brief  	Returns efficient qname (namespaceURI & localName) IDs for qnameID
- *
- * \param       state		   	Codec state
- * \param       qnameID		   	Qualified name ID
- * \param       namespaceURI	QName namespace URI ID
- * \param       localPart		QName local name ID
- * \return                  	Error-Code <> 0
- *
- */
-int exiGetEQName(exi_state_t* state, uint16_t qnameID, uint16_t* namespaceURI, uint16_t* localPart);
-
-
-/**
- * \brief  	Returns qnameID for qname namespaceURI & localName
- *
- * \param       state		   	Codec state
- * \param       namespaceURI	QName namespace URI ID
- * \param       localPart		QName local name ID
- * \param       qnameID		   	QName ID (out)
- * \return                  	Error-Code <> 0
- *
- */
-int exiGetQNameID(exi_state_t* state, uint16_t namespaceURI, uint16_t localPart, uint16_t* qnameID);
-
-
-/**
- * \brief  	Add  efficient qname (namespaceURI & localName) IDs for qnameID
- *
- * \param       state		   	Codec state
- * \param       qnameID		   	Qualified name ID
- * \param       namespaceURI	QName namespace URI ID
- * \param       localPart		QName local name ID
- * \return                  	Error-Code <> 0
- *
- */
-int exiAddEQName(exi_state_t* state, uint16_t* qnameID, uint16_t namespaceURI, uint16_t localPart);
-
-#endif
-

+ 0 - 144
src/codec/StringTable.c

@@ -1,144 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef STRING_TABLE_C
-#define STRING_TABLE_C
-
-#include <string.h>
-
-#include "StringTable.h"
-#include "NameTableEntries.h"
-#include "ErrorCodes.h"
-
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'runtimeTable' */
-#endif /* __GNUC__ */
-int exiGetUriSize(exi_name_table_prepopulated_t* prepopulatedTable, exi_name_table_runtime_t* runtimeTable, uint16_t* uriLength) {
-	*uriLength = prepopulatedTable->len;
-	return 0;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'runtimeTable' */
-#endif /* __GNUC__ */
-
-
-int exiGetLocalNameSize(exi_name_table_prepopulated_t* prepopulatedTable, exi_name_table_runtime_t* runtimeTable,
-		uint16_t uriID, uint16_t* localNameLength) {
-	*localNameLength = 0;
-	/* 1. pre-populated entries*/
-	if (uriID < prepopulatedTable->len) {
-		(*localNameLength) += prepopulatedTable->localNames[uriID];
-	} else {
-		/* range check */
-		if (uriID >= ( prepopulatedTable->len + runtimeTable->addedUriEntries )) {
-			return EXI_ERROR_OUT_OF_BOUNDS;
-		}
-	}
-	/* 2. runtime entries */
-	if (runtimeTable->addedLocalNameEntries > 0 ) {
-		int i;
-		for(i=0; i<(runtimeTable->addedUriEntries+runtimeTable->addedLocalNameEntries); i++) {
-			if ( runtimeTable->namePartitionsEntries[i].namePartitionType == EXI_NAME_PARTITION_LOCALNAME &&
-					runtimeTable->namePartitionsEntries[i].entry.localNamePartition.uriID == uriID ) {
-				(*localNameLength)++;
-			}
-		}
-	}
-
-	return 0;
-}
-
-
-/* inline */
-/*
-static int _max(int a, int b) {
-	return (a > b) ? a : b;
-}
-*/
-
-int exiInitNameTableRuntime(exi_name_table_runtime_t* runtimeTable) {
-	/*runtimeTable->numberOfUsedCharacters = 0;*/
-	runtimeTable->addedLocalNameEntries = 0;
-	runtimeTable->addedUriEntries = 0;
-	return 0;
-}
-
-int exiAddUri(exi_name_table_prepopulated_t* prepopulatedTable, exi_name_table_runtime_t* runtimeTable) {
-/*		, char* uri) { */
-	/*if (runtimeTable->addedUriEntries < EXI_RESERVED_NUMBER_URI_PARTITION_ENTRIES
-			|| runtimeTable->addedUriEntries
-					< (EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_ENTRIES - _max(
-							runtimeTable->addedLocalNameEntries,
-							EXI_RESERVED_NUMBER_LOCALNAME_PARTITION_ENTRIES))) {*/
-
-		uint16_t index = runtimeTable->addedUriEntries + runtimeTable->addedLocalNameEntries;
-		/*int charsIndex = runtimeTable->numberOfUsedCharacters+runtimeTable->addedUriEntries+runtimeTable->addedLocalNameEntries;*/
-		runtimeTable->namePartitionsEntries[index].namePartitionType = EXI_NAME_PARTITION_URI;
-		/* strcpy(runtimeTable->characters+charsIndex, uri); */
-		/*runtimeTable->namePartitionsEntries[index].entry.uriPartition.uri = runtimeTable->characters+charsIndex;*/
-		runtimeTable->namePartitionsEntries[index].entry.uriPartition.uriID = prepopulatedTable->len + runtimeTable->addedUriEntries;
-		runtimeTable->addedUriEntries++;
-		/* runtimeTable->numberOfUsedCharacters += strlen(uri); */
-		return 0;
-	/*} else {
-		return -1;
-	}*/
-}
-
-int exiAddLocalName(exi_name_table_prepopulated_t* prepopulatedTable, exi_name_table_runtime_t* runtimeTable, uint16_t uriID, uint16_t* localNameID) {
-		/* ,char* localName) { */
-	/*if (runtimeTable->addedUriEntries < EXI_RESERVED_NUMBER_LOCALNAME_PARTITION_ENTRIES
-			|| runtimeTable->addedLocalNameEntries
-					< (EXI_MAXIMUM_NUMBER_OF_NAME_PARTITION_ENTRIES - _max(
-							runtimeTable->addedUriEntries,
-							EXI_RESERVED_NUMBER_URI_PARTITION_ENTRIES))) {*/
-		uint16_t index = runtimeTable->addedUriEntries + runtimeTable->addedLocalNameEntries;
-		/*int charsIndex = runtimeTable->numberOfUsedCharacters+runtimeTable->addedUriEntries+runtimeTable->addedLocalNameEntries;*/
-		/*uint16_t localNameID;*/
-		int errn = exiGetLocalNameSize(prepopulatedTable, runtimeTable, uriID, localNameID);
-		if (errn < 0) {
-			return errn;
-		}
-
-		runtimeTable->namePartitionsEntries[index].namePartitionType = EXI_NAME_PARTITION_LOCALNAME;
-		/*strcpy(runtimeTable->characters+charsIndex, localName);*/
-		/*runtimeTable->namePartitionsEntries[index].entry.localNamePartition.localName = runtimeTable->characters+charsIndex;*/
-		runtimeTable->namePartitionsEntries[index].entry.localNamePartition.localNameID = *localNameID;
-		runtimeTable->namePartitionsEntries[index].entry.localNamePartition.uriID = uriID;
-		runtimeTable->addedLocalNameEntries++;
-		/*runtimeTable->numberOfUsedCharacters += strlen(localName);*/
-		return errn;
-	/*} else {
-		return -1;
-	}*/
-}
-
-#endif
-

+ 0 - 116
src/codec/StringTable.h

@@ -1,116 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * \file 	StringTable.h
- * \brief 	String table count implementation
- *
- */
-
-#ifndef STRING_TABLE_H
-#define STRING_TABLE_H
-
-#include "EXITypes.h"
-
-
-/**
- * \brief  		Init name table
- *
- * 				Inits counter et cetera
- *
- * \param       runtimeTable	Runtime Table
- * \return                  	Error-Code <> 0
- *
- */
-int exiInitNameTableRuntime(exi_name_table_runtime_t* runtimeTable);
-
-
-/**
- * \brief  		Get Uri Size
- *
- * \param       prepopulatedTable	Pre-Populated Table
- * \param       runtimeTable		Runtime Table
- * \param       uriLength			Uri Size (out)
- * \return                  		Error-Code <> 0
- *
- */
-int exiGetUriSize(exi_name_table_prepopulated_t* prepopulatedTable,
-		exi_name_table_runtime_t* runtimeTable, uint16_t* uriLength);
-
-
-/**
- * \brief  		Get LocalName Size
- *
- * \param       prepopulatedTable	Pre-Populated Table
- * \param       runtimeTable		Runtime Table
- * \param       uriID				Uri ID for local-name
- * \param       localNameLength		Local-Name Size (out)
- * \return                  		Error-Code <> 0
- *
- */
-int exiGetLocalNameSize(exi_name_table_prepopulated_t* prepopulatedTable,
-		exi_name_table_runtime_t* runtimeTable, uint16_t uriID,
-		uint16_t* localNameLength);
-
-
-/**
- * \brief  		Add runtime URI entry
- *
- * \param       prepopulatedTable	Pre-Populated Table
- * \param       runtimeTable		Runtime Table
- * \return                  		Error-Code <> 0
- *
- */
-int exiAddUri(exi_name_table_prepopulated_t* prepopulatedTable,
-		exi_name_table_runtime_t* runtimeTable);
-
-
-/**
- * \brief  		Add runtime local-name entry
- *
- * \param       prepopulatedTable	Pre-Populated Table
- * \param       runtimeTable		Runtime Table
- * \param       uriID				Uri ID for local-name
- * \param       localNameID			LocalName ID (out)
- * \return                  		Error-Code <> 0
- *
- */
-int exiAddLocalName(exi_name_table_prepopulated_t* prepopulatedTable,
-		exi_name_table_runtime_t* runtimeTable, uint16_t uriID, uint16_t* localNameID);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 67
src/codec/UCSString.c

@@ -1,67 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#include <string.h>
-
-#include "DecoderChannel.h"
-#include "BitInputStream.h"
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-
-#ifndef UCS_STRING_C
-#define UCS_STRING_C
-
-int toUCSString(char* chars, exi_string_ucs_t* s) {
-	unsigned int i;
-	s->len = (uint16_t)strlen(chars);
-
-	if (s->len <= s->size) {
-		for(i=0; i<s->len; i++) {
-			s->codepoints[i] = chars[i];
-		}
-		return 0;
-	} else {
-		return EXI_ERROR_OUT_OF_STRING_BUFFER;
-	}
-}
-
-/* Note A: fails if string contains non ASCII characters */
-/* Note B: causes harm if char array is not sufficiently long */
-int toASCIIString(exi_string_ucs_t* string, char* outASCII) {
-	unsigned int i;
-	for(i=0; i<string->len; i++) {
-		outASCII[i] = (char)string->codepoints[i];
-	}
-	outASCII[string->len] = '\0';
-
-	return 0;
-}
-
-#endif
-

+ 0 - 74
src/codec/UCSString.h

@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include "EXITypes.h"
-
-/**
- * \file 	UCSString.h
- * \brief 	UCS String utilities
- *
- */
-
-#ifndef UCS_STRING_H
-#define UCS_STRING_H
-
-/**
- * \brief 		Converts characters to USC string
- *
- * \param       chars	   		Characters
- * \param       s				UCS String
- * \return                  	Error-Code <> 0
- *
- */
-int toUCSString(char* chars, exi_string_ucs_t* s);
-
-
-/**
- * \brief 		Converts String to ASCII characters
- *
- * 				Note: fails if string contains non ASCII characters.
- *
- * \param       string			UCS String
- * \param       string	   		Input String
- * \param       outASCII	   	ASCII Characters (out)
- * \return                  	Error-Code <> 0
- *
- */
-int toASCIIString(exi_string_ucs_t* string, char* outASCII);
-
-#endif
-
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 862
src/codec/appHandCodec/appHandEXICoder.c

@@ -1,862 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_CODER_C
-#define EXI_appHand_CODER_C
-
-#include "appHandEXICoder.h"
-
-#include "EXITypes.h"
-#include "EXIOptions.h"
-#include "BitInputStream.h"
-#include "DecoderChannel.h"
-#include "ErrorCodes.h"
-
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'qnameID' */
-#endif /* __GNUC__ */
-int exi_appHand_IncrementStringValueCount(exi_state_t* state, uint16_t qnameID) {
-	int errn = 0;
-#if EXI_appHandVALUE_PARTITION_CAPACITY != 0
-#if EXI_appHandVALUE_MAX_LENGTH != 0
-	/* increment global string count */
-#if EXI_appHandVALUE_PARTITION_CAPACITY < 0
-	state->stringTable.numberOfGlobalStrings++;
-#else /* EXI_appHandVALUE_PARTITION_CAPACITY < 0 */
-	if (state->stringTable.numberOfGlobalStrings < EXI_appHandVALUE_PARTITION_CAPACITY) {
-		state->stringTable.numberOfGlobalStrings++;
-	}
-#endif /* EXI_appHandVALUE_PARTITION_CAPACITY < 0 */
-	/* increment local string count */
-	if (qnameID < state->stringTable.sizeLocalStrings) {
-		state->stringTable.numberOfLocalStrings[qnameID]++;
-		/* printf("\tSV %d:  lv=%d  and gv=%d \n", qnameID, state->numberOfLocalStrings[qnameID], state->numberOfGlobalStrings);*/
-	} else {
-		/* currently we do support a set of qnames only */
-		errn = EXI_ERROR_OUT_OF_QNAMES;
-	}
-#endif /* EXI_appHandVALUE_MAX_LENGTH != 0 */
-#endif /* EXI_appHandVALUE_PARTITION_CAPACITY != 0 */
-
-	return errn;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'qnameID' */
-#endif /* __GNUC__ */
-
-
-int exi_appHand_PushStack(exi_state_t* state, int16_t newState, uint16_t qnameID) {
-	/* eqname_t* eqn*/
-	if ((state->stackIndex + 1) < EXI_ELEMENT_STACK_SIZE) {
-		state->grammarStack[++state->stackIndex] = newState;
-		/* qname */
-		state->elementStack[state->stackIndex] = qnameID;
-
-		/*if (eqn == NULL) {
-			// generic SE, UCD profile
-		} else {
-			// copy IDs
-			state->elementStack[state->stackIndex].localPart = eqn->localPart;
-			state->elementStack[state->stackIndex].namespaceURI = eqn->namespaceURI;
-		}*/
-		return 0;
-	} else {
-		return EXI_ERROR_OUT_OF_GRAMMAR_STACK;
-	}
-}
-
-int exi_appHand_PopStack(exi_state_t* state) {
-	if (state->stackIndex >= 1) {
-		state->stackIndex--;
-		return 0;
-	} else {
-		return EXI_ERROR_OUT_OF_BOUNDS;
-	}
-}
-
-int exi_appHand_HandleXsiNilTrue(exi_state_t* state) {
-	switch (state->grammarStack[state->stackIndex]) {
-
-	}
-
-	return EXI_ERROR_UNEXPECTED_ATTRIBUTE_XSI_NIL;
-}
-
-int exi_appHand_HandleXsiType(exi_state_t* state, exi_eqname_t* xsiType) {
-	switch(xsiType->namespaceURI) {
-	case 0:
-		switch(xsiType->localPart) {
-		}
-		break;
-	case 1:
-		switch(xsiType->localPart) {
-		}
-		break;
-	case 2:
-		switch(xsiType->localPart) {
-		}
-		break;
-	case 3:
-		switch(xsiType->localPart) {
-		case 0:
-			/* {3}0,ENTITIES */
-			state->grammarStack[state->stackIndex] = 144;
-			break;
-		case 1:
-			/* {3}1,ENTITY */
-			state->grammarStack[state->stackIndex] = 10;
-			break;
-		case 2:
-			/* {3}2,ID */
-			state->grammarStack[state->stackIndex] = 141;
-			break;
-		case 3:
-			/* {3}3,IDREF */
-			state->grammarStack[state->stackIndex] = 79;
-			break;
-		case 4:
-			/* {3}4,IDREFS */
-			state->grammarStack[state->stackIndex] = 29;
-			break;
-		case 5:
-			/* {3}5,NCName */
-			state->grammarStack[state->stackIndex] = 98;
-			break;
-		case 6:
-			/* {3}6,NMTOKEN */
-			state->grammarStack[state->stackIndex] = 36;
-			break;
-		case 7:
-			/* {3}7,NMTOKENS */
-			state->grammarStack[state->stackIndex] = 25;
-			break;
-		case 8:
-			/* {3}8,NOTATION */
-			state->grammarStack[state->stackIndex] = 78;
-			break;
-		case 9:
-			/* {3}9,Name */
-			state->grammarStack[state->stackIndex] = 101;
-			break;
-		case 10:
-			/* {3}10,QName */
-			state->grammarStack[state->stackIndex] = 106;
-			break;
-		case 11:
-			/* {3}11,anySimpleType */
-			state->grammarStack[state->stackIndex] = 48;
-			break;
-		case 12:
-			/* {3}12,anyType */
-			state->grammarStack[state->stackIndex] = 50;
-			break;
-		case 13:
-			/* {3}13,anyURI */
-			state->grammarStack[state->stackIndex] = 142;
-			break;
-		case 14:
-			/* {3}14,base64Binary */
-			state->grammarStack[state->stackIndex] = 111;
-			break;
-		case 15:
-			/* {3}15,boolean */
-			state->grammarStack[state->stackIndex] = 80;
-			break;
-		case 16:
-			/* {3}16,byte */
-			state->grammarStack[state->stackIndex] = 134;
-			break;
-		case 17:
-			/* {3}17,date */
-			state->grammarStack[state->stackIndex] = 133;
-			break;
-		case 18:
-			/* {3}18,dateTime */
-			state->grammarStack[state->stackIndex] = 104;
-			break;
-		case 19:
-			/* {3}19,decimal */
-			state->grammarStack[state->stackIndex] = 53;
-			break;
-		case 20:
-			/* {3}20,double */
-			state->grammarStack[state->stackIndex] = 11;
-			break;
-		case 21:
-			/* {3}21,duration */
-			state->grammarStack[state->stackIndex] = 55;
-			break;
-		case 22:
-			/* {3}22,float */
-			state->grammarStack[state->stackIndex] = 130;
-			break;
-		case 23:
-			/* {3}23,gDay */
-			state->grammarStack[state->stackIndex] = 135;
-			break;
-		case 24:
-			/* {3}24,gMonth */
-			state->grammarStack[state->stackIndex] = 64;
-			break;
-		case 25:
-			/* {3}25,gMonthDay */
-			state->grammarStack[state->stackIndex] = 100;
-			break;
-		case 26:
-			/* {3}26,gYear */
-			state->grammarStack[state->stackIndex] = 99;
-			break;
-		case 27:
-			/* {3}27,gYearMonth */
-			state->grammarStack[state->stackIndex] = 74;
-			break;
-		case 28:
-			/* {3}28,hexBinary */
-			state->grammarStack[state->stackIndex] = 132;
-			break;
-		case 29:
-			/* {3}29,int */
-			state->grammarStack[state->stackIndex] = 76;
-			break;
-		case 30:
-			/* {3}30,integer */
-			state->grammarStack[state->stackIndex] = 138;
-			break;
-		case 31:
-			/* {3}31,language */
-			state->grammarStack[state->stackIndex] = 20;
-			break;
-		case 32:
-			/* {3}32,long */
-			state->grammarStack[state->stackIndex] = 93;
-			break;
-		case 33:
-			/* {3}33,negativeInteger */
-			state->grammarStack[state->stackIndex] = 89;
-			break;
-		case 34:
-			/* {3}34,nonNegativeInteger */
-			state->grammarStack[state->stackIndex] = 57;
-			break;
-		case 35:
-			/* {3}35,nonPositiveInteger */
-			state->grammarStack[state->stackIndex] = 69;
-			break;
-		case 36:
-			/* {3}36,normalizedString */
-			state->grammarStack[state->stackIndex] = 86;
-			break;
-		case 37:
-			/* {3}37,positiveInteger */
-			state->grammarStack[state->stackIndex] = 49;
-			break;
-		case 38:
-			/* {3}38,short */
-			state->grammarStack[state->stackIndex] = 68;
-			break;
-		case 39:
-			/* {3}39,string */
-			state->grammarStack[state->stackIndex] = 24;
-			break;
-		case 40:
-			/* {3}40,time */
-			state->grammarStack[state->stackIndex] = 112;
-			break;
-		case 41:
-			/* {3}41,token */
-			state->grammarStack[state->stackIndex] = 143;
-			break;
-		case 42:
-			/* {3}42,unsignedByte */
-			state->grammarStack[state->stackIndex] = 122;
-			break;
-		case 43:
-			/* {3}43,unsignedInt */
-			state->grammarStack[state->stackIndex] = 102;
-			break;
-		case 44:
-			/* {3}44,unsignedLong */
-			state->grammarStack[state->stackIndex] = 21;
-			break;
-		case 45:
-			/* {3}45,unsignedShort */
-			state->grammarStack[state->stackIndex] = 7;
-			break;
-		}
-		break;
-	case 4:
-		switch(xsiType->localPart) {
-		case 0:
-			/* {4}0,AppProtocolType */
-			state->grammarStack[state->stackIndex] = 5;
-			break;
-		case 1:
-			/* {4}1,idType */
-			state->grammarStack[state->stackIndex] = 45;
-			break;
-		case 2:
-			/* {4}2,priorityType */
-			state->grammarStack[state->stackIndex] = 43;
-			break;
-		case 3:
-			/* {4}3,protocolNameType */
-			state->grammarStack[state->stackIndex] = 58;
-			break;
-		case 4:
-			/* {4}4,protocolNamespaceType */
-			state->grammarStack[state->stackIndex] = 18;
-			break;
-		case 5:
-			/* {4}5,responseCodeType */
-			state->grammarStack[state->stackIndex] = 44;
-			break;
-		}
-		break;
-	}
-
-
-	return 0;
-}
-
-
-int exi_appHand_RetrieveAndPushGlobalGrammar(exi_state_t* state, uint16_t qnameID) {
-	int errn = EXI_ERROR_OUT_OF_RUNTIME_GRAMMAR_STACK;
-	int16_t i;
-
-	/* schema-informed global element --> Stack ID */
-	switch(qnameID) {
-	case 65:
-		return exi_appHand_PushStack(state, 15, 65);
-	case 66:
-		return exi_appHand_PushStack(state, 16, 66);
-
-	}
-
-
-	/* retrieve existing grammar for qname if any available */
-	for(i=0; i<state->numberOfRuntimeGrammars; i+=2) {
-		if( state->runtimeGrammars[i].qnameID == qnameID ) {
-			/* runtime grammar exists already */
-
-			/* push element stack */
-			errn = exi_appHand_PushStack(state, ((i+1) * (-1)), qnameID);
-			return errn;
-		}
-	}
-
-	/* create new runtime grammars if possible */
-	if((state->numberOfRuntimeGrammars + 2) < (MAX_NUMBER_OF_RUNTIME_ELEMENTS * 2) ) {
-		/* StartTagContent StackIds: -1, -3, -5, ... */
-		state->runtimeGrammars[state->numberOfRuntimeGrammars].qnameID = qnameID;
-		state->runtimeGrammars[state->numberOfRuntimeGrammars].numberOfProductions = 0;
-		state->runtimeGrammars[state->numberOfRuntimeGrammars].hasXsiType = 0;
-		state->runtimeGrammars[state->numberOfRuntimeGrammars].hasEE = 0;
-		/* ElementContent StackIds: -2, -4, -6, ... */
-		state->runtimeGrammars[state->numberOfRuntimeGrammars+1].qnameID = qnameID;
-		state->runtimeGrammars[state->numberOfRuntimeGrammars+1].numberOfProductions = 1;
-		state->runtimeGrammars[state->numberOfRuntimeGrammars+1].hasXsiType = 0;
-		state->runtimeGrammars[state->numberOfRuntimeGrammars+1].hasEE = 1;
-
-		/* push element stack */
-		errn = exi_appHand_PushStack(state, ((state->numberOfRuntimeGrammars+1) * (-1)), qnameID);
-
-		state->numberOfRuntimeGrammars+=2;
-	}
-
-	return errn;
-}
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'qnameID' */
-#endif /* __GNUC__ */
-int exi_appHand_LearnAttribute(exi_state_t* state, uint16_t qnameID, uint16_t uriID, uint16_t localID) {
-	int errn = 0;
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	int16_t runtimeID;
-
-	if (currentID < 0) {
-		runtimeID = (currentID+1)*(-1);
-
-		if (uriID == 2 && localID == 1 ) {
-			/* xsi:type: learned just once */
-			if(!state->runtimeGrammars[runtimeID].hasXsiType) {
-				/* hasXsiType stores production position PLUS 1 (one) */
-				state->runtimeGrammars[runtimeID].hasXsiType = ++state->runtimeGrammars[runtimeID].numberOfProductions;
-			}
-		} else {
-			/* increment production count */
-			++state->runtimeGrammars[runtimeID].numberOfProductions;
-			/* TODO store production information. Note: not necessary in restricted profile */
-		}
-	} else {
-		/* schema-informed grammar do no evolve */
-	}
-
-	return errn;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'qnameID' */
-#endif /* __GNUC__ */
-
-/*
- * RUNTIME RULES
- * each rule has 2 ids and counts backwards from -1, -2, ...
- * 1) StartTagContent (e.g., -1, -3, -5, ...)
- * 2) ElementContent (e.g., -2, -4, -6)
- *
- */
-
-int exi_appHand_IsStartContent(int16_t ruleID) {
-	return (ruleID % 2 != 0);
-}
-
-int exi_appHand_MoveToElementContentRule(exi_state_t* state) {
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	switch (currentID) {
-	case 100:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 139;
-		return 0;
-	case 143:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 40;
-		return 0;
-	case 86:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 38;
-		return 0;
-	case 134:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 56;
-		return 0;
-	case 24:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 118;
-		return 0;
-	case 132:
-		/* FirstStartTag[CHARACTERS[BINARY_HEX]] --> Element[CHARACTERS[BINARY_HEX]] */
-		state->grammarStack[state->stackIndex] = 28;
-		return 0;
-	case 98:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 131;
-		return 0;
-	case 133:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 121;
-		return 0;
-	case 89:
-		/* FirstStartTag[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-		state->grammarStack[state->stackIndex] = 107;
-		return 0;
-	case 78:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 137;
-		return 0;
-	case 101:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 70;
-		return 0;
-	case 50:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] --> Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		state->grammarStack[state->stackIndex] = 51;
-		return 0;
-	case 142:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 12;
-		return 0;
-	case 5:
-		/* FirstStartTag[START_ELEMENT(ProtocolNamespace)] --> Element[START_ELEMENT(ProtocolNamespace)] */
-		state->grammarStack[state->stackIndex] = 30;
-		return 0;
-	case 104:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 88;
-		return 0;
-	case 7:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 119;
-		return 0;
-	case 16:
-		/* FirstStartTag[START_ELEMENT(ResponseCode)] --> Element[START_ELEMENT(ResponseCode)] */
-		state->grammarStack[state->stackIndex] = 117;
-		return 0;
-	case 53:
-		/* FirstStartTag[CHARACTERS[DECIMAL]] --> Element[CHARACTERS[DECIMAL]] */
-		state->grammarStack[state->stackIndex] = 116;
-		return 0;
-	case 106:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 67;
-		return 0;
-	case 44:
-		/* FirstStartTag[CHARACTERS[ENUMERATION]] --> Element[CHARACTERS[ENUMERATION]] */
-		state->grammarStack[state->stackIndex] = 71;
-		return 0;
-	case 93:
-		/* FirstStartTag[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-		state->grammarStack[state->stackIndex] = 47;
-		return 0;
-	case 135:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 63;
-		return 0;
-	case 64:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 82;
-		return 0;
-	case 29:
-		/* FirstStartTag[CHARACTERS[LIST]] --> Element[CHARACTERS[LIST]] */
-		state->grammarStack[state->stackIndex] = 140;
-		return 0;
-	case 1:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 3:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 8:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 12:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 13:
-		/* DocContent[START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC] --> DocContent[START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC] */
-	case 17:
-		/* Element[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-	case 19:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 2:
-		/* Element[END_ELEMENT] --> Element[END_ELEMENT] */
-	case 26:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 0:
-		/* Document[START_DOCUMENT] --> Document[START_DOCUMENT] */
-	case 28:
-		/* Element[CHARACTERS[BINARY_HEX]] --> Element[CHARACTERS[BINARY_HEX]] */
-	case 30:
-		/* Element[START_ELEMENT(ProtocolNamespace)] --> Element[START_ELEMENT(ProtocolNamespace)] */
-	case 32:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 33:
-		/* Element[START_ELEMENT(VersionNumberMinor)] --> Element[START_ELEMENT(VersionNumberMinor)] */
-	case 37:
-		/* Element[CHARACTERS[BOOLEAN]] --> Element[CHARACTERS[BOOLEAN]] */
-	case 39:
-		/* Element[END_ELEMENT] --> Element[END_ELEMENT] */
-	case 38:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 40:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 41:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 42:
-		/* FragmentContent[START_ELEMENT(AppProtocol), START_ELEMENT(Priority), START_ELEMENT(ProtocolNamespace), START_ELEMENT(ResponseCode), START_ELEMENT(SchemaID), START_ELEMENT(VersionNumberMajor), START_ELEMENT(VersionNumberMinor), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC, END_DOCUMENT] --> FragmentContent[START_ELEMENT(AppProtocol), START_ELEMENT(Priority), START_ELEMENT(ProtocolNamespace), START_ELEMENT(ResponseCode), START_ELEMENT(SchemaID), START_ELEMENT(VersionNumberMajor), START_ELEMENT(VersionNumberMinor), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC, END_DOCUMENT] */
-	case 47:
-		/* Element[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-	case 52:
-		/* Element[CHARACTERS[BINARY_BASE64]] --> Element[CHARACTERS[BINARY_BASE64]] */
-	case 54:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 56:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 59:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 60:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 31:
-		/* Element[START_ELEMENT(VersionNumberMajor)] --> Element[START_ELEMENT(VersionNumberMajor)] */
-	case 62:
-		/* Element[CHARACTERS[FLOAT]] --> Element[CHARACTERS[FLOAT]] */
-	case 63:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 65:
-		/* Element[CHARACTERS[LIST]] --> Element[CHARACTERS[LIST]] */
-	case 67:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 70:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 71:
-		/* Element[CHARACTERS[ENUMERATION]] --> Element[CHARACTERS[ENUMERATION]] */
-	case 72:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 75:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 23:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] --> Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 77:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 81:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 82:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 83:
-		/* Element[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-	case 84:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 85:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 87:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 88:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 34:
-		/* Element[START_ELEMENT(SchemaID)] --> Element[START_ELEMENT(SchemaID)] */
-	case 9:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 91:
-		/* Element[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-	case 94:
-		/* Element[START_ELEMENT(AppProtocol)] --> Element[START_ELEMENT(AppProtocol)] */
-	case 95:
-		/* Element[CHARACTERS[LIST]] --> Element[CHARACTERS[LIST]] */
-	case 96:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 97:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 6:
-		/* Element[] --> Element[] */
-	case 103:
-		/* Element[CHARACTERS[FLOAT]] --> Element[CHARACTERS[FLOAT]] */
-	case 105:
-		/* Fragment[START_DOCUMENT] --> Fragment[START_DOCUMENT] */
-	case 107:
-		/* Element[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-	case 109:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 108:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 92:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 114:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 115:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 116:
-		/* Element[CHARACTERS[DECIMAL]] --> Element[CHARACTERS[DECIMAL]] */
-	case 117:
-		/* Element[START_ELEMENT(ResponseCode)] --> Element[START_ELEMENT(ResponseCode)] */
-	case 118:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 119:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 120:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 121:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 124:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 123:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 27:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 126:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 90:
-		/* Element[START_ELEMENT(Priority)] --> Element[START_ELEMENT(Priority)] */
-	case 51:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] --> Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 128:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 66:
-		/* Element[START_ELEMENT(SchemaID), END_ELEMENT] --> Element[START_ELEMENT(SchemaID), END_ELEMENT] */
-	case 131:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 110:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 61:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 127:
-		/* Element[END_ELEMENT] --> Element[END_ELEMENT] */
-	case 14:
-		/* DocEnd[END_DOCUMENT] --> DocEnd[END_DOCUMENT] */
-	case 136:
-		/* Element[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-	case 113:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 4:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 137:
-		/* Element[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-	case 125:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 140:
-		/* Element[CHARACTERS[LIST]] --> Element[CHARACTERS[LIST]] */
-	case 139:
-		/* Element[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-	case 145:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 129:
-		/* Element[END_ELEMENT] --> Element[END_ELEMENT] */
-	case 73:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] --> Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-		return 0;
-	case 68:
-		/* FirstStartTag[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-		state->grammarStack[state->stackIndex] = 136;
-		return 0;
-	case 79:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 54;
-		return 0;
-	case 43:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 19;
-		return 0;
-	case 49:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 59;
-		return 0;
-	case 111:
-		/* FirstStartTag[CHARACTERS[BINARY_BASE64]] --> Element[CHARACTERS[BINARY_BASE64]] */
-		state->grammarStack[state->stackIndex] = 52;
-		return 0;
-	case 11:
-		/* FirstStartTag[CHARACTERS[FLOAT]] --> Element[CHARACTERS[FLOAT]] */
-		state->grammarStack[state->stackIndex] = 62;
-		return 0;
-	case 21:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 108;
-		return 0;
-	case 25:
-		/* FirstStartTag[CHARACTERS[LIST]] --> Element[CHARACTERS[LIST]] */
-		state->grammarStack[state->stackIndex] = 95;
-		return 0;
-	case 112:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 126;
-		return 0;
-	case 57:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 145;
-		return 0;
-	case 22:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] --> Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		state->grammarStack[state->stackIndex] = 23;
-		return 0;
-	case 45:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 75;
-		return 0;
-	case 15:
-		/* FirstStartTag[START_ELEMENT(AppProtocol)] --> Element[START_ELEMENT(AppProtocol)] */
-		state->grammarStack[state->stackIndex] = 94;
-		return 0;
-	case 76:
-		/* FirstStartTag[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-		state->grammarStack[state->stackIndex] = 83;
-		return 0;
-	case 138:
-		/* FirstStartTag[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-		state->grammarStack[state->stackIndex] = 91;
-		return 0;
-	case 122:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] --> Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 1;
-		return 0;
-	case 48:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 96;
-		return 0;
-	case 80:
-		/* FirstStartTag[CHARACTERS[BOOLEAN]] --> Element[CHARACTERS[BOOLEAN]] */
-		state->grammarStack[state->stackIndex] = 37;
-		return 0;
-	case 55:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 41;
-		return 0;
-	case 10:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 87;
-		return 0;
-	case 20:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 32;
-		return 0;
-	case 36:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 120;
-		return 0;
-	case 130:
-		/* FirstStartTag[CHARACTERS[FLOAT]] --> Element[CHARACTERS[FLOAT]] */
-		state->grammarStack[state->stackIndex] = 103;
-		return 0;
-	case 141:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 114;
-		return 0;
-	case 144:
-		/* FirstStartTag[CHARACTERS[LIST]] --> Element[CHARACTERS[LIST]] */
-		state->grammarStack[state->stackIndex] = 65;
-		return 0;
-	case 58:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 85;
-		return 0;
-	case 69:
-		/* FirstStartTag[CHARACTERS[INTEGER]] --> Element[CHARACTERS[INTEGER]] */
-		state->grammarStack[state->stackIndex] = 17;
-		return 0;
-	case 46:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 35:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 102:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] --> Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		state->grammarStack[state->stackIndex] = 81;
-		return 0;
-	case 74:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 123;
-		return 0;
-	case 99:
-		/* FirstStartTag[CHARACTERS[DATETIME]] --> Element[CHARACTERS[DATETIME]] */
-		state->grammarStack[state->stackIndex] = 84;
-		return 0;
-	case 18:
-		/* FirstStartTag[CHARACTERS[STRING]] --> Element[CHARACTERS[STRING]] */
-		state->grammarStack[state->stackIndex] = 77;
-		return 0;
-
-	}
-
-	if (currentID < 0) {
-		if( exi_appHand_IsStartContent(currentID) ) {
-			state->grammarStack[state->stackIndex] = currentID - 1;
-		}
-	} else {
-		return EXI_ERROR_UNEXPECTED_ATTRIBUTE_MOVE_TO_CONTENT_RULE;
-	}
-
-	return 0;
-}
-
-
-#endif
-

+ 0 - 70
src/codec/appHandCodec/appHandEXICoder.h

@@ -1,70 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI_appHand_CODER_H
-#define EXI_appHand_CODER_H
-
-#include "EXITypes.h"
-
-#define DOCUMENT 0
-#define DOC_CONTENT 13
-#define DOC_END 14
-#define UR_TYPE_GRAMMAR_0 22
-#define UR_TYPE_GRAMMAR_1 23
-
-
-/* increments global and local string count */
-int exi_appHand_IncrementStringValueCount(exi_state_t* state, uint16_t qnameID);
-
-int exi_appHand_PushStack(exi_state_t* state, int16_t newState, uint16_t qnameID);
-
-int exi_appHand_PopStack(exi_state_t* state);
-
-int exi_appHand_HandleXsiNilTrue(exi_state_t* state);
-
-int exi_appHand_HandleXsiType(exi_state_t* state, exi_eqname_t* xsiType);
-
-int exi_appHand_RetrieveAndPushGlobalGrammar(exi_state_t* state, uint16_t qnameID);
-
-int exi_appHand_LearnAttribute(exi_state_t* state, uint16_t qnameID, uint16_t uriID, uint16_t localID);
-
-int exi_appHand_IsStartContent(int16_t ruleID);
-
-int exi_appHand_MoveToElementContentRule(exi_state_t* state);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 2219
src/codec/appHandCodec/appHandEXIDecoder.c

@@ -1,2219 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_DECODER_C
-#define EXI_appHand_DECODER_C
-
-
-#include "appHandEXIDecoder.h"
-
-#include "EXITypes.h"
-#include "EXIOptions.h"
-#include "BitInputStream.h"
-#include "DecoderChannel.h"
-#include "CoderChannel.h"
-
-#include "StringTable.h"
-#include "appHandNameTableEntries.h"
-#include "MethodsBag.h"
-
-#include "appHandEXICoder.h"
-#include "EXIHeaderDecoder.h"
-#include "ErrorCodes.h"
-
-#include "appHandQNames.h"
-#include "appHandQNameDefines.h"
-
-
-
-/* local variables */
-static uint32_t xsi;
-static uint32_t bits;
-static int errn;
-static exi_event_t currEvent;
-
-#define URI_CODEPOINTS_SIZE 35
-#define LOCALNAME_CODEPOINTS_SIZE 25
-
-uint32_t codepointsUri[URI_CODEPOINTS_SIZE];
-uint32_t codepointsLocalName[LOCALNAME_CODEPOINTS_SIZE];
-
-/*static exi_string_ucs_t stringUri = {URI_CODEPOINTS_SIZE, codepointsUri, 0};*/
-/*static exi_name_entry_t uri = {EXI_NAME_ENTRY_TYPE_ID, 0, {URI_CODEPOINTS_SIZE, codepointsUri, 0}};*/
-/*static exi_name_entry_t localName = {EXI_NAME_ENTRY_TYPE_ID, 0, {LOCALNAME_CODEPOINTS_SIZE, codepointsLocalName, 0}};*/
-static exi_qname_t _qname = {
-		{EXI_NAME_ENTRY_TYPE_ID, 0, {URI_CODEPOINTS_SIZE, codepointsUri, 0}},
-		{EXI_NAME_ENTRY_TYPE_ID, 0, {LOCALNAME_CODEPOINTS_SIZE, codepointsLocalName, 0}}
-};
-
-
-static int _decodeNBitIntegerValue(bitstream_t* stream, exi_integer_t* iv, uint16_t nbits, int32_t lowerBound) {
-	int errn;
-	uint32_t val;
-
-	errn = decodeNBitUnsignedInteger(stream, nbits, &val);
-	if(errn) {
-		return errn;
-	}
-
-	/* TODO map integer value more fine-grained */
-	iv->type = EXI_INTEGER_32;
-	iv->val.int32 = val + lowerBound;
-
-	return errn;
-}
-
-
-
-static int exiDecodeNext2Event(bitstream_t* stream, exi_state_t* state,
-		exi_event_t* nextEvent) {
-	uint32_t eventCode2 = 0;
-	int16_t ruleID = state->grammarStack[state->stackIndex];
-
-	switch (ruleID) {
-	case 7:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 11:
-		/* FirstStartTag[CHARACTERS[FLOAT]] */
-	case 10:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 18:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 20:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 21:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 25:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-	case 24:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 29:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-	case 36:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 48:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 49:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 53:
-		/* FirstStartTag[CHARACTERS[DECIMAL]] */
-	case 55:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 57:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 58:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 45:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 64:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 16:
-		/* FirstStartTag[START_ELEMENT(ResponseCode)] */
-	case 68:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 46:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 69:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 74:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 15:
-		/* FirstStartTag[START_ELEMENT(AppProtocol)] */
-	case 76:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 78:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 79:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 80:
-		/* FirstStartTag[CHARACTERS[BOOLEAN]] */
-	case 35:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 44:
-		/* FirstStartTag[CHARACTERS[ENUMERATION]] */
-	case 86:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 89:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 93:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 98:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 99:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 101:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 100:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 102:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 104:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 106:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 111:
-		/* FirstStartTag[CHARACTERS[BINARY_BASE64]] */
-	case 43:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 112:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 122:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 130:
-		/* FirstStartTag[CHARACTERS[FLOAT]] */
-	case 132:
-		/* FirstStartTag[CHARACTERS[BINARY_HEX]] */
-	case 133:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 134:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 135:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 5:
-		/* FirstStartTag[START_ELEMENT(ProtocolNamespace)] */
-	case 138:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 141:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 142:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 143:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 144:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-		errn = decodeNBitUnsignedInteger(stream, 3, &eventCode2);
-		switch (eventCode2) {
-		case 0:
-			*nextEvent = EXI_EVENT_END_ELEMENT_UNDECLARED;
-			return errn;
-		case 1:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_XSI_TYPE;
-			return errn;
-		case 2:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_XSI_NIL;
-			return errn;
-		case 3:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED;
-			return errn;
-		case 4:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_INVALID_VALUE;
-			errn = decodeNBitUnsignedInteger(stream, 0, &state->eventCode);
-			state->eventCode -= 1;
-			return errn;
-		case 5:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED;
-			return errn;
-		case 6:
-			*nextEvent = EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED;
-			return errn;
-		}
-		break;
-	case 22:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 50:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		errn = decodeNBitUnsignedInteger(stream, 3, &eventCode2);
-		switch (eventCode2) {
-		case 0:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_XSI_TYPE;
-			return errn;
-		case 1:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_XSI_NIL;
-			return errn;
-		case 2:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED;
-			return errn;
-		case 3:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_INVALID_VALUE;
-			errn = decodeNBitUnsignedInteger(stream, 0, &state->eventCode);
-			state->eventCode -= 1;
-			return errn;
-		case 4:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED;
-			return errn;
-		case 5:
-			*nextEvent = EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED;
-			return errn;
-		}
-		break;
-	case 1:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 12:
-		/* Element[CHARACTERS[STRING]] */
-	case 17:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 19:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 28:
-		/* Element[CHARACTERS[BINARY_HEX]] */
-	case 30:
-		/* Element[START_ELEMENT(ProtocolNamespace)] */
-	case 32:
-		/* Element[CHARACTERS[STRING]] */
-	case 33:
-		/* Element[START_ELEMENT(VersionNumberMinor)] */
-	case 37:
-		/* Element[CHARACTERS[BOOLEAN]] */
-	case 38:
-		/* Element[CHARACTERS[STRING]] */
-	case 40:
-		/* Element[CHARACTERS[STRING]] */
-	case 41:
-		/* Element[CHARACTERS[STRING]] */
-	case 47:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 52:
-		/* Element[CHARACTERS[BINARY_BASE64]] */
-	case 54:
-		/* Element[CHARACTERS[STRING]] */
-	case 56:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 59:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 31:
-		/* Element[START_ELEMENT(VersionNumberMajor)] */
-	case 62:
-		/* Element[CHARACTERS[FLOAT]] */
-	case 63:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 65:
-		/* Element[CHARACTERS[LIST]] */
-	case 67:
-		/* Element[CHARACTERS[STRING]] */
-	case 70:
-		/* Element[CHARACTERS[STRING]] */
-	case 71:
-		/* Element[CHARACTERS[ENUMERATION]] */
-	case 75:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 77:
-		/* Element[CHARACTERS[STRING]] */
-	case 81:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 82:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 83:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 84:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 85:
-		/* Element[CHARACTERS[STRING]] */
-	case 87:
-		/* Element[CHARACTERS[STRING]] */
-	case 88:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 34:
-		/* Element[START_ELEMENT(SchemaID)] */
-	case 91:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 94:
-		/* Element[START_ELEMENT(AppProtocol)] */
-	case 95:
-		/* Element[CHARACTERS[LIST]] */
-	case 96:
-		/* Element[CHARACTERS[STRING]] */
-	case 103:
-		/* Element[CHARACTERS[FLOAT]] */
-	case 107:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 108:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 114:
-		/* Element[CHARACTERS[STRING]] */
-	case 116:
-		/* Element[CHARACTERS[DECIMAL]] */
-	case 117:
-		/* Element[START_ELEMENT(ResponseCode)] */
-	case 118:
-		/* Element[CHARACTERS[STRING]] */
-	case 119:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 120:
-		/* Element[CHARACTERS[STRING]] */
-	case 121:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 123:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 126:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 90:
-		/* Element[START_ELEMENT(Priority)] */
-	case 131:
-		/* Element[CHARACTERS[STRING]] */
-	case 136:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 137:
-		/* Element[CHARACTERS[STRING]] */
-	case 140:
-		/* Element[CHARACTERS[LIST]] */
-	case 139:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 145:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		errn = decodeNBitUnsignedInteger(stream, 2, &eventCode2);
-		switch (eventCode2) {
-		case 0:
-			*nextEvent = EXI_EVENT_END_ELEMENT_UNDECLARED;
-			return errn;
-		case 1:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED;
-			return errn;
-		case 2:
-			*nextEvent = EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED;
-			return errn;
-		}
-		break;
-	case 3:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 8:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 2:
-		/* Element[END_ELEMENT] */
-	case 26:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 39:
-		/* Element[END_ELEMENT] */
-	case 60:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 72:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 23:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 9:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 97:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 109:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 92:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 115:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 124:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 27:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 51:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 128:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 66:
-		/* Element[START_ELEMENT(SchemaID), END_ELEMENT] */
-	case 110:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 61:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 127:
-		/* Element[END_ELEMENT] */
-	case 113:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 4:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 125:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 129:
-		/* Element[END_ELEMENT] */
-	case 73:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-		errn = decodeNBitUnsignedInteger(stream, 1, &eventCode2);
-		switch (eventCode2) {
-		case 0:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED;
-			return errn;
-		case 1:
-			*nextEvent = EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED;
-			return errn;
-		}
-		break;
-
-	default:
-		if (ruleID < 0) {
-			/* built-in element grammar */
-			if ( exi_appHand_IsStartContent(ruleID) ) {
-				/* TODO generate 2nd level productions */
-
-				/* StartTagContent grammar */
-				errn = decodeNBitUnsignedInteger(stream, 2, &eventCode2);
-				if(errn) {
-					return errn;
-				}
-				switch(eventCode2) {
-				case 0:
-					/* 0: EE */
-					*nextEvent = EXI_EVENT_END_ELEMENT_UNDECLARED;
-					break;
-				case 1:
-					/* 1: AT(*) */
-					*nextEvent = EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED;
-					break;
-				case 2:
-					/* 2: SE(*) */
-					*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED;
-					break;
-				case 3:
-					/* 3: CH */
-					*nextEvent = EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED;
-					break;
-				default:
-					return EXI_ERROR_UNEXPECTED_EVENT_LEVEL2;
-					break;
-				}
-				return errn;
-			} else {
-				/* TODO generate 2nd level productions */
-
-				/* ElementContent grammar */
-				errn = decodeNBitUnsignedInteger(stream, 1, &eventCode2);
-				if(errn) {
-					return errn;
-				}
-				switch(eventCode2) {
-				case 0:
-					/* 0: SE(*) */
-					*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED;
-					break;
-				case 1:
-					/* 1: CH */
-					*nextEvent = EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED;
-					break;
-				default:
-					return EXI_ERROR_UNEXPECTED_EVENT_LEVEL2;
-					break;
-				}
-
-
-
-			}
-
-		} else {
-			*nextEvent = EXI_EVENT_ERROR;
-			return EXI_ERROR_UNEXPECTED_EVENT_LEVEL2;
-		}
-		break;
-	}
-
-	return EXI_ERROR_UNEXPECTED_EVENT_LEVEL2;
-}
-
-
-
-static int _exiDecodeNamespaceUri(bitstream_t* stream, exi_state_t* state,
-		exi_name_entry_t* uri) {
-/*		exi_string_ascii_t* namespaceURI, uint32_t* uriID) {*/
-	uint16_t uriSize, uriCodingLength;
-	uint32_t uriID;
-	int errn;
-
-	errn = exiGetUriSize(&state->nameTablePrepopulated, &state->nameTableRuntime, &uriSize);
-	if (errn) {
-		return errn;
-	}
-	/* URI Entries + 1 */
-	errn = exiGetCodingLength(uriSize + 1, &uriCodingLength);
-	if (errn) {
-		return errn;
-	}
-
-	errn = decodeNBitUnsignedInteger(stream, uriCodingLength, &uriID);
-	if (errn) {
-		return errn;
-	}
-
-	if (uriID == 0) {
-		/* uri string value was not found */
-		/* ==> zero (0) as an n-nit unsigned integer */
-		/* followed by uri encoded as string */
-		uri->type = EXI_NAME_ENTRY_TYPE_STRING_AND_ID;
-		errn = decodeString(stream, &uri->str);
-		if (errn) {
-			return errn;
-		}
-		/* after encoding string value is added to table */
-		errn = exiAddUri(&state->nameTablePrepopulated, &state->nameTableRuntime); /*, namespaceURI->chars); */
-		if (errn) {
-			return errn;
-		}
-		uri->id = uriSize;
-		/* uriID = uriSize; */
-	} else {
-		/* uri string value found */
-		/* ==> value(i+1) is encoded as n-bit unsigned integer */
-		uri->type = EXI_NAME_ENTRY_TYPE_ID;
-		uri->id = (uint16_t)(uriID - 1);
-		/* *uriID = *uriID - 1; */
-	}
-
-	return 0;
-}
-
-static int _exiDecodeLocalName(bitstream_t* stream, exi_state_t* state,
-		uint16_t uriID, exi_name_entry_t* localName) {
-/*		exi_string_ascii_t* localName,
-		uint32_t* localNameID, uint32_t uriID) { */
-	uint32_t localNameID;
-	uint16_t slen;
-	uint16_t localNameSize;
-	uint16_t localNameCodingLength;
-
-
-	int errn = decodeUnsignedInteger16(stream, &slen);
-	if (errn) {
-		return errn;
-	}
-
-	if (slen > 0) {
-		/* string value was not found in local partition */
-		/* ==> string literal is encoded as a String */
-		/* with the length of the string incremented by one */
-		localName->type = EXI_NAME_ENTRY_TYPE_STRING_AND_ID;
-		if (slen-- >= (localName->str.size) ) {
-			return EXI_ERROR_OUT_OF_BOUNDS;
-		}
-		localName->str.len = slen;
-		errn = decodeCharacters(stream, slen, localName->str.codepoints);
-
-		/*if (slen-- >= localName->size) {
-			return EXI_ERROR_OUT_OF_BOUNDS;
-		}
-		errn = decodeCharactersASCII(stream, slen, localName->chars); */
-
-		if (errn) {
-			return errn;
-		}
-		/* After encoding the string value, it is added to the string table */
-		/* partition and assigned the next available compact identifier */
-		errn = exiAddLocalName(&state->nameTablePrepopulated, &state->nameTableRuntime, uriID, &localName->id); /* uriID); *//*, localName->chars); */
-
-		/*if (errn) {
-			return errn;
-		}*/
-		/* TODO UCD Profile */
-		/* qname = addLocalName(localName, uriID); */
-	} else {
-		/* string value found in local partition */
-		/* ==> string value is represented as zero (0) encoded as an */
-		/* Unsigned Integer */
-		/* followed by an the compact identifier of the string value as an */
-		/* n-bit unsigned integer */
-		/* n is log2 m and m is the number of entries in the string table */
-		/* partition */
-		localName->type = EXI_NAME_ENTRY_TYPE_ID;
-		errn = exiGetLocalNameSize(&state->nameTablePrepopulated, &state->nameTableRuntime, uriID, &localNameSize); /* uriID, &localNameSize); */
-		if (errn) {
-			return errn;
-		}
-		errn = exiGetCodingLength(localNameSize, &localNameCodingLength);
-		if (errn) {
-			return errn;
-		}
-		errn = decodeNBitUnsignedInteger(stream, localNameCodingLength, &localNameID); /*  localNameID);*/
-		localName->id = (uint16_t)(localNameID);
-		/*if (errn) {
-			return errn;
-		}*/
-	}
-
-	return errn;
-}
-
-static int _exiDecodeQName(bitstream_t* stream, exi_state_t* state,
-		uint16_t* qnameID,  exi_qname_t* qname) {
-
-	/*uint32_t uriID;
-	uint32_t localNameID;*/
-	/* const char * clocalName; */
-
-	/* uri */
-	int errn =_exiDecodeNamespaceUri(stream, state, &qname->uri); /* &qname->namespaceURI, &uriID); */
-	if (errn) {
-		return errn;
-	}
-	/* localName */
-	errn = _exiDecodeLocalName(stream, state, qname->uri.id, &qname->localName); /* &qname->localName, &localNameID, uriID); */
-	if (errn) {
-		return errn;
-	}
-
-	/*
-	errn = exiGetLocalName(nameTable, runtimeTable, uriID, localNameID, &clocalName);
-	if (errn) {
-		return errn;
-	}
-	strcpy ( qname->localName.chars, clocalName );
-	*/
-
-	if (_qname.localName.type == EXI_NAME_ENTRY_TYPE_STRING_AND_ID) {
-		errn = exiappHandAddEQName(state, qnameID, qname->uri.id, qname->localName.id);
-	} else {
-		/* IDs known --> retrieve qnameID */
-		errn = exiappHandGetQNameID(state, qname->uri.id, qname->localName.id, qnameID);
-	}
-
-
-	return errn;
-}
-
-
-static int _exiDecodeStartElement(exi_state_t* state, uint16_t qnameID,
-		uint16_t stackId, uint16_t newState) {
-	/*uint16_t ns, uint16_t ln, uint16_t qn, */
-	/*se->namespaceURI = ns;
-	se->localPart = ln;
-	se->qname = qn;*/
-	/* move on */
-	state->grammarStack[state->stackIndex] = stackId;
-	/* push element on stack */
-	return exi_appHand_PushStack(state, newState, qnameID); /* se);*/
-}
-
-
-int exiappHandGetLastQName(exi_qname_t** qname) {
-	*qname = &_qname;
-	return 0;
-}
-
-
-int exiappHandDecodeListValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, exi_value_t* val, exi_list_t lt) {
-	uint32_t uint32;
-
-	val->type = lt.type;
-
-	switch(lt.type) {
-	case EXI_DATATYPE_BINARY_BASE64:
-	case EXI_DATATYPE_BINARY_HEX:
-		errn = decodeBinary(stream, &val->binary);
-		break;
-	case EXI_DATATYPE_BOOLEAN:
-		errn = decodeBoolean(stream, &val->boolean);
-		break;
-	case EXI_DATATYPE_BOOLEAN_FACET:
-		errn = decodeNBitUnsignedInteger(stream, 2, &uint32);
-		val->boolean = uint32 > 1;
-		break;
-	case EXI_DATATYPE_DECIMAL:
-		errn = decodeDecimal(stream, &val->decimal);
-		break;
-	case EXI_DATATYPE_FLOAT:
-		errn = decodeFloat(stream, &val->float_me);
-		break;
-	case EXI_DATATYPE_NBIT_UNSIGNED_INTEGER:
-		errn = EXI_UNSUPPORTED_LIST_VALUE_TYPE;
-		break;
-	case EXI_DATATYPE_UNSIGNED_INTEGER:
-		errn = decodeUnsignedInteger(stream, &val->integer);
-		break;
-	case EXI_DATATYPE_INTEGER:
-		errn = decodeInteger(stream, &val->integer);
-		break;
-	case EXI_DATATYPE_DATETIME:
-		errn = decodeDateTime(stream,lt.datetimeType, &val->datetime);
-		break;
-	case EXI_DATATYPE_STRING:
-		errn = decodeStringValue(stream, state, qnameID, &val->str);
-		break;
-	default:
-		return EXI_UNSUPPORTED_LIST_VALUE_TYPE;
-	}
-
-	return errn;
-}
-
-
-
-
-int exiappHandInitDecoder(bitstream_t* stream, exi_state_t* state,
-		exi_name_table_runtime_t runtimeTable, exi_string_table_t stringTable) {
-#if EXI_appHandVALUE_PARTITION_CAPACITY != 0
-#if EXI_appHandVALUE_MAX_LENGTH != 0
-	int i;
-#endif /* EXI_appHandVALUE_MAX_LENGTH != 0 */
-#endif /* EXI_appHandVALUE_PARTITION_CAPACITY != 0 */
-	/* init grammar state */
-	state->stackIndex = 0;
-	state->grammarStack[0] = DOCUMENT;
-	/* name table */
-	state->nameTablePrepopulated = exiappHandNameTablePrepopulated;
-	state->nameTableRuntime = runtimeTable;
-	/* next qname ID */
-	state->nextQNameID = EXI_appHandNUMBER_OF_PREPOPULATED_QNAMES;
-	/* string table */
-	state->stringTable = stringTable;
-	state->stringTable.numberOfGlobalStrings = 0;
-#if EXI_appHandVALUE_PARTITION_CAPACITY != 0
-#if EXI_appHandVALUE_MAX_LENGTH != 0
-	for(i=0; i<(state->stringTable.sizeLocalStrings); i++) {
-		state->stringTable.numberOfLocalStrings[i] = 0;
-	}
-#endif /* EXI_appHandVALUE_MAX_LENGTH != 0 */
-#endif /* EXI_appHandVALUE_PARTITION_CAPACITY != 0 */
-
-	/* runtime grammars */
-	state->numberOfRuntimeGrammars = 0;
-
-	/* Avoid warning: Unused declaration of variable 'name' */
-	xsi = 0;
-	bits = 0;
-
-	/* decode header */
-	return readEXIHeader(stream);
-}
-
-int exiappHandDecodeNextEvent(bitstream_t* stream, exi_state_t* state,
-		exi_event_t* nextEvent) {
-	uint16_t codingLength;
-	uint16_t numberOfProductions;
-	uint32_t eventCode1;
-	int16_t ruleID = state->grammarStack[state->stackIndex];
-	state->eventCode = 0;
-	errn = 0;
-
-	switch (ruleID) {
-	case 3:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 8:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 26:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 60:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 72:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 9:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 97:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 109:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 92:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 115:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 124:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 27:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 128:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 66:
-		/* Element[START_ELEMENT(SchemaID), END_ELEMENT] */
-	case 110:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 61:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 113:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 4:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 125:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 73:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-		errn = decodeNBitUnsignedInteger(stream, 2, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-			*nextEvent = EXI_EVENT_START_ELEMENT;
-			break;
-		case 1:
-			*nextEvent = EXI_EVENT_END_ELEMENT;
-			break;
-		case 2:
-			/* 2nd level events */
-			errn = exiDecodeNext2Event(stream, state, nextEvent);
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 30:
-		/* Element[START_ELEMENT(ProtocolNamespace)] */
-	case 33:
-		/* Element[START_ELEMENT(VersionNumberMinor)] */
-	case 31:
-		/* Element[START_ELEMENT(VersionNumberMajor)] */
-	case 16:
-		/* FirstStartTag[START_ELEMENT(ResponseCode)] */
-	case 15:
-		/* FirstStartTag[START_ELEMENT(AppProtocol)] */
-	case 34:
-		/* Element[START_ELEMENT(SchemaID)] */
-	case 94:
-		/* Element[START_ELEMENT(AppProtocol)] */
-	case 117:
-		/* Element[START_ELEMENT(ResponseCode)] */
-	case 90:
-		/* Element[START_ELEMENT(Priority)] */
-	case 5:
-		/* FirstStartTag[START_ELEMENT(ProtocolNamespace)] */
-		errn = decodeNBitUnsignedInteger(stream, 1, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-			*nextEvent = EXI_EVENT_START_ELEMENT;
-			break;
-		case 1:
-			/* 2nd level events */
-			errn = exiDecodeNext2Event(stream, state, nextEvent);
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 0:
-		/* Document[START_DOCUMENT] */
-	case 105:
-		/* Fragment[START_DOCUMENT] */
-		*nextEvent = EXI_EVENT_START_DOCUMENT;
-		break;
-	case 14:
-		/* DocEnd[END_DOCUMENT] */
-		*nextEvent = EXI_EVENT_END_DOCUMENT;
-		break;
-	case 42:
-		/* FragmentContent[START_ELEMENT(AppProtocol), START_ELEMENT(Priority), START_ELEMENT(ProtocolNamespace), START_ELEMENT(ResponseCode), START_ELEMENT(SchemaID), START_ELEMENT(VersionNumberMajor), START_ELEMENT(VersionNumberMinor), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC, END_DOCUMENT] */
-		errn = decodeNBitUnsignedInteger(stream, 4, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-		case 1:
-		case 2:
-		case 3:
-		case 4:
-		case 5:
-		case 6:
-		case 7:
-		case 8:
-			*nextEvent = EXI_EVENT_START_ELEMENT;
-			break;
-		case 9:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC;
-			break;
-		case 10:
-			*nextEvent = EXI_EVENT_END_DOCUMENT;
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 22:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 50:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		errn = decodeNBitUnsignedInteger(stream, 3, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-			*nextEvent = EXI_EVENT_ATTRIBUTE_GENERIC;
-			break;
-		case 1:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC;
-			break;
-		case 2:
-			*nextEvent = EXI_EVENT_END_ELEMENT;
-			break;
-		case 3:
-			*nextEvent = EXI_EVENT_CHARACTERS_GENERIC;
-			break;
-		case 4:
-			/* 2nd level events */
-			errn = exiDecodeNext2Event(stream, state, nextEvent);
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 1:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 7:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 11:
-		/* FirstStartTag[CHARACTERS[FLOAT]] */
-	case 10:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 12:
-		/* Element[CHARACTERS[STRING]] */
-	case 17:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 18:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 19:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 20:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 21:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 25:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-	case 24:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 29:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-	case 28:
-		/* Element[CHARACTERS[BINARY_HEX]] */
-	case 32:
-		/* Element[CHARACTERS[STRING]] */
-	case 37:
-		/* Element[CHARACTERS[BOOLEAN]] */
-	case 36:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 38:
-		/* Element[CHARACTERS[STRING]] */
-	case 40:
-		/* Element[CHARACTERS[STRING]] */
-	case 41:
-		/* Element[CHARACTERS[STRING]] */
-	case 48:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 47:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 49:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 52:
-		/* Element[CHARACTERS[BINARY_BASE64]] */
-	case 53:
-		/* FirstStartTag[CHARACTERS[DECIMAL]] */
-	case 54:
-		/* Element[CHARACTERS[STRING]] */
-	case 55:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 56:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 57:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 58:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 59:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 45:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 62:
-		/* Element[CHARACTERS[FLOAT]] */
-	case 63:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 64:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 65:
-		/* Element[CHARACTERS[LIST]] */
-	case 67:
-		/* Element[CHARACTERS[STRING]] */
-	case 68:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 46:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 69:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 70:
-		/* Element[CHARACTERS[STRING]] */
-	case 71:
-		/* Element[CHARACTERS[ENUMERATION]] */
-	case 74:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 75:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 76:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 77:
-		/* Element[CHARACTERS[STRING]] */
-	case 78:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 79:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 80:
-		/* FirstStartTag[CHARACTERS[BOOLEAN]] */
-	case 81:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 35:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 82:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 44:
-		/* FirstStartTag[CHARACTERS[ENUMERATION]] */
-	case 83:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 84:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 85:
-		/* Element[CHARACTERS[STRING]] */
-	case 86:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 87:
-		/* Element[CHARACTERS[STRING]] */
-	case 88:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 89:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 91:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 93:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 95:
-		/* Element[CHARACTERS[LIST]] */
-	case 96:
-		/* Element[CHARACTERS[STRING]] */
-	case 98:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 99:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 101:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 100:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 102:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 103:
-		/* Element[CHARACTERS[FLOAT]] */
-	case 104:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 106:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 107:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 111:
-		/* FirstStartTag[CHARACTERS[BINARY_BASE64]] */
-	case 108:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 43:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 112:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 114:
-		/* Element[CHARACTERS[STRING]] */
-	case 116:
-		/* Element[CHARACTERS[DECIMAL]] */
-	case 118:
-		/* Element[CHARACTERS[STRING]] */
-	case 119:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-	case 120:
-		/* Element[CHARACTERS[STRING]] */
-	case 121:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 123:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 122:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 126:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 130:
-		/* FirstStartTag[CHARACTERS[FLOAT]] */
-	case 131:
-		/* Element[CHARACTERS[STRING]] */
-	case 132:
-		/* FirstStartTag[CHARACTERS[BINARY_HEX]] */
-	case 133:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 134:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-	case 135:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-	case 136:
-		/* Element[CHARACTERS[INTEGER]] */
-	case 137:
-		/* Element[CHARACTERS[STRING]] */
-	case 140:
-		/* Element[CHARACTERS[LIST]] */
-	case 139:
-		/* Element[CHARACTERS[DATETIME]] */
-	case 138:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-	case 141:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 142:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 143:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-	case 144:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-	case 145:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		errn = decodeNBitUnsignedInteger(stream, 1, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-			*nextEvent = EXI_EVENT_CHARACTERS;
-			break;
-		case 1:
-			/* 2nd level events */
-			errn = exiDecodeNext2Event(stream, state, nextEvent);
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 2:
-		/* Element[END_ELEMENT] */
-	case 39:
-		/* Element[END_ELEMENT] */
-	case 127:
-		/* Element[END_ELEMENT] */
-	case 129:
-		/* Element[END_ELEMENT] */
-		errn = decodeNBitUnsignedInteger(stream, 1, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-			*nextEvent = EXI_EVENT_END_ELEMENT;
-			break;
-		case 1:
-			/* 2nd level events */
-			errn = exiDecodeNext2Event(stream, state, nextEvent);
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 13:
-		/* DocContent[START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC] */
-		errn = decodeNBitUnsignedInteger(stream, 2, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-		case 1:
-			*nextEvent = EXI_EVENT_START_ELEMENT;
-			break;
-		case 2:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC;
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-	case 23:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 51:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		errn = decodeNBitUnsignedInteger(stream, 2, &state->eventCode);
-		switch (state->eventCode) {
-		case 0:
-			*nextEvent = EXI_EVENT_START_ELEMENT_GENERIC;
-			break;
-		case 1:
-			*nextEvent = EXI_EVENT_END_ELEMENT;
-			break;
-		case 2:
-			*nextEvent = EXI_EVENT_CHARACTERS_GENERIC;
-			break;
-		case 3:
-			/* 2nd level events */
-			errn = exiDecodeNext2Event(stream, state, nextEvent);
-			break;
-		default:
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-			break;
-		}
-		break;
-
-	default:
-		if(ruleID < 0)  {
-			/* built-in element grammar */
-			numberOfProductions = state->runtimeGrammars[(ruleID + 1)*(-1)].numberOfProductions;
-			if(numberOfProductions > 0) {
-				/* decode 1st level event code */
-				errn = exiGetCodingLength(numberOfProductions + 1, &codingLength);
-				if(errn) {
-					return errn;
-				}
-				errn = decodeNBitUnsignedInteger(stream, codingLength, &eventCode1);
-				if(errn) {
-					return errn;
-				}
-
-				if(eventCode1 == numberOfProductions) {
-					/* 2nd level */
-					errn = exiDecodeNext2Event(stream, state, nextEvent);
-				} else {
-					/* 1st level event not supported in profile */
-					errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-				}
-			} else {
-				errn = exiDecodeNext2Event(stream, state, nextEvent);
-			}
-		} else {
-			*nextEvent = EXI_EVENT_ERROR;
-			errn = EXI_ERROR_UNEXPECTED_EVENT_LEVEL1;
-		}
-		break;
-	}
-
-	currEvent = *nextEvent;
-	return errn;
-}
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-int exiappHandDecodeStartDocument(bitstream_t* stream, exi_state_t* state) {
-	if ( state->grammarStack[state->stackIndex] == 0 ) {
-		/* move on */
-		state->grammarStack[state->stackIndex] = 13;
-		return 0;
-	} 
-	if ( state->grammarStack[state->stackIndex] == 105 ) {
-		/* move on */
-		state->grammarStack[state->stackIndex] = 42;
-		return 0;
-	} 
-
-	return EXI_ERROR_UNEXPECTED_START_DOCUMENT;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-int exiappHandDecodeEndDocument(bitstream_t* stream, exi_state_t* state) {
-	if ( state->grammarStack[state->stackIndex] == 42) {
-		return 0;
-	} 
-	if ( state->grammarStack[state->stackIndex] == 14) {
-		return 0;
-	} 
-
-	return EXI_ERROR_UNEXPECTED_END_DOCUMENT;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-
-
-int exiappHandDecodeStartElement(bitstream_t* stream, exi_state_t* state,
-		uint16_t* qnameID) {
-	errn = EXI_ERROR_UNEXPECTED_START_ELEMENT;
-
-	switch(currEvent) {
-	case EXI_EVENT_START_ELEMENT:
-		switch (state->grammarStack[state->stackIndex]) {
-		case 3:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 4, 5);
-				break;
-			}
-			break;
-		case 4:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 124, 5);
-				break;
-			}
-			break;
-		case 5:
-			/* FirstStartTag[START_ELEMENT(ProtocolNamespace)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 2, 31, 18);
-				break;
-			}
-			break;
-		case 8:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 9, 5);
-				break;
-			}
-			break;
-		case 9:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 92, 5);
-				break;
-			}
-			break;
-		case 13:
-			/* DocContent[START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 65, 14, 15);
-				break;
-			case 1:
-				errn = _exiDecodeStartElement(state, *qnameID = 66, 14, 16);
-				break;
-			}
-			break;
-		case 15:
-			/* FirstStartTag[START_ELEMENT(AppProtocol)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 3, 5);
-				break;
-			}
-			break;
-		case 16:
-			/* FirstStartTag[START_ELEMENT(ResponseCode)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 3, 66, 44);
-				break;
-			}
-			break;
-		case 26:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 27, 5);
-				break;
-			}
-			break;
-		case 27:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 97, 5);
-				break;
-			}
-			break;
-		case 30:
-			/* Element[START_ELEMENT(ProtocolNamespace)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 2, 31, 18);
-				break;
-			}
-			break;
-		case 31:
-			/* Element[START_ELEMENT(VersionNumberMajor)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 5, 33, 46);
-				break;
-			}
-			break;
-		case 33:
-			/* Element[START_ELEMENT(VersionNumberMinor)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 6, 34, 35);
-				break;
-			}
-			break;
-		case 34:
-			/* Element[START_ELEMENT(SchemaID)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 4, 90, 45);
-				break;
-			}
-			break;
-		case 42:
-			/* FragmentContent[START_ELEMENT(AppProtocol), START_ELEMENT(Priority), START_ELEMENT(ProtocolNamespace), START_ELEMENT(ResponseCode), START_ELEMENT(SchemaID), START_ELEMENT(VersionNumberMajor), START_ELEMENT(VersionNumberMinor), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC, END_DOCUMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 42, 5);
-				break;
-			case 1:
-				errn = _exiDecodeStartElement(state, *qnameID = 1, 42, 43);
-				break;
-			case 2:
-				errn = _exiDecodeStartElement(state, *qnameID = 2, 42, 18);
-				break;
-			case 3:
-				errn = _exiDecodeStartElement(state, *qnameID = 3, 42, 44);
-				break;
-			case 4:
-				errn = _exiDecodeStartElement(state, *qnameID = 4, 42, 45);
-				break;
-			case 5:
-				errn = _exiDecodeStartElement(state, *qnameID = 5, 42, 46);
-				break;
-			case 6:
-				errn = _exiDecodeStartElement(state, *qnameID = 6, 42, 35);
-				break;
-			case 7:
-				errn = _exiDecodeStartElement(state, *qnameID = 65, 42, 15);
-				break;
-			case 8:
-				errn = _exiDecodeStartElement(state, *qnameID = 66, 42, 16);
-				break;
-			}
-			break;
-		case 60:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 61, 5);
-				break;
-			}
-			break;
-		case 61:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 26, 5);
-				break;
-			}
-			break;
-		case 66:
-			/* Element[START_ELEMENT(SchemaID), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 4, 129, 45);
-				break;
-			}
-			break;
-		case 72:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 73, 5);
-				break;
-			}
-			break;
-		case 73:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 109, 5);
-				break;
-			}
-			break;
-		case 90:
-			/* Element[START_ELEMENT(Priority)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 1, 127, 43);
-				break;
-			}
-			break;
-		case 92:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 113, 5);
-				break;
-			}
-			break;
-		case 94:
-			/* Element[START_ELEMENT(AppProtocol)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 3, 5);
-				break;
-			}
-			break;
-		case 97:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 39, 5);
-				break;
-			}
-			break;
-		case 109:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 110, 5);
-				break;
-			}
-			break;
-		case 110:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 60, 5);
-				break;
-			}
-			break;
-		case 113:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 115, 5);
-				break;
-			}
-			break;
-		case 115:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 72, 5);
-				break;
-			}
-			break;
-		case 117:
-			/* Element[START_ELEMENT(ResponseCode)] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 3, 66, 44);
-				break;
-			}
-			break;
-		case 124:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 125, 5);
-				break;
-			}
-			break;
-		case 125:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 128, 5);
-				break;
-			}
-			break;
-		case 128:
-			/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-			switch(state->eventCode) {
-			case 0:
-				errn = _exiDecodeStartElement(state, *qnameID = 0, 8, 5);
-				break;
-			}
-			break;
-
-		}
-		break;
-	case EXI_EVENT_START_ELEMENT_NS:
-		errn = EXI_ERROR_UNEXPECTED_START_ELEMENT;
-		break;
-	case EXI_EVENT_START_ELEMENT_GENERIC:
-	case EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED:
-		errn = _exiDecodeQName(stream, state, qnameID,
-				&_qname);
-		if (errn) {
-			return errn;
-		}
-
-		/* update current rule --> element content rule (if not already) */
-		errn = exi_appHand_MoveToElementContentRule(state);
-		if (errn) {
-			return errn;
-		}
-
-		/* retrieve global grammar(existing OR runtime) and push it stack */
-		errn = exi_appHand_RetrieveAndPushGlobalGrammar(state, *qnameID);
-		break;
-	default:
-		errn = EXI_ERROR_UNEXPECTED_START_ELEMENT;
-		break;
-	}
-
-	return errn;
-}
-
-
-
-/*int exiappHandDecodeStartElementGeneric(bitstream_t* stream, exi_state_t* state,
-		qname_t* qname) {
-	// decode qname
-	int errn = _exiDecodeQName(stream, &(state->nameTablePrepopulated), &(state->nameTableRuntime), qname);
-	if (errn) {
-		return errn;
-	}
-
-	switch (state->grammarStack[state->stackIndex]) {
-	// $EXI_DECODE_START_ELEMENT_GENERIC$
-	case DOC_CONTENT:
-		// move on to DocEnd
-		state->grammarStack[state->stackIndex] = DOC_END;
-		// push new ur-type grammar on stack
-		return exiPushStack(state, UR_TYPE_GRAMMAR_0, NULL);
-		break;
-	case UR_TYPE_GRAMMAR_0:
-		// move on to UR_TYPE_GRAMMAR_1
-		state->grammarStack[state->stackIndex] = UR_TYPE_GRAMMAR_1;
-		// push new ur-type grammar on stack
-		return exiPushStack(state, UR_TYPE_GRAMMAR_0, NULL);
-		break;
-	case UR_TYPE_GRAMMAR_1:
-		// remain in UR_TYPE_GRAMMAR_1
-		// push new ur-type grammar on stack
-		return exiPushStack(state, UR_TYPE_GRAMMAR_0, NULL);
-		break;
-	default:
-		return EXI_ERROR_UNEXPECTED_START_ELEMENT_GENERIC;
-	}
-
-	return EXI_ERROR_UNEXPECTED_START_ELEMENT_GENERIC;
-}*/
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-int exiappHandDecodeEndElement(bitstream_t* stream, exi_state_t* state, uint16_t* qnameID) {
-	int16_t currentID;
-	switch(currEvent) {
-	case EXI_EVENT_END_ELEMENT_UNDECLARED:
-		currentID = state->grammarStack[state->stackIndex];
-		if (currentID < 0) {
-			/* runtime grammars do have IDs smaller than 0 */
-			/* TODO learn EE event */
-			return -1;
-		}
-		/* Note: no break statement */
-	default:
-		/* copy IDs */
-		*qnameID = state->elementStack[state->stackIndex];
-		/*ee->localPart  = state->elementStack[state->stackIndex].localPart;
-		ee->namespaceURI = state->elementStack[state->stackIndex].namespaceURI;*/
-
-		return exi_appHand_PopStack(state);
-	}
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-
-/*int exiappHandDecodeEndElementUndeclared(bitstream_t* stream, exi_state_t* state, eqname_t* ee) {
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	if (currentID < 0) {
-		// runtime grammars do have IDs smaller than 0
-		// TODO learn EE event
-		return -1;
-	}
-
-	return exiappHandDecodeEndElement(stream, state, ee);
-}*/
-
-int exiappHandDecodeCharacters(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	int16_t moveOnID = 0;
-	errn = EXI_ERROR_UNEXPECTED_CHARACTERS;
-
-	switch(currEvent) {
-	case EXI_EVENT_CHARACTERS:
-	case EXI_EVENT_CHARACTERS_GENERIC:
-		switch (state->grammarStack[state->stackIndex]) {
-		case 53:
-			/* DECIMAL */
-		case 116:
-			/* DECIMAL */
-			val->type = EXI_DATATYPE_DECIMAL;
-			errn = decodeDecimal(stream, &val->decimal);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 10:
-			/* STRING */
-		case 12:
-			/* STRING */
-		case 18:
-			/* STRING */
-		case 20:
-			/* STRING */
-		case 24:
-			/* STRING */
-		case 32:
-			/* STRING */
-		case 36:
-			/* STRING */
-		case 38:
-			/* STRING */
-		case 40:
-			/* STRING */
-		case 41:
-			/* STRING */
-		case 48:
-			/* STRING */
-		case 54:
-			/* STRING */
-		case 55:
-			/* STRING */
-		case 58:
-			/* STRING */
-		case 67:
-			/* STRING */
-		case 70:
-			/* STRING */
-		case 77:
-			/* STRING */
-		case 78:
-			/* STRING */
-		case 79:
-			/* STRING */
-		case 85:
-			/* STRING */
-		case 86:
-			/* STRING */
-		case 87:
-			/* STRING */
-		case 96:
-			/* STRING */
-		case 98:
-			/* STRING */
-		case 101:
-			/* STRING */
-		case 106:
-			/* STRING */
-		case 114:
-			/* STRING */
-		case 118:
-			/* STRING */
-		case 120:
-			/* STRING */
-		case 131:
-			/* STRING */
-		case 137:
-			/* STRING */
-		case 141:
-			/* STRING */
-		case 142:
-			/* STRING */
-		case 143:
-			/* STRING */
-			val->type = EXI_DATATYPE_STRING;
-			errn = decodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 25:
-			/* LIST */
-		case 29:
-			/* LIST */
-		case 65:
-			/* LIST */
-		case 95:
-			/* LIST */
-		case 140:
-			/* LIST */
-		case 144:
-			/* LIST */
-			val->type = EXI_DATATYPE_LIST;
-			val->list.type = EXI_DATATYPE_STRING;
-			errn = decodeUnsignedInteger16(stream, &val->list.len);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 112:
-			/* DATETIME */
-		case 126:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_TIME, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 28:
-			/* BINARY_HEX */
-		case 132:
-			/* BINARY_HEX */
-			val->type = EXI_DATATYPE_BINARY_HEX;
-			errn = decodeBinary(stream, &val->binary);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 74:
-			/* DATETIME */
-		case 123:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_GYEARMONTH, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 1:
-			/* NBIT_UNSIGNED_INTEGER */
-		case 45:
-			/* NBIT_UNSIGNED_INTEGER */
-		case 75:
-			/* NBIT_UNSIGNED_INTEGER */
-		case 122:
-			/* NBIT_UNSIGNED_INTEGER */
-			val->type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-			errn = _decodeNBitIntegerValue(stream, &val->integer, 8, 0);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 88:
-			/* DATETIME */
-		case 104:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_DATETIME, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 56:
-			/* NBIT_UNSIGNED_INTEGER */
-		case 134:
-			/* NBIT_UNSIGNED_INTEGER */
-			val->type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-			errn = _decodeNBitIntegerValue(stream, &val->integer, 8, -128);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 100:
-			/* DATETIME */
-		case 139:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_GMONTHDAY, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 17:
-			/* INTEGER */
-		case 47:
-			/* INTEGER */
-		case 68:
-			/* INTEGER */
-		case 69:
-			/* INTEGER */
-		case 76:
-			/* INTEGER */
-		case 83:
-			/* INTEGER */
-		case 89:
-			/* INTEGER */
-		case 91:
-			/* INTEGER */
-		case 93:
-			/* INTEGER */
-		case 107:
-			/* INTEGER */
-		case 136:
-			/* INTEGER */
-		case 138:
-			/* INTEGER */
-			val->type = EXI_DATATYPE_INTEGER;
-			errn = decodeInteger(stream, &val->integer);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 71:
-			/* ENUMERATION */
-		case 44:
-			/* ENUMERATION */
-			val->type = EXI_DATATYPE_ENUMERATION;
-			errn = decodeNBitUnsignedInteger(stream, 2, &val->enumeration);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 64:
-			/* DATETIME */
-		case 82:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_GMONTH, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 84:
-			/* DATETIME */
-		case 99:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_GYEAR, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 121:
-			/* DATETIME */
-		case 133:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_DATE, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 63:
-			/* DATETIME */
-		case 135:
-			/* DATETIME */
-			val->type = EXI_DATATYPE_DATETIME;
-			errn = decodeDateTime(stream, EXI_DATETIME_GDAY, &val->datetime);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 22:
-			/* STRING */
-		case 23:
-			/* STRING */
-			val->type = EXI_DATATYPE_STRING;
-			errn = decodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 23; /* move on ID */
-			break;
-		case 11:
-			/* FLOAT */
-		case 62:
-			/* FLOAT */
-		case 103:
-			/* FLOAT */
-		case 130:
-			/* FLOAT */
-			val->type = EXI_DATATYPE_FLOAT;
-			errn = decodeFloat(stream, &val->float_me);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 19:
-			/* NBIT_UNSIGNED_INTEGER */
-		case 43:
-			/* NBIT_UNSIGNED_INTEGER */
-			val->type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-			errn = _decodeNBitIntegerValue(stream, &val->integer, 5, 1);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 37:
-			/* BOOLEAN */
-		case 80:
-			/* BOOLEAN */
-			val->type = EXI_DATATYPE_BOOLEAN;
-			errn = decodeBoolean(stream, &val->boolean);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 7:
-			/* UNSIGNED_INTEGER */
-		case 21:
-			/* UNSIGNED_INTEGER */
-		case 49:
-			/* UNSIGNED_INTEGER */
-		case 57:
-			/* UNSIGNED_INTEGER */
-		case 59:
-			/* UNSIGNED_INTEGER */
-		case 46:
-			/* UNSIGNED_INTEGER */
-		case 81:
-			/* UNSIGNED_INTEGER */
-		case 35:
-			/* UNSIGNED_INTEGER */
-		case 102:
-			/* UNSIGNED_INTEGER */
-		case 108:
-			/* UNSIGNED_INTEGER */
-		case 119:
-			/* UNSIGNED_INTEGER */
-		case 145:
-			/* UNSIGNED_INTEGER */
-			val->type = EXI_DATATYPE_UNSIGNED_INTEGER;
-			errn = decodeUnsignedInteger(stream, &val->integer);
-			moveOnID = 2; /* move on ID */
-			break;
-		case 50:
-			/* STRING */
-		case 51:
-			/* STRING */
-			val->type = EXI_DATATYPE_STRING;
-			errn = decodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 51; /* move on ID */
-			break;
-		case 52:
-			/* BINARY_BASE64 */
-		case 111:
-			/* BINARY_BASE64 */
-			val->type = EXI_DATATYPE_BINARY_BASE64;
-			errn = decodeBinary(stream, &val->binary);
-			moveOnID = 2; /* move on ID */
-			break;
-
-		}
-		if (errn) {
-			/* error */
-		} else {
-			/* move on */
-			state->grammarStack[state->stackIndex] = moveOnID;
-		}
-		break;
-	case EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED:
-		if (state->grammarStack[state->stackIndex] < 0) {
-			/* runtime grammars do have IDs smaller than 0 */
-			return EXI_UNSUPPORTED_GRAMMAR_LEARNING_CH;
-		}
-
-		/* update current rule --> element content rule (if not already) */
-		errn = exi_appHand_MoveToElementContentRule(state);
-		if (errn) {
-			return errn;
-		}
-
-		/* read content value as STRING */
-		val->type = EXI_DATATYPE_STRING;
-		errn = decodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-		break;
-	default:
-		errn = EXI_ERROR_UNEXPECTED_CHARACTERS;
-		break;
-	}
-
-	return errn;
-}
-
-/*int exiappHandDecodeCharactersGeneric(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	return exiappHandDecodeCharacters(stream, state, val);
-}*/
-
-/*int exiappHandDecodeCharactersGenericUndeclared(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	int errn = 0;
-	if (state->grammarStack[state->stackIndex] < 0) {
-		// runtime grammars do have IDs smaller than 0
-		// TODO learn CH event
-		return -1;
-	}
-
-	// update current rule --> element content rule (if not already)
-	errn = exiMoveToElementContentRule(state);
-	if (errn) {
-		return errn;
-	}
-
-	// read content value
-	// STRING
-	val->type = EXI_DATATYPE_STRING;
-	errn = decodeStringValue(stream, &val->string);
-	return errn;
-}*/
-
-int exiappHandDecodeAttributeGenericValue(bitstream_t* stream, exi_state_t* state, uint16_t* qnameID, exi_value_t* val) {
-	int16_t currentID;
-
-	if (_qname.uri.id == 2 && _qname.localName.id == 1 ) {
-		/* xsi:type --> QName type */
-		errn = exiappHandDecodeAttributeXsiType(stream, state, val);
-	} else {
-		currentID = state->grammarStack[state->stackIndex];
-		if (currentID >= 0) {
-			/* if schema-informed value type according global attribute */
-			switch(*qnameID) {
-
-			default:
-				val->type = EXI_DATATYPE_STRING;
-				errn = decodeStringValue(stream, state, *qnameID, &val->str);
-				break;
-			}
-
-		} else {
-			val->type = EXI_DATATYPE_STRING;
-			errn = decodeStringValue(stream, state, *qnameID, &val->str);
-		}
-	}
-
-	return errn;
-}
-
-int exiappHandDecodeAttribute(bitstream_t* stream, exi_state_t* state,
-		uint16_t* qnameID, exi_value_t* val) {
-	int16_t moveOnID = 0;
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	errn = EXI_ERROR_UNEXPECTED_ATTRIBUTE;
-
-	switch(currEvent) {
-	case EXI_EVENT_ATTRIBUTE:
-	case EXI_EVENT_ATTRIBUTE_INVALID_VALUE:
-		switch (currentID) {
-
-		}
-
-		if (errn) {
-			/* error */
-		} else {
-			/* move on */
-			state->grammarStack[state->stackIndex] = moveOnID;
-		}
-		break;
-	case EXI_EVENT_ATTRIBUTE_GENERIC:
-	case EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED:
-		errn = _exiDecodeQName(stream, state, qnameID, &_qname);
-		if (errn) {
-			return errn;
-		}
-		/* learn attribute ? */
-		errn = exi_appHand_LearnAttribute(state, *qnameID, _qname.uri.id,  _qname.localName.id);
-		if (errn) {
-			return errn;
-		}
-		/* decode attribute value */
-		errn = exiappHandDecodeAttributeGenericValue(stream, state, qnameID, val);
-		break;
-	default:
-		errn = EXI_ERROR_UNEXPECTED_ATTRIBUTE;
-		break;
-	}
-
-	return errn;
-}
-
-
-
-/*int exiappHandDecodeAttributeGenericUndeclared(bitstream_t* stream, exi_state_t* state,
-		qname_t* at, exi_value_t* val) {
-	int errn;
-	int16_t currentID = state->grammarStack[state->stackIndex];
-
-	if (currentID < 0) {
-		// TODO runtime elements
-		return -1;
-	} else {
-		// decode qname
-		errn = _exiDecodeQName(stream, &(state->nameTablePrepopulated), &(state->nameTableRuntime), at);
-		if (errn) {
-			return errn;
-		}
-	}
-
-
-	if (currentID < 0) {
-		// TODO learn AT event
-		return -1;
-	}
-
-	 decode attribute value
-	val->type = EXI_DATATYPE_STRING;
-	errn = decodeStringValue(stream, &val->string);
-
-	// we do not move forward in grammars
-
-	return errn;
-}*/
-
-
-
-int exiappHandDecodeAttributeXsiNil(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	errn = decodeBoolean(stream, &val->boolean);
-	if (errn >= 0 && val->boolean) {
-		/* handle xsi:nil == true */
-		 errn = exi_appHand_HandleXsiNilTrue(state);
-	}
-	return errn;
-}
-
-
-int exiappHandDecodeAttributeXsiType(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	/*uint32_t uriID;
-	uint32_t localNameID; */
-	/* uri */
-	errn =_exiDecodeNamespaceUri(stream, state, &_qname.uri); /* NULL, &uriID); */
-	if (errn) {
-		return errn;
-	}
-	/* localName */
-	errn = _exiDecodeLocalName(stream, state, _qname.uri.id, &_qname.localName); /* NULL, &localNameID, uriID);*/
-	if (errn) {
-		return errn;
-	}
-
-	val->type = EXI_DATATYPE_QNAME;
-	val->eqname.namespaceURI = _qname.uri.id; /*  uriID; */
-	val->eqname.localPart = _qname.localName.id; /* localNameID; */
-
-	/* handle xsi type cast */
-	errn = exi_appHand_HandleXsiType(state, &val->eqname);
-
-	return errn;
-}
-
-
-
-#endif
-

+ 0 - 222
src/codec/appHandCodec/appHandEXIDecoder.h

@@ -1,222 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI_appHand_DECODER_H
-#define EXI_appHand_DECODER_H
-
-/**
-* \file 	EXIDecoder.h
-* \brief 	EXI Decoder
-*
-*/
-
-#include "EXITypes.h"
-
-/**
- * \brief 		Initialize EXI decoder
- *
- *         		Resets & initializes the EXI decoder.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       runtimeTable   	Runtime name-tables
- * \param       stringTable   	String table
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandInitDecoder(bitstream_t* stream, exi_state_t* state,
-		exi_name_table_runtime_t runtimeTable, exi_string_table_t stringTable);
-
-
-/**
- * \brief 		Reports last decoded qualified name
- *
- *         		Note: Qualified name only available for previously unknown qname. Otherwise make use of name table entries.
- *
- * \param       qname   		Qualified name
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandGetLastQName(exi_qname_t** qname);
-
-
-/**
- * \brief 		Decodes next event
- *
- * 				Inspects EXI stream and decodes next EXI event.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       nextEvent   	Next event
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeNextEvent(bitstream_t* stream,
-		exi_state_t* state, exi_event_t* nextEvent);
-
-
-/**
- * \brief 		Decodes StartDocument (SD) event
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeStartDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief 		Decodes EndDocument (ED) event
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeEndDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief 		Decodes StartElemnt (SE) event
- *
- * 				Note: The first time a qnameID is larger than schema-informed NUMBER_OF_QNAMES it is possible to retrieve the qname by calling GetLastQName(...).
- * 				It is up to the caller to track qnames.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \return                  	Error-Code <> 0
- *
- */
-int
-exiappHandDecodeStartElement(bitstream_t* stream,
-		exi_state_t* state, uint16_t* qnameID);
-
-
-/**
- * \brief 		Decodes EndElement (EE) event
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeEndElement(bitstream_t* stream,
-		exi_state_t* state, uint16_t* qnameID);
-
-
-/**
- * \brief 		Decodes Characters (CH) event.
- *
- * 				Reports characters value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeCharacters(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes Attribute (AT) event.
- *
- * 				Reports attribute qname and value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeAttribute(bitstream_t* stream,
-		exi_state_t* state, uint16_t* qnameID, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes attribute xsi:nil
- *
- * 				Reports value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeAttributeXsiNil(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes attribute xsi:type
- *
- * 				Reports value.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       val		   		Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeAttributeXsiType(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-
-/**
- * \brief 		Decodes attribute/characters list value
- *
- * 				List values are special and are processed one by one.
- *
- * \param       stream   		Input Stream
- * \param       state   		Codec state
- * \param       qnameID   		Qualified Name ID
- * \param       val		   		List value
- * \param       lt		   		List type
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandDecodeListValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID,
-		exi_value_t* val, exi_list_t lt);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 1415
src/codec/appHandCodec/appHandEXIEncoder.c

@@ -1,1415 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_ENCODER_C
-#define EXI_appHand_ENCODER_C
-
-#include "EXITypes.h"
-#include "EXIOptions.h"
-#include "BitOutputStream.h"
-#include "EncoderChannel.h"
-
-#include "StringTable.h"
-#include "appHandNameTableEntries.h"
-#include "MethodsBag.h"
-
-#include "EXIOptions.h"
-
-#include "appHandEXICoder.h"
-#include "EXIHeaderEncoder.h"
-#include "ErrorCodes.h"
-#include "appHandQNames.h"
-#include "appHandQNameDefines.h"
-
-
-
-
-/* local variables */
-static uint32_t bits;
-static int errn;
-
-/* ==================================== */
-
-static int _encodeNBitIntegerValue(bitstream_t* stream, exi_integer_t* iv, uint16_t nbits, int32_t lowerBound) {
-	int errn;
-	uint32_t val;
-	switch(iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		val = iv->val.int8 - lowerBound;
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		val = iv->val.int16 - lowerBound;
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		val = (uint32_t)(iv->val.int32 - lowerBound);
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		val = (uint32_t)(iv->val.int64 - lowerBound);
-		break;
-	/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		val = iv->val.uint8 - lowerBound;
-		break;
-	case EXI_INTEGER_16:
-		val = iv->val.uint16 - lowerBound;
-		break;
-	case EXI_INTEGER_32:
-		val = iv->val.uint32 - lowerBound;
-		break;
-	case EXI_INTEGER_64:
-		val = (uint32_t)(iv->val.uint64 - lowerBound);
-		break;
-	default:
-		return EXI_UNSUPPORTED_INTEGER_VALUE_TYPE;
-		break;
-	}
-
-	errn = encodeNBitUnsignedInteger(stream, nbits, val);
-	return errn;
-}
-
-
-
-static int _exiValueToString(exi_value_t* val) {
-	if (val->type == EXI_DATATYPE_STRING) {
-		return 0;
-	} else {
-		/* TODO convert typed value to string */
-		return EXI_ERROR_CONVERSION_TYPE_TO_STRING;
-	}
-}
-
-
-
-static int _exiEncodeEventCode2(bitstream_t* stream, exi_state_t* state, exi_event_t event2) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-static int _exiEncodeNamespaceUriHit(bitstream_t* stream, exi_state_t* state, uint16_t uriID) {
-	int errn;
-	uint16_t uriCodingLength;
-	uint16_t uriSize;
-
-	errn = exiGetUriSize(&state->nameTablePrepopulated, &state->nameTableRuntime, &uriSize);
-	if (errn) {
-		return errn;
-	}
-	/* URI Entries + 1 */
-	errn = exiGetCodingLength(uriSize + 1, &uriCodingLength);
-	if (errn) {
-		return errn;
-	}
-
-	/* uri string value found */
-	/* ==> value(i+1) is encoded as n-bit unsigned integer */
-	errn = encodeNBitUnsignedInteger(stream, uriCodingLength, uriID+1);
-
-	return errn;
-}
-
-
-static int _exiEncodeNamespaceMiss(bitstream_t* stream, exi_state_t* state,
-		exi_string_ucs_t* uri, uint16_t* uriID) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-
-static int _exiEncodeLocalNameHit(bitstream_t* stream, exi_state_t* state,
-		uint16_t uriID, uint16_t localNameID) {
-	int errn;
-	uint16_t localNameSize;
-	uint16_t localNameCodingLength;
-
-	/* string value found in local partition */
-	/* ==> string value is represented as zero (0) encoded as an */
-	errn = encodeUnsignedInteger32(stream, 0 );
-	if (errn < 0) {
-		return errn;
-	}
-	/* Unsigned Integer followed by an the compact identifier of the */
-	/* string value as an n-bit unsigned integer n is log2 m and m is */
-	/* the number of entries in the string table partition */
-	errn = exiGetLocalNameSize(&state->nameTablePrepopulated, &state->nameTableRuntime, uriID, &localNameSize);
-	if (errn < 0) {
-		return errn;
-	}
-	errn = exiGetCodingLength(localNameSize, &localNameCodingLength);
-	if (errn) {
-		return errn;
-	}
-	errn = encodeNBitUnsignedInteger(stream, localNameCodingLength, localNameID);
-	return errn;
-
-}
-
-
-static int _exiEncodeLocalNameMiss(bitstream_t* stream, exi_state_t* state,
-		exi_string_ucs_t* localName, uint16_t uriID, uint16_t* localNameID) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-static int _encodeAttributeXsiTypeContent(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-
-	/* encode qname */
-	errn = _exiEncodeNamespaceUriHit(stream, state, val->eqname.namespaceURI);
-	if (errn < 0) {
-		return errn;
-	}
-	errn = _exiEncodeLocalNameHit(stream, state, val->eqname.namespaceURI, val->eqname.localPart);
-	if (errn < 0) {
-		return errn;
-	}
-
-	/* handle xsi type cast */
-	errn = exi_appHand_HandleXsiType(state, &val->eqname);
-
-	return errn;
-}
-
-
-static int _exiEncodeStartElement(bitstream_t* stream, uint16_t nbits,
-		uint32_t val, exi_state_t* state, uint16_t qnameID, uint16_t stackId,
-		uint16_t newState) {
-	/* event-code */
-	int errn = encodeNBitUnsignedInteger(stream, nbits, val);
-	if (errn) {
-		return errn;
-	}
-	/* move on */
-	state->grammarStack[state->stackIndex] = stackId;
-	/* push element on stack */
-	return exi_appHand_PushStack(state, newState, qnameID);
-}
-
-
-static int _exiEncodeEndElementUndeclared(bitstream_t* stream, exi_state_t* state) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-static int _encode2ndLevelAttribute(bitstream_t* stream, exi_state_t* state, uint16_t qnameID,
-		exi_value_t* val) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-int exiappHandEncodeListValue(bitstream_t* stream, exi_state_t* state, uint16_t qnameID, exi_value_t* val, exi_list_t lt) {
-
-	switch(lt.type) {
-	case EXI_DATATYPE_BINARY_BASE64:
-	case EXI_DATATYPE_BINARY_HEX:
-		errn = encodeBinary(stream, &val->binary);
-		break;
-	case EXI_DATATYPE_BOOLEAN:
-		errn = encodeBoolean(stream, val->boolean);
-		break;
-	case EXI_DATATYPE_BOOLEAN_FACET:
-		errn = encodeNBitUnsignedInteger(stream, 2, val->boolean ? 2 : 0);
-		break;
-	case EXI_DATATYPE_DECIMAL:
-		errn = encodeDecimal(stream, &val->decimal);
-		break;
-	case EXI_DATATYPE_FLOAT:
-		errn = encodeFloat(stream, &val->float_me);
-		break;
-	case EXI_DATATYPE_NBIT_UNSIGNED_INTEGER:
-		errn = EXI_UNSUPPORTED_LIST_VALUE_TYPE;
-		break;
-	case EXI_DATATYPE_UNSIGNED_INTEGER:
-		errn = encodeUnsignedInteger(stream, &val->integer);
-		break;
-	case EXI_DATATYPE_INTEGER:
-		errn = encodeInteger(stream, &val->integer);
-		break;
-	case EXI_DATATYPE_DATETIME:
-		errn = encodeDateTime(stream, &val->datetime);
-		break;
-	case EXI_DATATYPE_STRING:
-		errn = encodeStringValue(stream, state, qnameID, &val->str);
-		break;
-	default:
-		return EXI_UNSUPPORTED_LIST_VALUE_TYPE;
-	}
-
-	return errn;
-}
-
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-int exiappHandEncodeStartDocument(bitstream_t* stream, exi_state_t* state) {
-	if ( state->grammarStack[state->stackIndex] == 0 ) {
-		/* move on */
-		state->grammarStack[state->stackIndex] = 13;
-		return 0;
-	} 
-	if ( state->grammarStack[state->stackIndex] == 0 ) {
-		/* move on */
-		state->grammarStack[state->stackIndex] = 13;
-		return 0;
-	} 
-	if ( state->grammarStack[state->stackIndex] == 105 ) {
-		/* move on */
-		state->grammarStack[state->stackIndex] = 42;
-		return 0;
-	} 
-
-	return EXI_ERROR_UNEXPECTED_START_DOCUMENT;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-
-
-#ifndef __GNUC__
-#pragma warning( disable : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-int exiappHandEncodeEndDocument(bitstream_t* stream, exi_state_t* state) {
-	if ( state->grammarStack[state->stackIndex] == 42) {
-		encodeFinish(stream);
-		return 0;
-	} 
-	if ( state->grammarStack[state->stackIndex] == 14) {
-		encodeFinish(stream);
-		return 0;
-	} 
-
-	return EXI_ERROR_UNEXPECTED_END_DOCUMENT;
-}
-#ifndef __GNUC__
-#pragma warning( default : 4100 ) /* warning unreferenced parameter 'stream' */
-#endif /* __GNUC__ */
-
-
-int exiappHandInitEncoder(bitstream_t* stream, exi_state_t* state,
-		exi_name_table_runtime_t runtimeTable, exi_string_table_t stringTable) {
-#if EXI_appHandVALUE_PARTITION_CAPACITY != 0
-#if EXI_appHandVALUE_MAX_LENGTH != 0
-	int i;
-#endif /* EXI_appHandVALUE_MAX_LENGTH != 0 */
-#endif /* EXI_appHandVALUE_PARTITION_CAPACITY != 0 */
-	/* init grammar state */
-	state->stackIndex = 0;
-	state->grammarStack[0] = DOCUMENT;
-	/* name tables */
-	state->nameTablePrepopulated = exiappHandNameTablePrepopulated;
-	state->nameTableRuntime = runtimeTable;
-	/* next qname ID */
-	state->nextQNameID = EXI_appHandNUMBER_OF_PREPOPULATED_QNAMES;
-	/* string tables */
-	state->stringTable = stringTable;
-	state->stringTable.numberOfGlobalStrings = 0;
-#if EXI_appHandVALUE_PARTITION_CAPACITY != 0
-#if EXI_appHandVALUE_MAX_LENGTH != 0
-	for(i=0; i<(state->stringTable.sizeLocalStrings); i++) {
-		state->stringTable.numberOfLocalStrings[i] = 0;
-	}
-#endif /* EXI_appHandVALUE_MAX_LENGTH != 0 */
-#endif /* EXI_appHandVALUE_PARTITION_CAPACITY != 0 */
-
-	/* runtime grammars */
-	state->numberOfRuntimeGrammars = 0;
-
-	/* Avoid warning: Unused declaration of variable 'name' */
-	bits = 0;
-
-	/* encode header */
-	return writeEXIHeader(stream);
-}
-
-
-int exiappHandEncodeStartElement(bitstream_t* stream, exi_state_t* state, uint16_t qnameID) {
-	uint16_t namespaceUriID, localNameID;
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	errn = EXI_ERROR_UNEXPECTED_START_ELEMENT;
-
-	switch (currentID) {
-	case 3:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 4, 5);
-			break;
-		}
-		break;
-	case 4:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 124, 5);
-			break;
-		}
-		break;
-	case 5:
-		/* FirstStartTag[START_ELEMENT(ProtocolNamespace)] */ 
-		switch(qnameID) {
-		case 2:
-			/* SE( ProtocolNamespace ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 31, 18);
-			break;
-		}
-		break;
-	case 8:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 9, 5);
-			break;
-		}
-		break;
-	case 9:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 92, 5);
-			break;
-		}
-		break;
-	case 13:
-		/* DocContent[START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC] */ 
-		switch(qnameID) {
-		case 65:
-			/* SE( {urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 14, 15);
-			break;
-		case 66:
-			/* SE( {urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes ) */
-			errn = _exiEncodeStartElement(stream, 2, 1, state, qnameID, 14, 16);
-			break;
-		}
-		break;
-	case 15:
-		/* FirstStartTag[START_ELEMENT(AppProtocol)] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 3, 5);
-			break;
-		}
-		break;
-	case 16:
-		/* FirstStartTag[START_ELEMENT(ResponseCode)] */ 
-		switch(qnameID) {
-		case 3:
-			/* SE( ResponseCode ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 66, 44);
-			break;
-		}
-		break;
-	case 26:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 27, 5);
-			break;
-		}
-		break;
-	case 27:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 97, 5);
-			break;
-		}
-		break;
-	case 30:
-		/* Element[START_ELEMENT(ProtocolNamespace)] */ 
-		switch(qnameID) {
-		case 2:
-			/* SE( ProtocolNamespace ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 31, 18);
-			break;
-		}
-		break;
-	case 31:
-		/* Element[START_ELEMENT(VersionNumberMajor)] */ 
-		switch(qnameID) {
-		case 5:
-			/* SE( VersionNumberMajor ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 33, 46);
-			break;
-		}
-		break;
-	case 33:
-		/* Element[START_ELEMENT(VersionNumberMinor)] */ 
-		switch(qnameID) {
-		case 6:
-			/* SE( VersionNumberMinor ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 34, 35);
-			break;
-		}
-		break;
-	case 34:
-		/* Element[START_ELEMENT(SchemaID)] */ 
-		switch(qnameID) {
-		case 4:
-			/* SE( SchemaID ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 90, 45);
-			break;
-		}
-		break;
-	case 42:
-		/* FragmentContent[START_ELEMENT(AppProtocol), START_ELEMENT(Priority), START_ELEMENT(ProtocolNamespace), START_ELEMENT(ResponseCode), START_ELEMENT(SchemaID), START_ELEMENT(VersionNumberMajor), START_ELEMENT(VersionNumberMinor), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq), START_ELEMENT({urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes), START_ELEMENT_GENERIC, END_DOCUMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 4, 0, state, qnameID, 42, 5);
-			break;
-		case 1:
-			/* SE( Priority ) */
-			errn = _exiEncodeStartElement(stream, 4, 1, state, qnameID, 42, 43);
-			break;
-		case 2:
-			/* SE( ProtocolNamespace ) */
-			errn = _exiEncodeStartElement(stream, 4, 2, state, qnameID, 42, 18);
-			break;
-		case 3:
-			/* SE( ResponseCode ) */
-			errn = _exiEncodeStartElement(stream, 4, 3, state, qnameID, 42, 44);
-			break;
-		case 4:
-			/* SE( SchemaID ) */
-			errn = _exiEncodeStartElement(stream, 4, 4, state, qnameID, 42, 45);
-			break;
-		case 5:
-			/* SE( VersionNumberMajor ) */
-			errn = _exiEncodeStartElement(stream, 4, 5, state, qnameID, 42, 46);
-			break;
-		case 6:
-			/* SE( VersionNumberMinor ) */
-			errn = _exiEncodeStartElement(stream, 4, 6, state, qnameID, 42, 35);
-			break;
-		case 65:
-			/* SE( {urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq ) */
-			errn = _exiEncodeStartElement(stream, 4, 7, state, qnameID, 42, 15);
-			break;
-		case 66:
-			/* SE( {urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes ) */
-			errn = _exiEncodeStartElement(stream, 4, 8, state, qnameID, 42, 16);
-			break;
-		}
-		break;
-	case 60:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 61, 5);
-			break;
-		}
-		break;
-	case 61:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 26, 5);
-			break;
-		}
-		break;
-	case 66:
-		/* Element[START_ELEMENT(SchemaID), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 4:
-			/* SE( SchemaID ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 129, 45);
-			break;
-		}
-		break;
-	case 72:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 73, 5);
-			break;
-		}
-		break;
-	case 73:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 109, 5);
-			break;
-		}
-		break;
-	case 90:
-		/* Element[START_ELEMENT(Priority)] */ 
-		switch(qnameID) {
-		case 1:
-			/* SE( Priority ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 127, 43);
-			break;
-		}
-		break;
-	case 92:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 113, 5);
-			break;
-		}
-		break;
-	case 94:
-		/* Element[START_ELEMENT(AppProtocol)] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 3, 5);
-			break;
-		}
-		break;
-	case 97:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 39, 5);
-			break;
-		}
-		break;
-	case 109:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 110, 5);
-			break;
-		}
-		break;
-	case 110:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 60, 5);
-			break;
-		}
-		break;
-	case 113:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 115, 5);
-			break;
-		}
-		break;
-	case 115:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 72, 5);
-			break;
-		}
-		break;
-	case 117:
-		/* Element[START_ELEMENT(ResponseCode)] */ 
-		switch(qnameID) {
-		case 3:
-			/* SE( ResponseCode ) */
-			errn = _exiEncodeStartElement(stream, 1, 0, state, qnameID, 66, 44);
-			break;
-		}
-		break;
-	case 124:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 125, 5);
-			break;
-		}
-		break;
-	case 125:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 128, 5);
-			break;
-		}
-		break;
-	case 128:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */ 
-		switch(qnameID) {
-		case 0:
-			/* SE( AppProtocol ) */
-			errn = _exiEncodeStartElement(stream, 2, 0, state, qnameID, 8, 5);
-			break;
-		}
-		break;
-
-	default:
-		/* element qname not expected */
-		return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-	}
-
-	return errn;
-}
-
-
-
-int exiappHandEncodeStartElementNS(bitstream_t* stream,
-		exi_state_t* state, uint16_t namespaceUriID,
-		exi_string_ucs_t* localName) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-int exiappHandEncodeStartElementGeneric(bitstream_t* stream,
-		exi_state_t* state, exi_string_ucs_t* namespaceUri,
-		exi_string_ucs_t* localName) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-
-int exiappHandEncodeEndElement(bitstream_t* stream, exi_state_t* state) {
-	int errn = 0;
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	switch (currentID) {
-	case 22:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 50:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		errn = encodeNBitUnsignedInteger(stream, 3, 2);
-		break;
-	case 2:
-		/* Element[END_ELEMENT] */
-	case 39:
-		/* Element[END_ELEMENT] */
-	case 127:
-		/* Element[END_ELEMENT] */
-	case 129:
-		/* Element[END_ELEMENT] */
-		errn = encodeNBitUnsignedInteger(stream, 1, 0);
-		break;
-	case 3:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 8:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 26:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 60:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 72:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 23:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 9:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 97:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 109:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 92:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 115:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 124:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 27:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 51:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-	case 128:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 66:
-		/* Element[START_ELEMENT(SchemaID), END_ELEMENT] */
-	case 110:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 61:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 113:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 4:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 125:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-	case 73:
-		/* Element[START_ELEMENT(AppProtocol), END_ELEMENT] */
-		errn = encodeNBitUnsignedInteger(stream, 2, 1);
-		break;
-
-	default:
-		return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-	}
-
-	if (errn < 0) {
-		return errn;
-	}
-
-	/* pop item */
-	return exi_appHand_PopStack(state);
-}
-
-
-
-int exiappHandEncodeCharacters(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	int16_t moveOnID = 0;
-	int deviantChars = 0;
-
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	switch (currentID) {
-		case 43:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = _encodeNBitIntegerValue(stream, &val->integer, 5, 1);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 65:
-	case 95:
-	case 140:
-		/* Element[CHARACTERS[LIST]] */
-		if (val->type == EXI_DATATYPE_LIST) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeUnsignedInteger32(stream, val->list.len);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 51:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		if (val->type == EXI_DATATYPE_STRING) {
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			errn = encodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 51;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 2, 3);
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			deviantChars = 1;
-		}
-		break;
-	case 37:
-		/* Element[CHARACTERS[BOOLEAN]] */
-		if (val->type == EXI_DATATYPE_BOOLEAN) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeBoolean(stream, val->boolean);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 56:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = _encodeNBitIntegerValue(stream, &val->integer, 8, -128);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 19:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = _encodeNBitIntegerValue(stream, &val->integer, 5, 1);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 44:
-		/* FirstStartTag[CHARACTERS[ENUMERATION]] */
-		if (val->type == EXI_DATATYPE_ENUMERATION) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeNBitUnsignedInteger(stream, 2, val->enumeration);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 53:
-		/* FirstStartTag[CHARACTERS[DECIMAL]] */
-		if (val->type == EXI_DATATYPE_DECIMAL) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeDecimal(stream, &val->decimal);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 11:
-	case 130:
-		/* FirstStartTag[CHARACTERS[FLOAT]] */
-		if (val->type == EXI_DATATYPE_FLOAT) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeFloat(stream, &val->float_me);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 116:
-		/* Element[CHARACTERS[DECIMAL]] */
-		if (val->type == EXI_DATATYPE_DECIMAL) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeDecimal(stream, &val->decimal);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 25:
-	case 29:
-	case 144:
-		/* FirstStartTag[CHARACTERS[LIST]] */
-		if (val->type == EXI_DATATYPE_LIST) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeUnsignedInteger32(stream, val->list.len);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 50:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		if (val->type == EXI_DATATYPE_STRING) {
-			encodeNBitUnsignedInteger(stream, 3, 3);
-			errn = encodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 51;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 3, 4);
-			encodeNBitUnsignedInteger(stream, 3, 5);
-			deviantChars = 1;
-		}
-		break;
-	case 46:
-	case 35:
-		/* First(xsi:type)StartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeUnsignedInteger(stream, &val->integer);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 12:
-	case 32:
-	case 38:
-	case 40:
-	case 41:
-	case 54:
-	case 67:
-	case 70:
-	case 77:
-	case 85:
-	case 87:
-	case 96:
-	case 114:
-	case 118:
-	case 120:
-	case 131:
-	case 137:
-		/* Element[CHARACTERS[STRING]] */
-		if (val->type == EXI_DATATYPE_STRING) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 23:
-		/* Element[START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		if (val->type == EXI_DATATYPE_STRING) {
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			errn = encodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 23;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 2, 3);
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			deviantChars = 1;
-		}
-		break;
-	case 111:
-		/* FirstStartTag[CHARACTERS[BINARY_BASE64]] */
-		if (val->type == EXI_DATATYPE_BINARY_BASE64) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeBinary(stream, &val->binary);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 28:
-		/* Element[CHARACTERS[BINARY_HEX]] */
-		if (val->type == EXI_DATATYPE_BINARY_HEX) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeBinary(stream, &val->binary);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 17:
-	case 47:
-	case 83:
-	case 91:
-	case 107:
-	case 136:
-		/* Element[CHARACTERS[INTEGER]] */
-		if (val->type == EXI_DATATYPE_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeInteger(stream, &val->integer);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 62:
-	case 103:
-		/* Element[CHARACTERS[FLOAT]] */
-		if (val->type == EXI_DATATYPE_FLOAT) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeFloat(stream, &val->float_me);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 52:
-		/* Element[CHARACTERS[BINARY_BASE64]] */
-		if (val->type == EXI_DATATYPE_BINARY_BASE64) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeBinary(stream, &val->binary);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 132:
-		/* FirstStartTag[CHARACTERS[BINARY_HEX]] */
-		if (val->type == EXI_DATATYPE_BINARY_HEX) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeBinary(stream, &val->binary);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 7:
-	case 21:
-	case 49:
-	case 57:
-	case 102:
-		/* FirstStartTag[CHARACTERS[UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeUnsignedInteger(stream, &val->integer);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 45:
-	case 122:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = _encodeNBitIntegerValue(stream, &val->integer, 8, 0);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 64:
-	case 74:
-	case 99:
-	case 100:
-	case 104:
-	case 112:
-	case 133:
-	case 135:
-		/* FirstStartTag[CHARACTERS[DATETIME]] */
-		if (val->type == EXI_DATATYPE_DATETIME) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeDateTime(stream, &val->datetime);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 1:
-	case 75:
-		/* Element[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = _encodeNBitIntegerValue(stream, &val->integer, 8, 0);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 68:
-	case 69:
-	case 76:
-	case 89:
-	case 93:
-	case 138:
-		/* FirstStartTag[CHARACTERS[INTEGER]] */
-		if (val->type == EXI_DATATYPE_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeInteger(stream, &val->integer);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 134:
-		/* FirstStartTag[CHARACTERS[NBIT_UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = _encodeNBitIntegerValue(stream, &val->integer, 8, -128);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 71:
-		/* Element[CHARACTERS[ENUMERATION]] */
-		if (val->type == EXI_DATATYPE_ENUMERATION) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeNBitUnsignedInteger(stream, 2, val->enumeration);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 59:
-	case 81:
-	case 108:
-	case 119:
-	case 145:
-		/* Element[CHARACTERS[UNSIGNED_INTEGER]] */
-		if (val->type == EXI_DATATYPE_UNSIGNED_INTEGER) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeUnsignedInteger(stream, &val->integer);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 80:
-		/* FirstStartTag[CHARACTERS[BOOLEAN]] */
-		if (val->type == EXI_DATATYPE_BOOLEAN) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeBoolean(stream, val->boolean);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 63:
-	case 82:
-	case 84:
-	case 88:
-	case 121:
-	case 123:
-	case 126:
-	case 139:
-		/* Element[CHARACTERS[DATETIME]] */
-		if (val->type == EXI_DATATYPE_DATETIME) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeDateTime(stream, &val->datetime);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 2, 2);
-			deviantChars = 1;
-		}
-		break;
-	case 10:
-	case 18:
-	case 20:
-	case 24:
-	case 36:
-	case 48:
-	case 55:
-	case 58:
-	case 78:
-	case 79:
-	case 86:
-	case 98:
-	case 101:
-	case 106:
-	case 141:
-	case 142:
-	case 143:
-		/* FirstStartTag[CHARACTERS[STRING]] */
-		if (val->type == EXI_DATATYPE_STRING) {
-			encodeNBitUnsignedInteger(stream, 1, 0);
-			errn = encodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 2;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 1, 1);
-			encodeNBitUnsignedInteger(stream, 3, 6);
-			deviantChars = 1;
-		}
-		break;
-	case 22:
-		/* FirstStartTag[ATTRIBUTE_GENERIC, START_ELEMENT_GENERIC, END_ELEMENT, CHARACTERS_GENERIC[STRING]] */
-		if (val->type == EXI_DATATYPE_STRING) {
-			encodeNBitUnsignedInteger(stream, 3, 3);
-			errn = encodeStringValue(stream, state, state->elementStack[state->stackIndex], &val->str);
-			moveOnID = 23;
-		} else { 
-			/* deviant characters */ 
-			encodeNBitUnsignedInteger(stream, 3, 4);
-			encodeNBitUnsignedInteger(stream, 3, 5);
-			deviantChars = 1;
-		}
-		break;
-
-	default:
-		return EXI_ERROR_UNEXPECTED_CHARACTERS;
-	}
-
-	if (currentID < 0) {
-		/* TODO runtime rules */
-		errn = EXI_ERROR_UNEXPECTED_CHARACTERS;
-	} else if (deviantChars) {
-		return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-	} else {
-		/* move on */
-		state->grammarStack[state->stackIndex] = moveOnID;
-	}
-
-	return errn;
-}
-
-
-int exiappHandEncodeAttribute(bitstream_t* stream, exi_state_t* state, uint16_t qnameID,
-		exi_value_t* val) {
-	int16_t moveOnID = 0;
-	int16_t currentID = state->grammarStack[state->stackIndex];
-	errn = EXI_ERROR_UNEXPECTED_ATTRIBUTE;
-
-	switch (currentID) {
-
-	}
-
-	/* no expected attribute */
-	if (currentID < 0) {
-		/* runtime element */
-		errn = _encode2ndLevelAttribute(stream, state, qnameID, val);
-	} else {
-		if(moveOnID == 0) {
-			/* no action yet */
-#if EXI_appHandSTRICT != 0
-			/* no 2nd level events in strict mode for schema-informed grammars */
-			errn = EXI_ERROR_UNEXPECTED_ATTRIBUTE;
-#else /* EXI_appHandSTRICT != 0 */
-			errn = _encode2ndLevelAttribute(stream, state, qnameID, val);
-#endif /* EXI_appHandSTRICT != 0 */
-		} else {
-			state->grammarStack[state->stackIndex] = moveOnID;
-		}
-	}
-
-	return errn;
-}
-
-
-int exiappHandEncodeAttributeNS(bitstream_t* stream,
-		exi_state_t* state, uint16_t namespaceUriID,
-		exi_string_ucs_t* localName, exi_value_t* val) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-int exiappHandEncodeAttributeGeneric(bitstream_t* stream,
-		exi_state_t* state, exi_string_ucs_t* namespaceUri,
-		exi_string_ucs_t* localName, exi_value_t* val) {
-	return EXI_DEVIANT_SUPPORT_NOT_DEPLOYED;
-}
-
-
-int exiappHandEncodeAttributeXsiNil(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-
-	switch (state->grammarStack[state->stackIndex]) {
-
-	}
-
-	if (errn < 0) {
-		return errn;
-	}
-
-	errn = encodeBoolean(stream, val->boolean);
-	if (!errn && val->boolean) {
-		/* handle xsi:nil == true */
-		 errn = exi_appHand_HandleXsiNilTrue(state);
-	}
-	return errn;
-}
-
-
-
-int exiappHandEncodeAttributeXsiType(bitstream_t* stream, exi_state_t* state,
-		exi_value_t* val) {
-	/* encode xsi:type event code */
-	switch (state->grammarStack[state->stackIndex]) {
-	case 46:
-		errn = encodeNBitUnsignedInteger(stream, 1, 1);
-		if(errn) return errn;
-		errn = encodeNBitUnsignedInteger(stream, 3, 1);
-		break;
-	case 35:
-		errn = encodeNBitUnsignedInteger(stream, 1, 1);
-		if(errn) return errn;
-		errn = encodeNBitUnsignedInteger(stream, 3, 1);
-		break;
-
-	default:
-		return EXI_ERROR_UNEXPECTED_ATTRIBUTE_XSI_TYPE;
-	}
-	if (errn) {
-		return errn;
-	}
-
-	/* encode qname */
-	errn = _encodeAttributeXsiTypeContent(stream, state, val);
-
-	return errn;
-}
-
-
-
-
-#endif
-

+ 0 - 271
src/codec/appHandCodec/appHandEXIEncoder.h

@@ -1,271 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI_appHand_ENCODER_H
-#define EXI_appHand_ENCODER_H
-
-/**
-* \file 	EXIEncoder.h
-* \brief 	EXI Encoder
-*
-*/
-
-#include "EXITypes.h"
-#include "appHandEXIEncoder.h"
-
-/**
- * \brief 	Initialize EXI encoder
- *
- *         	Resets & initializes the EXI encoder.
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       runtimeTable   	Runtime name-tables
- * \param       stringTable   	String table
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandInitEncoder(bitstream_t* stream, exi_state_t* state,
-		exi_name_table_runtime_t runtimeTable, exi_string_table_t stringTable);
-
-/**
- * \brief  	Reports the beginning of a set of XML events
- *
- *			see EXI StartDocument (SD) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeStartDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief  	Reports the end of a set of XML events
- *
- *			see EXI EndDocument (ED) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeEndDocument(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief  	Supplies the start of a known element
- *
- *			Provides access to the namespace URI and local name of the start tag by providing qnameID.
- *			Note: Both, namespace URI and local name are known (schema-informed) or have been encoded before.
- *			see EXI StartElement (SE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		qualified name ID
- * \return                  	Error-Code <> 0
- *
- */
-int
-exiappHandEncodeStartElement(bitstream_t* stream,
-		exi_state_t* state, uint16_t qnameID);
-
-/**
- * \brief  	Supplies the start of an element where the namespace is known
- *
- *			Note: Namespace URI is known (schema-informed) or has been encoded before while local name is unknown.
- *			see EXI StartElement (SE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUriID  namespace URI ID
- * \param       localName  		local name as string
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeStartElementNS(bitstream_t* stream,
-		exi_state_t* state, uint16_t namespaceUriID,
-		exi_string_ucs_t* localName);
-
-/**
- * \brief  	Supplies the start of an element where the namespace and the local name is unknown
- *
- *			Note: Neither namespace URI nor local name is known.
- *			see EXI StartElement (SE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUri  	namespace URI as string
- * \param       localName  		local name as string
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeStartElementGeneric(bitstream_t* stream,
-		exi_state_t* state, exi_string_ucs_t* namespaceUri,
-		exi_string_ucs_t* localName);
-
-/**
- * \brief  	Supplies the end tag of an element
- *
- *			see EXI EndElement (EE) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeEndElement(bitstream_t* stream,
-		exi_state_t* state);
-
-/**
- * \brief  	Supplies characters value
- *
- *			Note: Special handling for list value.
- *			see EXI Characters (CH) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       val   			Characters value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeCharacters(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-/**
- * \brief  	Supplies an attribute qname and value
- *
- *			Note: Special handling for list value.
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		qualified name ID
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeAttribute(bitstream_t* stream,
-		exi_state_t* state, uint16_t qnameID, exi_value_t* val);
-
-
-
-
-/**
- * \brief  	Supplies an attribute qname and value where the namespace is known
- *
- *			Note: Special handling for list value.
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUriID  Qualified namespace URI ID
- * \param       localName  		Qualified localname as String
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeAttributeNS(bitstream_t* stream,
-		exi_state_t* state, uint16_t namespaceUriID,
-		exi_string_ucs_t* localName, exi_value_t* val);
-
-
-/**
- * \brief  	Supplies an attribute qname and value where the namespace and the local name is unknown
- *
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       namespaceUri  	namespace URI as string
- * \param       localName  		local name as string
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeAttributeGeneric(bitstream_t* stream,
-		exi_state_t* state, exi_string_ucs_t* namespaceUri,
-		exi_string_ucs_t* localName, exi_value_t* val);
-
-
-
-/**
- * \brief  	Supplies an xsi:nil attribute
- *
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeAttributeXsiNil(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-/**
- * \brief  	Supplies an xsi:type attribute
- *
- *			see EXI Attribute (AT) event
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       val   			Attribute value
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeAttributeXsiType(bitstream_t* stream,
-		exi_state_t* state, exi_value_t* val);
-
-/**
- * \brief  	Supplies list value for characters and attribute event
- *
- *			List values are special given that first the number and type of entry needs to be passed (element/attribute event) and then one by one the actual values.
- *
- * \param       stream   		Output Stream
- * \param       state   		Codec state
- * \param       qnameID   		qualified name ID
- * \param       val   			one list value
- * \param       lt   			list type
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandEncodeListValue(bitstream_t* stream,
-		exi_state_t* state, uint16_t qnameID, exi_value_t* val, exi_list_t lt);
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-

+ 0 - 98
src/codec/appHandCodec/appHandNameTableEntries.c

@@ -1,98 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_NAME_TABLE_ENTRIES_C
-#define EXI_appHand_NAME_TABLE_ENTRIES_C
-
-#include "appHandNameTableEntries.h"
-
-
-
-/* ==================================== */
-/* String Table Population */
-
-/* localName entries for URI '', id = 0 */
-/* 
-  "AppProtocol",  "Priority",  "ProtocolNamespace",  "ResponseCode",  "SchemaID",
-  "VersionNumberMajor",  "VersionNumberMinor"
- */
-
-/* localName entries for URI 'http://www.w3.org/XML/1998/namespace', id = 1 */
-/* 
-  "base",  "id",  "lang",  "space"
- */
-
-/* localName entries for URI 'http://www.w3.org/2001/XMLSchema-instance', id = 2 */
-/* 
-  "nil",  "type"
- */
-
-/* localName entries for URI 'http://www.w3.org/2001/XMLSchema', id = 3 */
-/* 
-  "ENTITIES",  "ENTITY",  "ID",  "IDREF",  "IDREFS",
-  "NCName",  "NMTOKEN",  "NMTOKENS",  "NOTATION",  "Name",
-  "QName",  "anySimpleType",  "anyType",  "anyURI",  "base64Binary",
-  "boolean",  "byte",  "date",  "dateTime",  "decimal",
-  "double",  "duration",  "float",  "gDay",  "gMonth",
-  "gMonthDay",  "gYear",  "gYearMonth",  "hexBinary",  "int",
-  "integer",  "language",  "long",  "negativeInteger",  "nonNegativeInteger",
-  "nonPositiveInteger",  "normalizedString",  "positiveInteger",  "short",  "string",
-  "time",  "token",  "unsignedByte",  "unsignedInt",  "unsignedLong",
-  "unsignedShort"
- */
-
-/* localName entries for URI 'urn:iso:15118:2:2010:AppProtocol', id = 4 */
-/* 
-  "AppProtocolType",  "idType",  "priorityType",  "protocolNameType",  "protocolNamespaceType",
-  "responseCodeType",  "supportedAppProtocolReq",  "supportedAppProtocolRes"
- */
-
-
-/* number of local-name entries per URI */
-static uint16_t localNames[5] = {
-	/* '' */
-	7,
-	/* 'http://www.w3.org/XML/1998/namespace' */
-	4,
-	/* 'http://www.w3.org/2001/XMLSchema-instance' */
-	2,
-	/* 'http://www.w3.org/2001/XMLSchema' */
-	46,
-	/* 'urn:iso:15118:2:2010:AppProtocol' */
-	8
-};
-
-
-exi_name_table_prepopulated_t exiappHandNameTablePrepopulated = { 5, localNames };
-
-
-
-
-#endif
-

+ 0 - 41
src/codec/appHandCodec/appHandNameTableEntries.h

@@ -1,41 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_NAME_TABLE_ENTRIES_H
-#define EXI_appHand_NAME_TABLE_ENTRIES_H
-
-#include "EXITypes.h"
-
-/* ==================================== */
-/* String Table Population */
-
-extern exi_name_table_prepopulated_t exiappHandNameTablePrepopulated;
-
-#endif
-

+ 0 - 51
src/codec/appHandCodec/appHandQNameDefines.h

@@ -1,51 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI_appHand_QNAME_DEFINES_H
-#define EXI_appHand_QNAME_DEFINES_H
-
-/** Number of pre-populated qnames */
-#define EXI_appHandNUMBER_OF_PREPOPULATED_QNAMES 67
-
-/** Number of runtime qnames */
-#define EXI_appHandMAX_NUMBER_OF_SUPPORTED_RUNTIMES_QNAMES 100
-
-/** Number of overall qnames (pre-populated from schema and runtime qnames) */
-#define EXI_appHandMAX_NUMBER_OF_QNAMES (EXI_appHandNUMBER_OF_PREPOPULATED_QNAMES + EXI_appHandMAX_NUMBER_OF_SUPPORTED_RUNTIMES_QNAMES)
-
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 223
src/codec/appHandCodec/appHandQNames.c

@@ -1,223 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_QNAMES_C
-#define EXI_appHand_QNAMES_C
-
-#include "EXITypes.h"
-#include "ErrorCodes.h"
-#include "appHandQNameDefines.h"
-
-/* qname is a composition of namespaceURI(ID) and localPart(ID) */
-static exi_eqname_t qnames[EXI_appHandMAX_NUMBER_OF_QNAMES] = {
-	/* qnameID == 0: AppProtocol */
-	{0, 0},
-	/* qnameID == 1: Priority */
-	{0, 1},
-	/* qnameID == 2: ProtocolNamespace */
-	{0, 2},
-	/* qnameID == 3: ResponseCode */
-	{0, 3},
-	/* qnameID == 4: SchemaID */
-	{0, 4},
-	/* qnameID == 5: VersionNumberMajor */
-	{0, 5},
-	/* qnameID == 6: VersionNumberMinor */
-	{0, 6},
-	/* qnameID == 7: {http://www.w3.org/XML/1998/namespace}base */
-	{1, 0},
-	/* qnameID == 8: {http://www.w3.org/XML/1998/namespace}id */
-	{1, 1},
-	/* qnameID == 9: {http://www.w3.org/XML/1998/namespace}lang */
-	{1, 2},
-	/* qnameID == 10: {http://www.w3.org/XML/1998/namespace}space */
-	{1, 3},
-	/* qnameID == 11: {http://www.w3.org/2001/XMLSchema-instance}nil */
-	{2, 0},
-	/* qnameID == 12: {http://www.w3.org/2001/XMLSchema-instance}type */
-	{2, 1},
-	/* qnameID == 13: {http://www.w3.org/2001/XMLSchema}ENTITIES */
-	{3, 0},
-	/* qnameID == 14: {http://www.w3.org/2001/XMLSchema}ENTITY */
-	{3, 1},
-	/* qnameID == 15: {http://www.w3.org/2001/XMLSchema}ID */
-	{3, 2},
-	/* qnameID == 16: {http://www.w3.org/2001/XMLSchema}IDREF */
-	{3, 3},
-	/* qnameID == 17: {http://www.w3.org/2001/XMLSchema}IDREFS */
-	{3, 4},
-	/* qnameID == 18: {http://www.w3.org/2001/XMLSchema}NCName */
-	{3, 5},
-	/* qnameID == 19: {http://www.w3.org/2001/XMLSchema}NMTOKEN */
-	{3, 6},
-	/* qnameID == 20: {http://www.w3.org/2001/XMLSchema}NMTOKENS */
-	{3, 7},
-	/* qnameID == 21: {http://www.w3.org/2001/XMLSchema}NOTATION */
-	{3, 8},
-	/* qnameID == 22: {http://www.w3.org/2001/XMLSchema}Name */
-	{3, 9},
-	/* qnameID == 23: {http://www.w3.org/2001/XMLSchema}QName */
-	{3, 10},
-	/* qnameID == 24: {http://www.w3.org/2001/XMLSchema}anySimpleType */
-	{3, 11},
-	/* qnameID == 25: {http://www.w3.org/2001/XMLSchema}anyType */
-	{3, 12},
-	/* qnameID == 26: {http://www.w3.org/2001/XMLSchema}anyURI */
-	{3, 13},
-	/* qnameID == 27: {http://www.w3.org/2001/XMLSchema}base64Binary */
-	{3, 14},
-	/* qnameID == 28: {http://www.w3.org/2001/XMLSchema}boolean */
-	{3, 15},
-	/* qnameID == 29: {http://www.w3.org/2001/XMLSchema}byte */
-	{3, 16},
-	/* qnameID == 30: {http://www.w3.org/2001/XMLSchema}date */
-	{3, 17},
-	/* qnameID == 31: {http://www.w3.org/2001/XMLSchema}dateTime */
-	{3, 18},
-	/* qnameID == 32: {http://www.w3.org/2001/XMLSchema}decimal */
-	{3, 19},
-	/* qnameID == 33: {http://www.w3.org/2001/XMLSchema}double */
-	{3, 20},
-	/* qnameID == 34: {http://www.w3.org/2001/XMLSchema}duration */
-	{3, 21},
-	/* qnameID == 35: {http://www.w3.org/2001/XMLSchema}float */
-	{3, 22},
-	/* qnameID == 36: {http://www.w3.org/2001/XMLSchema}gDay */
-	{3, 23},
-	/* qnameID == 37: {http://www.w3.org/2001/XMLSchema}gMonth */
-	{3, 24},
-	/* qnameID == 38: {http://www.w3.org/2001/XMLSchema}gMonthDay */
-	{3, 25},
-	/* qnameID == 39: {http://www.w3.org/2001/XMLSchema}gYear */
-	{3, 26},
-	/* qnameID == 40: {http://www.w3.org/2001/XMLSchema}gYearMonth */
-	{3, 27},
-	/* qnameID == 41: {http://www.w3.org/2001/XMLSchema}hexBinary */
-	{3, 28},
-	/* qnameID == 42: {http://www.w3.org/2001/XMLSchema}int */
-	{3, 29},
-	/* qnameID == 43: {http://www.w3.org/2001/XMLSchema}integer */
-	{3, 30},
-	/* qnameID == 44: {http://www.w3.org/2001/XMLSchema}language */
-	{3, 31},
-	/* qnameID == 45: {http://www.w3.org/2001/XMLSchema}long */
-	{3, 32},
-	/* qnameID == 46: {http://www.w3.org/2001/XMLSchema}negativeInteger */
-	{3, 33},
-	/* qnameID == 47: {http://www.w3.org/2001/XMLSchema}nonNegativeInteger */
-	{3, 34},
-	/* qnameID == 48: {http://www.w3.org/2001/XMLSchema}nonPositiveInteger */
-	{3, 35},
-	/* qnameID == 49: {http://www.w3.org/2001/XMLSchema}normalizedString */
-	{3, 36},
-	/* qnameID == 50: {http://www.w3.org/2001/XMLSchema}positiveInteger */
-	{3, 37},
-	/* qnameID == 51: {http://www.w3.org/2001/XMLSchema}short */
-	{3, 38},
-	/* qnameID == 52: {http://www.w3.org/2001/XMLSchema}string */
-	{3, 39},
-	/* qnameID == 53: {http://www.w3.org/2001/XMLSchema}time */
-	{3, 40},
-	/* qnameID == 54: {http://www.w3.org/2001/XMLSchema}token */
-	{3, 41},
-	/* qnameID == 55: {http://www.w3.org/2001/XMLSchema}unsignedByte */
-	{3, 42},
-	/* qnameID == 56: {http://www.w3.org/2001/XMLSchema}unsignedInt */
-	{3, 43},
-	/* qnameID == 57: {http://www.w3.org/2001/XMLSchema}unsignedLong */
-	{3, 44},
-	/* qnameID == 58: {http://www.w3.org/2001/XMLSchema}unsignedShort */
-	{3, 45},
-	/* qnameID == 59: {urn:iso:15118:2:2010:AppProtocol}AppProtocolType */
-	{4, 0},
-	/* qnameID == 60: {urn:iso:15118:2:2010:AppProtocol}idType */
-	{4, 1},
-	/* qnameID == 61: {urn:iso:15118:2:2010:AppProtocol}priorityType */
-	{4, 2},
-	/* qnameID == 62: {urn:iso:15118:2:2010:AppProtocol}protocolNameType */
-	{4, 3},
-	/* qnameID == 63: {urn:iso:15118:2:2010:AppProtocol}protocolNamespaceType */
-	{4, 4},
-	/* qnameID == 64: {urn:iso:15118:2:2010:AppProtocol}responseCodeType */
-	{4, 5},
-	/* qnameID == 65: {urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolReq */
-	{4, 6},
-	/* qnameID == 66: {urn:iso:15118:2:2010:AppProtocol}supportedAppProtocolRes */
-	{4, 7}
-
-};
-
-
-int exiappHandGetEQName(exi_state_t* state, uint16_t qnameID, uint16_t* namespaceURI, uint16_t* localPart) {
-	int errn = 0;
-	/* EXI_appHandNUMBER_OF_QNAMES */
-	if (qnameID < state->nextQNameID) {
-		*namespaceURI = qnames[qnameID].namespaceURI;
-		*localPart = qnames[qnameID].localPart;
-	} else {
-		errn = EXI_ERROR_OUT_OF_BOUNDS;
-	}
-	return errn;
-}
-
-
-int exiappHandGetQNameID(exi_state_t* state, uint16_t namespaceURI, uint16_t localPart, uint16_t* qnameID) {
-	uint16_t i;
-	/* TODO Do something more efficient than just walk over the entire list */
-	/* EXI_appHandNUMBER_OF_QNAMES */
-	for(i=0; i<state->nextQNameID; i++) {
-		if(qnames[i].localPart == localPart && qnames[i].namespaceURI == namespaceURI) {
-			*qnameID = i;
-			return 0;
-		}
-	}
-
-	return EXI_ERROR_OUT_OF_BOUNDS;
-}
-
-
-int exiappHandAddEQName(exi_state_t* state, uint16_t* qnameID, uint16_t namespaceURI, uint16_t localPart) {
-	int errn = 0;
-	if(state->nextQNameID < (EXI_appHandMAX_NUMBER_OF_QNAMES -1)) {
-		/* store IDs */
-		qnames[state->nextQNameID].namespaceURI = namespaceURI;
-		qnames[state->nextQNameID].localPart = localPart;
-		/* increment counter */
-		*qnameID = state->nextQNameID++;
-	} else {
-		errn = EXI_ERROR_OUT_OF_BOUNDS;
-	}
-
-
-	return errn;
-}
-
-
-#endif
-

+ 0 - 74
src/codec/appHandCodec/appHandQNames.h

@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-#ifndef EXI_appHand_QNAMES_H
-#define EXI_appHand_QNAMES_H
-
-#include "EXITypes.h"
-
-/**
- * \brief  	Returns efficient qname (namespaceURI & localName) IDs for qnameID
- *
- * \param       state		   	Codec state
- * \param       qnameID		   	Qualified name ID
- * \param       namespaceURI	QName namespace URI ID
- * \param       localPart		QName local name ID
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandGetEQName(exi_state_t* state, uint16_t qnameID, uint16_t* namespaceURI, uint16_t* localPart);
-
-
-/**
- * \brief  	Returns qnameID for qname namespaceURI & localName
- *
- * \param       state		   	Codec state
- * \param       namespaceURI	QName namespace URI ID
- * \param       localPart		QName local name ID
- * \param       qnameID		   	QName ID (out)
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandGetQNameID(exi_state_t* state, uint16_t namespaceURI, uint16_t localPart, uint16_t* qnameID);
-
-
-/**
- * \brief  	Add  efficient qname (namespaceURI & localName) IDs for qnameID
- *
- * \param       state		   	Codec state
- * \param       qnameID		   	Qualified name ID
- * \param       namespaceURI	QName namespace URI ID
- * \param       localPart		QName local name ID
- * \return                  	Error-Code <> 0
- *
- */
-int exiappHandAddEQName(exi_state_t* state, uint16_t* qnameID, uint16_t namespaceURI, uint16_t localPart);
-
-#endif
-

+ 0 - 844
src/service/v2g_dataTypes.c

@@ -1,844 +0,0 @@
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-#include "EXITypes.h"
-#include "v2g_dataTypes.h"
-
-
-static  void init_sessionIDType(struct sessionIDType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_faultMsgType(struct faultMsgType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_NotificationType(struct NotificationType* type)
-{		
-	init_faultMsgType(&(type->FaultMsg));	
-	type->isused.FaultMsg=0;
-
-}
-
-static  void init_service_string(struct service_string* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_CanonicalizationMethodType(struct CanonicalizationMethodType* type)
-{	
-	init_service_string(&(type->attr_Algorithm));
-
-}
-
-static  void init_SignatureMethodType(struct SignatureMethodType* type)
-{	
-	init_service_string(&(type->attr_Algorithm));
-
-}
-
-static  void init_DigestMethodType(struct DigestMethodType* type)
-{	
-	init_service_string(&(type->attr_Algorithm));
-
-}
-
-static  void init_DigestValueType(struct DigestValueType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_ReferenceType(struct ReferenceType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_service_string(&(type->attr_URI));	
-	type->isused.attr_URI=0;	
-	init_service_string(&(type->attr_Type));	
-	type->isused.attr_Type=0;	
-	init_DigestMethodType(&(type->DigestMethod));	
-	init_DigestValueType(&(type->DigestValue));
-
-}
-
-static  void init_SignedInfoType(struct SignedInfoType* type)
-{
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_CanonicalizationMethodType(&(type->CanonicalizationMethod));	
-	init_SignatureMethodType(&(type->SignatureMethod));	
-	init_ReferenceType(&(type->Reference[0]));
-
-	type->arraylen.Reference=0;
-}
-
-static  void init_SignatureValueType(struct SignatureValueType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_X509IssuerSerialType(struct X509IssuerSerialType* type)
-{	
-	init_service_string(&(type->X509IssuerName));	
-
-}
-
-static  void init_service_byte(struct service_byte* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_X509DataType(struct X509DataType* type)
-{	
-	init_X509IssuerSerialType(&(type->X509IssuerSerial));	
-	init_service_byte(&(type->X509SKI));	
-	init_service_string(&(type->X509SubjectName));	
-	init_service_byte(&(type->X509Certificate));	
-	init_service_byte(&(type->X509CRL));
-
-}
-
-static  void init_KeyInfoType(struct KeyInfoType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_X509DataType(&(type->X509Data));
-
-}
-
-static  void init_SignatureType(struct SignatureType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_SignedInfoType(&(type->SignedInfo));	
-	init_SignatureValueType(&(type->SignatureValue));	
-	init_KeyInfoType(&(type->KeyInfo));	
-	type->isused.KeyInfo=0;
-
-}
-
-static  void init_MessageHeaderType(struct MessageHeaderType* type)
-{	
-	init_sessionIDType(&(type->SessionID));	
-	init_NotificationType(&(type->Notification));	
-	type->isused.Notification=0;		
-	type->isused.Signature=0;
-
-}
-
-static  void init_evccIDType(struct evccIDType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_SessionSetupReqType(struct SessionSetupReqType* type)
-{	
-	init_evccIDType(&(type->EVCCID));
-
-}
-
-static  void init_evseIDType(struct evseIDType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_SessionSetupResType(struct SessionSetupResType* type)
-{		
-	init_evseIDType(&(type->EVSEID));		
-	type->isused.DateTimeNow=0;
-
-}
-
-static  void init_serviceScopeType(struct serviceScopeType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_ServiceDiscoveryReqType(struct ServiceDiscoveryReqType* type)
-{	
-	init_serviceScopeType(&(type->ServiceScope));	
-	type->isused.ServiceScope=0;		
-	type->isused.ServiceCategory=0;
-
-}
-
-static  void init_PaymentOptionsType(struct PaymentOptionsType* type)
-{
-
-	type->arraylen.PaymentOption=0;
-
-}
-
-static  void init_serviceNameType(struct serviceNameType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_ServiceTagType(struct ServiceTagType* type)
-{		
-	init_serviceNameType(&(type->ServiceName));	
-	type->isused.ServiceName=0;		
-	init_serviceScopeType(&(type->ServiceScope));	
-	type->isused.ServiceScope=0;
-
-}
-
-static  void init_ServiceChargeType(struct ServiceChargeType* type)
-{	
-	init_ServiceTagType(&(type->ServiceTag));		
-
-}
-
-static  void init_ServiceType(struct ServiceType* type)
-{	
-	init_ServiceTagType(&(type->ServiceTag));	
-
-}
-
-static  void init_ServiceTagListType(struct ServiceTagListType* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<3;i_loop++)
-	{
-		init_ServiceType(&(type->Service[i_loop]));
-	}
-	
-	type->arraylen.Service=0;
-
-}
-
-static void init_ServiceDiscoveryResType(struct ServiceDiscoveryResType* type)
-{		
-	init_PaymentOptionsType(&(type->PaymentOptions));	
-	init_ServiceChargeType(&(type->ChargeService));	
-	init_ServiceTagListType(&(type->ServiceList));	
-	type->isused.ServiceList=0;
-
-}
-
-static  void init_PhysicalValueType(struct PhysicalValueType* type)
-{			
-	type->isused.Unit=0;	
-
-}
-
-static  void init_ParameterType(struct ParameterType* type)
-{	
-	init_service_string(&(type->attr_Name));	
-	init_service_string(&(type->attr_ValueType));					
-	init_PhysicalValueType(&(type->physicalValue));	
-	init_service_string(&(type->stringValue));
-
-}
-
-static  void init_ParameterSetType(struct ParameterSetType* type)
-{
-	int i_loop;
-			
-	for(i_loop=0; i_loop<2;i_loop++)
-	{
-		init_ParameterType(&(type->Parameter[i_loop]));
-	}
-	
-	type->arraylen.Parameter=0;
-
-}
-
-static  void init_ServiceParameterListType(struct ServiceParameterListType* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<2;i_loop++)
-	{
-		init_ParameterSetType(&(type->ParameterSet[i_loop]));
-	}
-	
-	type->arraylen.ParameterSet=0;
-
-}
-
-static  void init_ServiceDetailResType(struct ServiceDetailResType* type)
-{			
-	init_ServiceParameterListType(&(type->ServiceParameterList));	
-	type->isused.ServiceParameterList=0;
-
-}
-
-static  void init_SelectedServiceType(struct SelectedServiceType* type)
-{			
-	type->isused.ParameterSetID=0;
-
-}
-
-static  void init_SelectedServiceListType(struct SelectedServiceListType* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<2;i_loop++)
-	{
-		init_SelectedServiceType(&(type->SelectedService[i_loop]));
-	}
-	
-	type->arraylen.SelectedService=0;
-
-}
-
-static  void init_ServicePaymentSelectionReqType(struct ServicePaymentSelectionReqType* type)
-{		
-	init_SelectedServiceListType(&(type->SelectedServiceList));
-
-}
-
-static  void init_contractIDType(struct contractIDType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_certificateType(struct certificateType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_SubCertificatesType(struct SubCertificatesType* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<4;i_loop++)
-	{
-		init_certificateType(&(type->Certificate[i_loop]));
-	}
-	
-	type->arraylen.Certificate=0;
-
-}
-
-static  void init_CertificateChainType(struct CertificateChainType* type)
-{	
-	init_certificateType(&(type->Certificate));	
-	init_SubCertificatesType(&(type->SubCertificates));	
-	type->isused.SubCertificates=0;
-
-}
-
-static  void init_PaymentDetailsReqType(struct PaymentDetailsReqType* type)
-{	
-	init_contractIDType(&(type->ContractID));	
-	init_CertificateChainType(&(type->ContractSignatureCertChain));
-
-}
-
-static  void init_genChallengeType(struct genChallengeType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_PaymentDetailsResType(struct PaymentDetailsResType* type)
-{		
-	init_genChallengeType(&(type->GenChallenge));	
-
-}
-
-static  void init_ContractAuthenticationReqType(struct ContractAuthenticationReqType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_genChallengeType(&(type->GenChallenge));	
-	type->isused.GenChallenge=0;
-
-}
-
-static  void init_AC_EVChargeParameterType(struct AC_EVChargeParameterType* type)
-{		
-	init_PhysicalValueType(&(type->EAmount));	
-	init_PhysicalValueType(&(type->EVMaxVoltage));	
-	init_PhysicalValueType(&(type->EVMaxCurrent));	
-	init_PhysicalValueType(&(type->EVMinCurrent));
-
-}
-
-static  void init_DC_EVStatusType(struct DC_EVStatusType* type)
-{			
-	type->isused.EVCabinConditioning=0;		
-	type->isused.EVRESSConditioning=0;		
-
-}
-
-static  void init_DC_EVChargeParameterType(struct DC_EVChargeParameterType* type)
-{	
-	init_DC_EVStatusType(&(type->DC_EVStatus));	
-	init_PhysicalValueType(&(type->EVMaximumCurrentLimit));	
-	init_PhysicalValueType(&(type->EVMaximumPowerLimit));	
-	type->isused.EVMaximumPowerLimit=0;	
-	init_PhysicalValueType(&(type->EVMaximumVoltageLimit));	
-	init_PhysicalValueType(&(type->EVEnergyCapacity));	
-	type->isused.EVEnergyCapacity=0;	
-	init_PhysicalValueType(&(type->EVEnergyRequest));	
-	type->isused.EVEnergyRequest=0;		
-	type->isused.FullSOC=0;		
-	type->isused.BulkSOC=0;
-
-}
-
-static  void init_ChargeParameterDiscoveryReqType(struct ChargeParameterDiscoveryReqType* type)
-{			
-	type->isused.AC_EVChargeParameter=0;		
-	type->isused.DC_EVChargeParameter=0;
-
-}
-
-static  void init_RelativeTimeIntervalType(struct RelativeTimeIntervalType* type)
-{			
-	type->isused.duration=0;
-
-}
-
-static  void init_PMaxScheduleEntryType(struct PMaxScheduleEntryType* type)
-{	
-	init_RelativeTimeIntervalType(&(type->RelativeTimeInterval));	
-
-}
-
-static  void init_PMaxScheduleType(struct PMaxScheduleType* type)
-{
-	int i_loop;
-			
-	for(i_loop=0; i_loop<12;i_loop++)
-	{
-		init_PMaxScheduleEntryType(&(type->PMaxScheduleEntry[i_loop]));
-	}
-	
-	type->arraylen.PMaxScheduleEntry=0;
-
-}
-
-static  void init_tariffDescriptionType(struct tariffDescriptionType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_CostType(struct CostType* type)
-{				
-	type->isused.amountMultiplier=0;
-
-}
-
-static  void init_ConsumptionCostType(struct ConsumptionCostType* type)
-{
-	int i_loop;
-			
-	for(i_loop=0; i_loop<2;i_loop++)
-	{
-		init_CostType(&(type->Cost[i_loop]));
-	}
-	
-	type->arraylen.Cost=0;	
-	type->isused.Cost=0;
-
-}
-
-static  void init_SalesTariffEntryType(struct SalesTariffEntryType* type)
-{
-	int i_loop;
-		
-	init_RelativeTimeIntervalType(&(type->RelativeTimeInterval));		
-	for(i_loop=0; i_loop<2;i_loop++)
-	{
-		init_ConsumptionCostType(&(type->ConsumptionCost[i_loop]));
-	}
-	
-	type->arraylen.ConsumptionCost=0;	
-	type->isused.ConsumptionCost=0;
-
-}
-
-static  void init_SalesTariffType(struct SalesTariffType* type)
-{
-	int i_loop;
-		
-	init_service_string(&(type->attr_Id));		
-	init_tariffDescriptionType(&(type->SalesTariffDescription));	
-	type->isused.SalesTariffDescription=0;		
-	for(i_loop=0; i_loop<12;i_loop++)
-	{
-		init_SalesTariffEntryType(&(type->SalesTariffEntry[i_loop]));
-	}
-	
-	type->arraylen.SalesTariffEntry=0;
-
-}
-
-static  void init_SAScheduleTupleType(struct SAScheduleTupleType* type)
-{		
-	init_PMaxScheduleType(&(type->PMaxSchedule));		
-	type->isused.SalesTariff=0;
-
-}
-
-static  void init_SAScheduleListType(struct SAScheduleListType* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<3;i_loop++)
-	{
-		init_SAScheduleTupleType(&(type->SAScheduleTuple[i_loop]));
-	}
-	
-	type->arraylen.SAScheduleTuple=0;
-
-}
-
-static  void init_AC_EVSEChargeParameterType(struct AC_EVSEChargeParameterType* type)
-{		
-	init_PhysicalValueType(&(type->EVSEMaxVoltage));	
-	init_PhysicalValueType(&(type->EVSEMaxCurrent));	
-	init_PhysicalValueType(&(type->EVSEMinCurrent));
-
-}
-
-static  void init_DC_EVSEStatusType(struct DC_EVSEStatusType* type)
-{		
-	type->isused.EVSEIsolationStatus=0;			
-
-}
-
-static  void init_DC_EVSEChargeParameterType(struct DC_EVSEChargeParameterType* type)
-{	
-	init_DC_EVSEStatusType(&(type->DC_EVSEStatus));	
-	init_PhysicalValueType(&(type->EVSEMaximumCurrentLimit));	
-	init_PhysicalValueType(&(type->EVSEMaximumPowerLimit));	
-	type->isused.EVSEMaximumPowerLimit=0;	
-	init_PhysicalValueType(&(type->EVSEMaximumVoltageLimit));	
-	init_PhysicalValueType(&(type->EVSEMinimumCurrentLimit));	
-	init_PhysicalValueType(&(type->EVSEMinimumVoltageLimit));	
-	init_PhysicalValueType(&(type->EVSECurrentRegulationTolerance));	
-	type->isused.EVSECurrentRegulationTolerance=0;	
-	init_PhysicalValueType(&(type->EVSEPeakCurrentRipple));	
-	init_PhysicalValueType(&(type->EVSEEnergyToBeDelivered));	
-	type->isused.EVSEEnergyToBeDelivered=0;
-
-}
-
-static  void init_ChargeParameterDiscoveryResType(struct ChargeParameterDiscoveryResType* type)
-{			
-	init_SAScheduleListType(&(type->SAScheduleList));		
-	type->isused.AC_EVSEChargeParameter=0;		
-	type->isused.DC_EVSEChargeParameter=0;
-
-}
-
-static  void init_ChargingProfileType(struct ChargingProfileType* type)
-{
-
-	type->arraylen.ProfileEntry=0;
-
-}
-
-static  void init_DC_EVPowerDeliveryParameterType(struct DC_EVPowerDeliveryParameterType* type)
-{	
-	init_DC_EVStatusType(&(type->DC_EVStatus));		
-	type->isused.BulkChargingComplete=0;	
-
-}
-
-static  void init_PowerDeliveryReqType(struct PowerDeliveryReqType* type)
-{		
-	init_ChargingProfileType(&(type->ChargingProfile));	
-	type->isused.ChargingProfile=0;		
-	type->isused.DC_EVPowerDeliveryParameter=0;
-
-}
-
-static  void init_PowerDeliveryResType(struct PowerDeliveryResType* type)
-{			
-	type->isused.AC_EVSEStatus=0;		
-	type->isused.DC_EVSEStatus=0;
-
-}
-
-static  void init_meterIDType(struct meterIDType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_sigMeterReadingType(struct sigMeterReadingType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_MeterInfoType(struct MeterInfoType* type)
-{	
-	init_meterIDType(&(type->MeterID));	
-	init_PhysicalValueType(&(type->MeterReading));	
-	type->isused.MeterReading=0;	
-	init_sigMeterReadingType(&(type->SigMeterReading));	
-	type->isused.SigMeterReading=0;		
-	type->isused.MeterStatus=0;		
-	type->isused.TMeter=0;
-
-}
-
-static  void init_ChargingStatusResType(struct ChargingStatusResType* type)
-{		
-	init_evseIDType(&(type->EVSEID));		
-	init_PhysicalValueType(&(type->EVSEMaxCurrent));	
-	type->isused.EVSEMaxCurrent=0;	
-	init_MeterInfoType(&(type->MeterInfo));	
-	type->isused.MeterInfo=0;		
-
-}
-
-static  void init_MeteringReceiptReqType(struct MeteringReceiptReqType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_sessionIDType(&(type->SessionID));		
-	type->isused.SAScheduleTupleID=0;	
-	init_MeterInfoType(&(type->MeterInfo));
-
-}
-
-static  void init_MeteringReceiptResType(struct MeteringReceiptResType* type)
-{		
-
-}
-
-static  void init_rootCertificateIDType(struct rootCertificateIDType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_ListOfRootCertificateIDsType(struct ListOfRootCertificateIDsType* type)
-{
-	int i_loop;
-		
-	for(i_loop=0; i_loop<20;i_loop++)
-	{
-		init_rootCertificateIDType(&(type->RootCertificateID[i_loop]));
-	}
-	
-	type->arraylen.RootCertificateID=0;
-
-}
-
-static  void init_dHParamsType(struct dHParamsType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_CertificateUpdateReqType(struct CertificateUpdateReqType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_CertificateChainType(&(type->ContractSignatureCertChain));	
-	init_contractIDType(&(type->ContractID));	
-	init_ListOfRootCertificateIDsType(&(type->ListOfRootCertificateIDs));	
-	init_dHParamsType(&(type->DHParams));
-
-}
-
-static  void init_privateKeyType(struct privateKeyType* type)
-{	
-	type->arraylen.data=0;
-
-}
-
-static  void init_CertificateUpdateResType(struct CertificateUpdateResType* type)
-{	
-	init_service_string(&(type->attr_Id));		
-	init_CertificateChainType(&(type->ContractSignatureCertChain));	
-	init_privateKeyType(&(type->ContractSignatureEncryptedPrivateKey));	
-	init_dHParamsType(&(type->DHParams));	
-	init_contractIDType(&(type->ContractID));	
-
-}
-
-static  void init_CertificateInstallationReqType(struct CertificateInstallationReqType* type)
-{	
-	init_service_string(&(type->attr_Id));	
-	type->isused.attr_Id=0;	
-	init_certificateType(&(type->OEMProvisioningCert));	
-	init_ListOfRootCertificateIDsType(&(type->ListOfRootCertificateIDs));	
-	init_dHParamsType(&(type->DHParams));
-
-}
-
-static  void init_CertificateInstallationResType(struct CertificateInstallationResType* type)
-{	
-	init_service_string(&(type->attr_Id));		
-	init_CertificateChainType(&(type->ContractSignatureCertChain));	
-	init_privateKeyType(&(type->ContractSignatureEncryptedPrivateKey));	
-	init_dHParamsType(&(type->DHParams));	
-	init_contractIDType(&(type->ContractID));
-
-}
-
-static  void init_CableCheckReqType(struct CableCheckReqType* type)
-{	
-	init_DC_EVStatusType(&(type->DC_EVStatus));
-
-}
-
-static  void init_CableCheckResType(struct CableCheckResType* type)
-{		
-	init_DC_EVSEStatusType(&(type->DC_EVSEStatus));	
-
-}
-
-static  void init_PreChargeReqType(struct PreChargeReqType* type)
-{	
-	init_DC_EVStatusType(&(type->DC_EVStatus));	
-	init_PhysicalValueType(&(type->EVTargetVoltage));	
-	init_PhysicalValueType(&(type->EVTargetCurrent));
-
-}
-
-static  void init_PreChargeResType(struct PreChargeResType* type)
-{		
-	init_DC_EVSEStatusType(&(type->DC_EVSEStatus));	
-	init_PhysicalValueType(&(type->EVSEPresentVoltage));
-
-}
-
-static  void init_CurrentDemandReqType(struct CurrentDemandReqType* type)
-{	
-	init_DC_EVStatusType(&(type->DC_EVStatus));	
-	init_PhysicalValueType(&(type->EVTargetCurrent));	
-	init_PhysicalValueType(&(type->EVMaximumVoltageLimit));	
-	type->isused.EVMaximumVoltageLimit=0;	
-	init_PhysicalValueType(&(type->EVMaximumCurrentLimit));	
-	type->isused.EVMaximumCurrentLimit=0;	
-	init_PhysicalValueType(&(type->EVMaximumPowerLimit));	
-	type->isused.EVMaximumPowerLimit=0;		
-	type->isused.BulkChargingComplete=0;		
-	init_PhysicalValueType(&(type->RemainingTimeToFullSoC));	
-	type->isused.RemainingTimeToFullSoC=0;	
-	init_PhysicalValueType(&(type->RemainingTimeToBulkSoC));	
-	type->isused.RemainingTimeToBulkSoC=0;	
-	init_PhysicalValueType(&(type->EVTargetVoltage));
-
-}
-
-static  void init_CurrentDemandResType(struct CurrentDemandResType* type)
-{		
-	init_DC_EVSEStatusType(&(type->DC_EVSEStatus));	
-	init_PhysicalValueType(&(type->EVSEPresentVoltage));	
-	init_PhysicalValueType(&(type->EVSEPresentCurrent));				
-	init_PhysicalValueType(&(type->EVSEMaximumVoltageLimit));	
-	type->isused.EVSEMaximumVoltageLimit=0;	
-	init_PhysicalValueType(&(type->EVSEMaximumCurrentLimit));	
-	type->isused.EVSEMaximumCurrentLimit=0;	
-	init_PhysicalValueType(&(type->EVSEMaximumPowerLimit));	
-	type->isused.EVSEMaximumPowerLimit=0;
-
-}
-
-static  void init_WeldingDetectionReqType(struct WeldingDetectionReqType* type)
-{	
-	init_DC_EVStatusType(&(type->DC_EVStatus));
-
-}
-
-static  void init_WeldingDetectionResType(struct WeldingDetectionResType* type)
-{		
-	init_DC_EVSEStatusType(&(type->DC_EVSEStatus));	
-	init_PhysicalValueType(&(type->EVSEPresentVoltage));
-
-}
-
-static  void init_BodyType(struct BodyType* type)
-{		
-	type->isused.SessionSetupReq=0;		
-	type->isused.SessionSetupRes=0;		
-	type->isused.ServiceDiscoveryReq=0;		
-	type->isused.ServiceDiscoveryRes=0;		
-	type->isused.ServiceDetailReq=0;		
-	type->isused.ServiceDetailRes=0;		
-	type->isused.ServicePaymentSelectionReq=0;		
-	type->isused.ServicePaymentSelectionRes=0;		
-	type->isused.PaymentDetailsReq=0;		
-	type->isused.PaymentDetailsRes=0;		
-	type->isused.ContractAuthenticationReq=0;		
-	type->isused.ContractAuthenticationRes=0;		
-	type->isused.ChargeParameterDiscoveryReq=0;		
-	type->isused.ChargeParameterDiscoveryRes=0;		
-	type->isused.PowerDeliveryReq=0;		
-	type->isused.PowerDeliveryRes=0;		
-	type->isused.ChargingStatusReq=0;		
-	type->isused.ChargingStatusRes=0;		
-	type->isused.MeteringReceiptReq=0;		
-	type->isused.MeteringReceiptRes=0;		
-	type->isused.SessionStopReq=0;		
-	type->isused.SessionStopRes=0;		
-	type->isused.CertificateUpdateReq=0;		
-	type->isused.CertificateUpdateRes=0;		
-	type->isused.CertificateInstallationReq=0;		
-	type->isused.CertificateInstallationRes=0;		
-	type->isused.CableCheckReq=0;		
-	type->isused.CableCheckRes=0;		
-	type->isused.PreChargeReq=0;		
-	type->isused.PreChargeRes=0;		
-	type->isused.CurrentDemandReq=0;		
-	type->isused.CurrentDemandRes=0;		
-	type->isused.WeldingDetectionReq=0;		
-	type->isused.WeldingDetectionRes=0;
-
-}
-
-static  void init_AnonType_V2G_Message(struct AnonType_V2G_Message* type)
-{		
-	init_BodyType(&(type->Body));
-
-}
-
-static void init_EXIDocumentType(struct EXIDocumentType* type)
-{	
-	init_AnonType_V2G_Message(&(type->V2G_Message));
-
-}

+ 0 - 1688
src/service/v2g_dataTypes.h

@@ -1,1688 +0,0 @@
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef SERVICEDATATYPES_H
-#define SERVICEDATATYPES_H
-
-#include "EXITypes.h"
-
-
-	
-
-enum faultCodeType
-{
-	ParsingError_faultCodeType=0, 
-	NoTLSRootCertificatAvailable_faultCodeType=1, 
-	UnknownError_faultCodeType=2
-
-}; 
-
-enum responseCodeType
-{
-	OK_responseCodeType=0, 
-	OK_NewSessionEstablished_responseCodeType=1, 
-	OK_OldSessionJoined_responseCodeType=2, 
-	OK_CertificateExpiresSoon_responseCodeType=3, 
-	FAILED_responseCodeType=4, 
-	FAILED_SequenceError_responseCodeType=5, 
-	FAILED_ServiceIDInvalid_responseCodeType=6, 
-	FAILED_UnknownSession_responseCodeType=7, 
-	FAILED_ServiceSelectionInvalid_responseCodeType=8, 
-	FAILED_PaymentSelectionInvalid_responseCodeType=9, 
-	FAILED_CertificateExpired_responseCodeType=10, 
-	FAILED_SignatureError_responseCodeType=11, 
-	FAILED_NoCertificateAvailable_responseCodeType=12, 
-	FAILED_CertChainError_responseCodeType=13, 
-	FAILED_ChallengeInvalid_responseCodeType=14, 
-	FAILED_ContractCanceled_responseCodeType=15, 
-	FAILED_WrongChargeParameter_responseCodeType=16, 
-	FAILED_PowerDeliveryNotApplied_responseCodeType=17, 
-	FAILED_TariffSelectionInvalid_responseCodeType=18, 
-	FAILED_ChargingProfileInvalid_responseCodeType=19, 
-	FAILED_EVSEPresentVoltageToLow_responseCodeType=20, 
-	FAILED_MeteringSignatureNotValid_responseCodeType=21, 
-	FAILED_WrongEnergyTransferType_responseCodeType=22
-
-}; 
-
-enum serviceCategoryType
-{
-	EVCharging_serviceCategoryType=0, 
-	Internet_serviceCategoryType=1, 
-	ContractCertificate_serviceCategoryType=2, 
-	OtherCustom_serviceCategoryType=3
-
-}; 
-
-enum paymentOptionType
-{
-	Contract_paymentOptionType=0, 
-	ExternalPayment_paymentOptionType=1
-
-}; 
-
-enum EVSESupportedEnergyTransferType
-{
-	AC_single_phase_core_EVSESupportedEnergyTransferType=0, 
-	AC_three_phase_core_EVSESupportedEnergyTransferType=1, 
-	DC_core_EVSESupportedEnergyTransferType=2, 
-	DC_extended_EVSESupportedEnergyTransferType=3, 
-	DC_combo_core_EVSESupportedEnergyTransferType=4, 
-	DC_dual_EVSESupportedEnergyTransferType=5, 
-	AC_core1p_DC_extended_EVSESupportedEnergyTransferType=6, 
-	AC_single_DC_core_EVSESupportedEnergyTransferType=7, 
-	AC_single_phase_three_phase_core_DC_extended_EVSESupportedEnergyTransferType=8, 
-	AC_core3p_DC_extended_EVSESupportedEnergyTransferType=9
-
-}; 
-
-enum unitSymbolType
-{
-	h_unitSymbolType=0, 
-	m_unitSymbolType=1, 
-	s_unitSymbolType=2, 
-	A_unitSymbolType=3, 
-	Ah_unitSymbolType=4, 
-	V_unitSymbolType=5, 
-	VA_unitSymbolType=6, 
-	W_unitSymbolType=7, 
-	W_s_unitSymbolType=8, 
-	Wh_unitSymbolType=9
-
-}; 
-
-enum EVSEProcessingType
-{
-	Finished_EVSEProcessingType=0, 
-	Ongoing_EVSEProcessingType=1
-
-}; 
-
-enum EVRequestedEnergyTransferType
-{
-	AC_single_phase_core_EVRequestedEnergyTransferType=0, 
-	AC_three_phase_core_EVRequestedEnergyTransferType=1, 
-	DC_core_EVRequestedEnergyTransferType=2, 
-	DC_extended_EVRequestedEnergyTransferType=3, 
-	DC_combo_core_EVRequestedEnergyTransferType=4, 
-	DC_unique_EVRequestedEnergyTransferType=5
-
-}; 
-
-enum DC_EVErrorCodeType
-{
-	NO_ERROR_DC_EVErrorCodeType=0, 
-	FAILED_RESSTemperatureInhibit_DC_EVErrorCodeType=1, 
-	FAILED_EVShiftPosition_DC_EVErrorCodeType=2, 
-	FAILED_ChargerConnectorLockFault_DC_EVErrorCodeType=3, 
-	FAILED_EVRESSMalfunction_DC_EVErrorCodeType=4, 
-	FAILED_ChargingCurrentdifferential_DC_EVErrorCodeType=5, 
-	FAILED_ChargingVoltageOutOfRange_DC_EVErrorCodeType=6, 
-	Reserved_A_DC_EVErrorCodeType=7, 
-	Reserved_B_DC_EVErrorCodeType=8, 
-	Reserved_C_DC_EVErrorCodeType=9, 
-	FAILED_ChargingSystemIncompatibility_DC_EVErrorCodeType=10, 
-	NoData_DC_EVErrorCodeType=11
-
-}; 
-
-enum costKindType
-{
-	relativePricePercentage_costKindType=0, 
-	RenewableGenerationPercentage_costKindType=1, 
-	CarbonDioxideEmission_costKindType=2
-
-}; 
-
-enum EVSENotificationType
-{
-	None_EVSENotificationType=0, 
-	StopCharging_EVSENotificationType=1, 
-	ReNegotiation_EVSENotificationType=2
-
-}; 
-
-enum isolationLevelType
-{
-	Invalid_isolationLevelType=0, 
-	Valid_isolationLevelType=1, 
-	Warning_isolationLevelType=2, 
-	Fault_isolationLevelType=3
-
-}; 
-
-enum DC_EVSEStatusCodeType
-{
-	EVSE_NotReady_DC_EVSEStatusCodeType=0, 
-	EVSE_Ready_DC_EVSEStatusCodeType=1, 
-	EVSE_Shutdown_DC_EVSEStatusCodeType=2, 
-	EVSE_UtilityInterruptEvent_DC_EVSEStatusCodeType=3, 
-	EVSE_IsolationMonitoringActive_DC_EVSEStatusCodeType=4, 
-	EVSE_EmergencyShutdown_DC_EVSEStatusCodeType=5, 
-	EVSE_Malfunction_DC_EVSEStatusCodeType=6, 
-	Reserved_8_DC_EVSEStatusCodeType=7, 
-	Reserved_9_DC_EVSEStatusCodeType=8, 
-	Reserved_A_DC_EVSEStatusCodeType=9, 
-	Reserved_B_DC_EVSEStatusCodeType=10, 
-	Reserved_C_DC_EVSEStatusCodeType=11
-
-}; 
-
-
-
-
-struct arraylen_sessionIDType
-{
-	size_t data;
-
-
-};
-
-struct sessionIDType
-{
-	uint8_t data[8];
-	struct arraylen_sessionIDType arraylen;
-
-};
-
-struct arraylen_faultMsgType
-{
-	size_t data;
-
-
-};
-
-struct faultMsgType
-{
-	uint32_t data[64];
-	struct arraylen_faultMsgType arraylen;
-
-};
-
-struct selection_NotificationType
-{
-	unsigned int FaultMsg:1;
-
-
-};
-
-struct NotificationType
-{
-	enum faultCodeType FaultCode;
-	struct faultMsgType FaultMsg;
-	struct selection_NotificationType isused;
-
-};
-
-struct selection_MessageHeaderType
-{
-	unsigned int Notification:1;
-	unsigned int Signature:1;
-
-
-};
-
-struct arraylen_service_string
-{
-	size_t data;
-
-
-};
-
-struct service_string
-{
-	uint32_t data[256];
-	struct arraylen_service_string arraylen;
-
-};
-
-struct selection_SignatureType
-{
-	unsigned int attr_Id:1;
-	unsigned int KeyInfo:1;
-
-
-};
-
-struct selection_SignedInfoType
-{
-	unsigned int attr_Id:1;
-
-
-};
-
-struct CanonicalizationMethodType
-{
-	struct service_string attr_Algorithm;
-
-
-};
-
-struct SignatureMethodType
-{
-	struct service_string attr_Algorithm;
-
-
-};
-
-struct selection_ReferenceType
-{
-	unsigned int attr_Id:1;
-	unsigned int attr_URI:1;
-	unsigned int attr_Type:1;
-
-
-};
-
-struct DigestMethodType
-{
-	struct service_string attr_Algorithm;
-
-
-};
-
-struct arraylen_DigestValueType
-{
-	size_t data;
-
-
-};
-
-struct DigestValueType
-{
-	uint8_t data[128];
-	struct arraylen_DigestValueType arraylen;
-
-};
-
-struct ReferenceType
-{
-	struct service_string attr_Id;
-	struct service_string attr_URI;
-	struct service_string attr_Type;
-	struct DigestMethodType DigestMethod;
-	struct DigestValueType DigestValue;
-	struct selection_ReferenceType isused;
-
-};
-
-struct arraylen_SignedInfoType
-{
-	size_t Reference;
-
-
-};
-
-struct SignedInfoType
-{
-	struct service_string attr_Id;
-	struct CanonicalizationMethodType CanonicalizationMethod;
-	struct SignatureMethodType SignatureMethod;
-	struct ReferenceType Reference[1];
-	struct selection_SignedInfoType isused;	struct arraylen_SignedInfoType arraylen;
-
-};
-
-struct arraylen_SignatureValueType
-{
-	size_t data;
-
-
-};
-
-struct SignatureValueType
-{
-	uint8_t data[128];
-	struct arraylen_SignatureValueType arraylen;
-
-
-};
-
-struct selection_KeyInfoType
-{
-	unsigned int attr_Id:1;
-
-
-};
-
-struct X509IssuerSerialType
-{
-	struct service_string X509IssuerName;
-	int64_t X509SerialNumber;
-
-
-};
-
-struct arraylen_service_byte
-{
-	size_t data;
-
-
-};
-
-struct service_byte
-{
-	uint8_t data[128];
-	struct arraylen_service_byte arraylen;
-
-};
-
-struct X509DataType
-{
-	struct X509IssuerSerialType X509IssuerSerial;
-	struct service_byte X509SKI;
-	struct service_string X509SubjectName;
-	struct service_byte X509Certificate;
-	struct service_byte X509CRL;
-
-
-};
-
-struct KeyInfoType
-{
-	struct service_string attr_Id;
-	struct X509DataType X509Data;
-	struct selection_KeyInfoType isused;
-
-};
-
-struct SignatureType
-{
-	struct service_string attr_Id;
-	struct SignedInfoType SignedInfo;
-	struct SignatureValueType SignatureValue;
-	struct KeyInfoType KeyInfo;
-	struct selection_SignatureType isused;
-
-};
-
-struct MessageHeaderType
-{
-	struct sessionIDType SessionID;
-	struct NotificationType Notification;
-	struct SignatureType* Signature;
-	struct selection_MessageHeaderType isused;
-
-};
-
-struct arraylen_evccIDType
-{
-	size_t data;
-
-
-};
-
-struct evccIDType
-{
-	uint8_t data[8];
-	struct arraylen_evccIDType arraylen;
-
-};
-
-struct SessionSetupReqType
-{
-	struct evccIDType EVCCID;
-
-
-};
-
-struct selection_BodyType
-{
-	unsigned int SessionSetupReq:1;
-	unsigned int SessionSetupRes:1;
-	unsigned int ServiceDiscoveryReq:1;
-	unsigned int ServiceDiscoveryRes:1;
-	unsigned int ServiceDetailReq:1;
-	unsigned int ServiceDetailRes:1;
-	unsigned int ServicePaymentSelectionReq:1;
-	unsigned int ServicePaymentSelectionRes:1;
-	unsigned int PaymentDetailsReq:1;
-	unsigned int PaymentDetailsRes:1;
-	unsigned int ContractAuthenticationReq:1;
-	unsigned int ContractAuthenticationRes:1;
-	unsigned int ChargeParameterDiscoveryReq:1;
-	unsigned int ChargeParameterDiscoveryRes:1;
-	unsigned int PowerDeliveryReq:1;
-	unsigned int PowerDeliveryRes:1;
-	unsigned int ChargingStatusReq:1;
-	unsigned int ChargingStatusRes:1;
-	unsigned int MeteringReceiptReq:1;
-	unsigned int MeteringReceiptRes:1;
-	unsigned int SessionStopReq:1;
-	unsigned int SessionStopRes:1;
-	unsigned int CertificateUpdateReq:1;
-	unsigned int CertificateUpdateRes:1;
-	unsigned int CertificateInstallationReq:1;
-	unsigned int CertificateInstallationRes:1;
-	unsigned int CableCheckReq:1;
-	unsigned int CableCheckRes:1;
-	unsigned int PreChargeReq:1;
-	unsigned int PreChargeRes:1;
-	unsigned int CurrentDemandReq:1;
-	unsigned int CurrentDemandRes:1;
-	unsigned int WeldingDetectionReq:1;
-	unsigned int WeldingDetectionRes:1;
-
-
-};
-
-struct arraylen_evseIDType
-{
-	size_t data;
-
-
-};
-
-struct evseIDType
-{
-	uint8_t data[32];
-	struct arraylen_evseIDType arraylen;
-
-};
-
-struct selection_SessionSetupResType
-{
-	unsigned int DateTimeNow:1;
-
-
-};
-
-struct SessionSetupResType
-{
-	enum responseCodeType ResponseCode;
-	struct evseIDType EVSEID;
-	int64_t DateTimeNow;
-	struct selection_SessionSetupResType isused;
-
-};
-
-struct arraylen_serviceScopeType
-{
-	size_t data;
-
-
-};
-
-struct serviceScopeType
-{
-	uint32_t data[32];
-	struct arraylen_serviceScopeType arraylen;
-
-};
-
-struct selection_ServiceDiscoveryReqType
-{
-	unsigned int ServiceScope:1;
-	unsigned int ServiceCategory:1;
-
-
-};
-
-struct ServiceDiscoveryReqType
-{
-	struct serviceScopeType ServiceScope;
-	enum serviceCategoryType ServiceCategory;
-	struct selection_ServiceDiscoveryReqType isused;
-
-};
-
-struct arraylen_PaymentOptionsType
-{
-	size_t PaymentOption;
-
-
-};
-
-struct PaymentOptionsType
-{
-	enum paymentOptionType PaymentOption[2];
-	struct arraylen_PaymentOptionsType arraylen;
-
-};
-
-struct arraylen_serviceNameType
-{
-	size_t data;
-
-
-};
-
-struct serviceNameType
-{
-	uint32_t data[32];
-	struct arraylen_serviceNameType arraylen;
-
-};
-
-struct selection_ServiceTagType
-{
-	unsigned int ServiceName:1;
-	unsigned int ServiceScope:1;
-
-
-};
-
-struct ServiceTagType
-{
-	uint16_t ServiceID;
-	struct serviceNameType ServiceName;
-	enum serviceCategoryType ServiceCategory;
-	struct serviceScopeType ServiceScope;
-	struct selection_ServiceTagType isused;
-
-};
-
-struct ServiceChargeType
-{
-	struct ServiceTagType ServiceTag;
-	int FreeService;
-	enum EVSESupportedEnergyTransferType EnergyTransferType;
-
-
-};
-
-struct ServiceType
-{
-	struct ServiceTagType ServiceTag;
-	int FreeService;
-
-
-};
-
-struct arraylen_ServiceTagListType
-{
-	size_t Service;
-
-
-};
-
-struct ServiceTagListType
-{
-	struct ServiceType Service[3];
-	struct arraylen_ServiceTagListType arraylen;
-
-};
-
-struct selection_ServiceDiscoveryResType
-{
-	unsigned int ServiceList:1;
-
-
-};
-
-struct ServiceDiscoveryResType
-{
-	enum responseCodeType ResponseCode;
-	struct PaymentOptionsType PaymentOptions;
-	struct ServiceChargeType ChargeService;
-	struct ServiceTagListType ServiceList;
-	struct selection_ServiceDiscoveryResType isused;
-
-};
-
-struct ServiceDetailReqType
-{
-	uint16_t ServiceID;
-
-
-};
-
-struct selection_PhysicalValueType
-{
-	unsigned int Unit:1;
-
-
-};
-
-struct PhysicalValueType
-{
-	int8_t Multiplier;
-	enum unitSymbolType Unit;
-	int16_t Value;
-	struct selection_PhysicalValueType isused;
-
-};
-
-struct ParameterType
-{
-	struct service_string attr_Name;
-	struct service_string attr_ValueType;
-	int boolValue;
-	int8_t byteValue;
-	int16_t shortValue;
-	int32_t intValue;
-	struct PhysicalValueType physicalValue;
-	struct service_string stringValue;
-
-
-};
-
-struct arraylen_ParameterSetType
-{
-	size_t Parameter;
-
-
-};
-
-struct ParameterSetType
-{
-	int16_t ParameterSetID;
-	struct ParameterType Parameter[2];
-	struct arraylen_ParameterSetType arraylen;
-
-};
-
-struct arraylen_ServiceParameterListType
-{
-	size_t ParameterSet;
-
-
-};
-
-struct ServiceParameterListType
-{
-	struct ParameterSetType ParameterSet[2];
-	struct arraylen_ServiceParameterListType arraylen;
-
-};
-
-struct selection_ServiceDetailResType
-{
-	unsigned int ServiceParameterList:1;
-
-
-};
-
-struct ServiceDetailResType
-{
-	enum responseCodeType ResponseCode;
-	uint16_t ServiceID;
-	struct ServiceParameterListType ServiceParameterList;
-	struct selection_ServiceDetailResType isused;
-
-};
-
-struct selection_SelectedServiceType
-{
-	unsigned int ParameterSetID:1;
-
-
-};
-
-struct SelectedServiceType
-{
-	uint16_t ServiceID;
-	int16_t ParameterSetID;
-	struct selection_SelectedServiceType isused;
-
-};
-
-struct arraylen_SelectedServiceListType
-{
-	size_t SelectedService;
-
-
-};
-
-struct SelectedServiceListType
-{
-	struct SelectedServiceType SelectedService[2];
-	struct arraylen_SelectedServiceListType arraylen;
-
-};
-
-struct ServicePaymentSelectionReqType
-{
-	enum paymentOptionType SelectedPaymentOption;
-	struct SelectedServiceListType SelectedServiceList;
-
-
-};
-
-struct ServicePaymentSelectionResType
-{
-	enum responseCodeType ResponseCode;
-
-
-};
-
-struct arraylen_contractIDType
-{
-	size_t data;
-
-
-};
-
-struct contractIDType
-{
-	uint32_t data[24];
-	struct arraylen_contractIDType arraylen;
-
-};
-
-struct arraylen_certificateType
-{
-	size_t data;
-
-
-};
-
-struct certificateType
-{
-	uint8_t data[1200];
-	struct arraylen_certificateType arraylen;
-
-};
-
-struct arraylen_SubCertificatesType
-{
-	size_t Certificate;
-
-
-};
-
-struct SubCertificatesType
-{
-	struct certificateType Certificate[4];
-	struct arraylen_SubCertificatesType arraylen;
-
-};
-
-struct selection_CertificateChainType
-{
-	unsigned int SubCertificates:1;
-
-
-};
-
-struct CertificateChainType
-{
-	struct certificateType Certificate;
-	struct SubCertificatesType SubCertificates;
-	struct selection_CertificateChainType isused;
-
-};
-
-struct PaymentDetailsReqType
-{
-	struct contractIDType ContractID;
-	struct CertificateChainType ContractSignatureCertChain;
-
-
-};
-
-struct arraylen_genChallengeType
-{
-	size_t data;
-
-
-};
-
-struct genChallengeType
-{
-	uint32_t data[256];
-	struct arraylen_genChallengeType arraylen;
-
-};
-
-struct PaymentDetailsResType
-{
-	enum responseCodeType ResponseCode;
-	struct genChallengeType GenChallenge;
-	int64_t DateTimeNow;
-
-
-};
-
-struct selection_ContractAuthenticationReqType
-{
-	unsigned int attr_Id:1;
-	unsigned int GenChallenge:1;
-
-
-};
-
-struct ContractAuthenticationReqType
-{
-	struct service_string attr_Id;
-	struct genChallengeType GenChallenge;
-	struct selection_ContractAuthenticationReqType isused;
-
-};
-
-struct ContractAuthenticationResType
-{
-	enum responseCodeType ResponseCode;
-	enum EVSEProcessingType EVSEProcessing;
-
-
-};
-
-struct AC_EVChargeParameterType
-{
-	uint32_t DepartureTime;
-	struct PhysicalValueType EAmount;
-	struct PhysicalValueType EVMaxVoltage;
-	struct PhysicalValueType EVMaxCurrent;
-	struct PhysicalValueType EVMinCurrent;
-
-
-};
-
-struct selection_ChargeParameterDiscoveryReqType
-{
-	unsigned int AC_EVChargeParameter:1;
-	unsigned int DC_EVChargeParameter:1;
-
-
-};
-
-struct selection_DC_EVStatusType
-{
-	unsigned int EVCabinConditioning:1;
-	unsigned int EVRESSConditioning:1;
-
-
-};
-
-struct DC_EVStatusType
-{
-	int EVReady;
-	int EVCabinConditioning;
-	int EVRESSConditioning;
-	enum DC_EVErrorCodeType EVErrorCode;
-	int8_t EVRESSSOC;
-	struct selection_DC_EVStatusType isused;
-
-};
-
-struct selection_DC_EVChargeParameterType
-{
-	unsigned int EVMaximumPowerLimit:1;
-	unsigned int EVEnergyCapacity:1;
-	unsigned int EVEnergyRequest:1;
-	unsigned int FullSOC:1;
-	unsigned int BulkSOC:1;
-
-
-};
-
-struct DC_EVChargeParameterType
-{
-	struct DC_EVStatusType DC_EVStatus;
-	struct PhysicalValueType EVMaximumCurrentLimit;
-	struct PhysicalValueType EVMaximumPowerLimit;
-	struct PhysicalValueType EVMaximumVoltageLimit;
-	struct PhysicalValueType EVEnergyCapacity;
-	struct PhysicalValueType EVEnergyRequest;
-	int8_t FullSOC;
-	int8_t BulkSOC;
-	struct selection_DC_EVChargeParameterType isused;
-
-};
-
-struct ChargeParameterDiscoveryReqType
-{
-	enum EVRequestedEnergyTransferType EVRequestedEnergyTransferType;
-	struct AC_EVChargeParameterType* AC_EVChargeParameter;
-	struct DC_EVChargeParameterType* DC_EVChargeParameter;
-	struct selection_ChargeParameterDiscoveryReqType isused;
-
-};
-
-struct selection_RelativeTimeIntervalType
-{
-	unsigned int duration:1;
-
-
-};
-
-struct RelativeTimeIntervalType
-{
-	uint32_t start;
-	uint32_t duration;
-	struct selection_RelativeTimeIntervalType isused;
-
-};
-
-struct PMaxScheduleEntryType
-{
-	struct RelativeTimeIntervalType RelativeTimeInterval;
-	int16_t PMax;
-
-
-};
-
-struct arraylen_PMaxScheduleType
-{
-	size_t PMaxScheduleEntry;
-
-
-};
-
-struct PMaxScheduleType
-{
-	int16_t PMaxScheduleID;
-	struct PMaxScheduleEntryType PMaxScheduleEntry[12];
-	struct arraylen_PMaxScheduleType arraylen;
-
-};
-
-struct arraylen_tariffDescriptionType
-{
-	size_t data;
-
-
-};
-
-struct tariffDescriptionType
-{
-	uint32_t data[32];
-	struct arraylen_tariffDescriptionType arraylen;
-
-};
-
-struct selection_SalesTariffType
-{
-	unsigned int SalesTariffDescription:1;
-
-
-};
-
-struct selection_CostType
-{
-	unsigned int amountMultiplier:1;
-
-
-};
-
-struct CostType
-{
-	enum costKindType costKind;
-	uint32_t amount;
-	int8_t amountMultiplier;
-	struct selection_CostType isused;
-
-};
-
-struct selection_ConsumptionCostType
-{
-	unsigned int Cost:1;
-
-
-};
-
-struct arraylen_ConsumptionCostType
-{
-	size_t Cost;
-
-
-};
-
-struct ConsumptionCostType
-{
-	uint32_t startValue;
-	struct CostType Cost[2];
-	struct selection_ConsumptionCostType isused;	struct arraylen_ConsumptionCostType arraylen;
-
-};
-
-struct selection_SalesTariffEntryType
-{
-	unsigned int ConsumptionCost:1;
-
-
-};
-
-struct arraylen_SalesTariffEntryType
-{
-	size_t ConsumptionCost;
-
-
-};
-
-struct SalesTariffEntryType
-{
-	struct RelativeTimeIntervalType RelativeTimeInterval;
-	uint8_t EPriceLevel;
-	struct ConsumptionCostType ConsumptionCost[2];
-	struct selection_SalesTariffEntryType isused;	struct arraylen_SalesTariffEntryType arraylen;
-
-};
-
-struct arraylen_SalesTariffType
-{
-	size_t SalesTariffEntry;
-
-
-};
-
-struct SalesTariffType
-{
-	struct service_string attr_Id;
-	int16_t SalesTariffID;
-	struct tariffDescriptionType SalesTariffDescription;
-	uint8_t NumEPriceLevels;
-	struct SalesTariffEntryType SalesTariffEntry[12];
-	struct selection_SalesTariffType isused;
-	struct arraylen_SalesTariffType arraylen;
-
-};
-
-struct selection_SAScheduleTupleType
-{
-	unsigned int SalesTariff:1;
-
-
-};
-
-struct SAScheduleTupleType
-{
-	int16_t SAScheduleTupleID;
-	struct PMaxScheduleType PMaxSchedule;
-	struct SalesTariffType* SalesTariff;
-	struct selection_SAScheduleTupleType isused;
-
-};
-
-struct arraylen_SAScheduleListType
-{
-	size_t SAScheduleTuple;
-
-
-};
-
-struct SAScheduleListType
-{
-	struct SAScheduleTupleType SAScheduleTuple[3];
-	struct arraylen_SAScheduleListType arraylen;
-
-};
-
-struct AC_EVSEStatusType
-{
-	int PowerSwitchClosed;
-	int RCD;
-	uint32_t NotificationMaxDelay;
-	enum EVSENotificationType EVSENotification;
-
-
-};
-
-struct AC_EVSEChargeParameterType
-{
-	struct AC_EVSEStatusType AC_EVSEStatus;
-	struct PhysicalValueType EVSEMaxVoltage;
-	struct PhysicalValueType EVSEMaxCurrent;
-	struct PhysicalValueType EVSEMinCurrent;
-
-
-};
-
-struct selection_ChargeParameterDiscoveryResType
-{
-	unsigned int AC_EVSEChargeParameter:1;
-	unsigned int DC_EVSEChargeParameter:1;
-
-
-};
-
-struct selection_DC_EVSEStatusType
-{
-	unsigned int EVSEIsolationStatus:1;
-
-
-};
-
-struct DC_EVSEStatusType
-{
-	enum isolationLevelType EVSEIsolationStatus;
-	enum DC_EVSEStatusCodeType EVSEStatusCode;
-	uint32_t NotificationMaxDelay;
-	enum EVSENotificationType EVSENotification;
-	struct selection_DC_EVSEStatusType isused;
-
-};
-
-struct selection_DC_EVSEChargeParameterType
-{
-	unsigned int EVSEMaximumPowerLimit:1;
-	unsigned int EVSECurrentRegulationTolerance:1;
-	unsigned int EVSEEnergyToBeDelivered:1;
-
-
-};
-
-struct DC_EVSEChargeParameterType
-{
-	struct DC_EVSEStatusType DC_EVSEStatus;
-	struct PhysicalValueType EVSEMaximumCurrentLimit;
-	struct PhysicalValueType EVSEMaximumPowerLimit;
-	struct PhysicalValueType EVSEMaximumVoltageLimit;
-	struct PhysicalValueType EVSEMinimumCurrentLimit;
-	struct PhysicalValueType EVSEMinimumVoltageLimit;
-	struct PhysicalValueType EVSECurrentRegulationTolerance;
-	struct PhysicalValueType EVSEPeakCurrentRipple;
-	struct PhysicalValueType EVSEEnergyToBeDelivered;
-	struct selection_DC_EVSEChargeParameterType isused;
-
-};
-
-struct ChargeParameterDiscoveryResType
-{
-	enum responseCodeType ResponseCode;
-	enum EVSEProcessingType EVSEProcessing;
-	struct SAScheduleListType SAScheduleList;
-	struct AC_EVSEChargeParameterType* AC_EVSEChargeParameter;
-	struct DC_EVSEChargeParameterType* DC_EVSEChargeParameter;
-	struct selection_ChargeParameterDiscoveryResType isused;
-
-};
-
-struct ProfileEntryType
-{
-	uint32_t ChargingProfileEntryStart;
-	int16_t ChargingProfileEntryMaxPower;
-
-
-};
-
-struct arraylen_ChargingProfileType
-{
-	size_t ProfileEntry;
-
-
-};
-
-struct ChargingProfileType
-{
-	int16_t SAScheduleTupleID;
-	struct ProfileEntryType ProfileEntry[24];
-	struct arraylen_ChargingProfileType arraylen;
-
-};
-
-struct selection_PowerDeliveryReqType
-{
-	unsigned int ChargingProfile:1;
-	unsigned int DC_EVPowerDeliveryParameter:1;
-
-
-};
-
-struct selection_DC_EVPowerDeliveryParameterType
-{
-	unsigned int BulkChargingComplete:1;
-
-
-};
-
-struct DC_EVPowerDeliveryParameterType
-{
-	struct DC_EVStatusType DC_EVStatus;
-	int BulkChargingComplete;
-	int ChargingComplete;
-	struct selection_DC_EVPowerDeliveryParameterType isused;
-
-};
-
-struct PowerDeliveryReqType
-{
-	int ReadyToChargeState;
-	struct ChargingProfileType ChargingProfile;
-	struct DC_EVPowerDeliveryParameterType* DC_EVPowerDeliveryParameter;
-	struct selection_PowerDeliveryReqType isused;
-
-};
-
-struct selection_PowerDeliveryResType
-{
-	unsigned int AC_EVSEStatus:1;
-	unsigned int DC_EVSEStatus:1;
-
-
-};
-
-struct PowerDeliveryResType
-{
-	enum responseCodeType ResponseCode;
-	struct AC_EVSEStatusType* AC_EVSEStatus;
-	struct DC_EVSEStatusType* DC_EVSEStatus;
-	struct selection_PowerDeliveryResType isused;
-
-};
-
-struct ChargingStatusReqType
-{
-
- 
-	int NO_MEMBER:1;
-	
-};
-
-struct selection_ChargingStatusResType
-{
-	unsigned int EVSEMaxCurrent:1;
-	unsigned int MeterInfo:1;
-
-
-};
-
-struct arraylen_meterIDType
-{
-	size_t data;
-
-
-};
-
-struct meterIDType
-{
-	uint32_t data[32];
-	struct arraylen_meterIDType arraylen;
-
-};
-
-struct selection_MeterInfoType
-{
-	unsigned int MeterReading:1;
-	unsigned int SigMeterReading:1;
-	unsigned int MeterStatus:1;
-	unsigned int TMeter:1;
-
-
-};
-
-struct arraylen_sigMeterReadingType
-{
-	size_t data;
-
-
-};
-
-struct sigMeterReadingType
-{
-	uint8_t data[32];
-	struct arraylen_sigMeterReadingType arraylen;
-
-};
-
-struct MeterInfoType
-{
-	struct meterIDType MeterID;
-	struct PhysicalValueType MeterReading;
-	struct sigMeterReadingType SigMeterReading;
-	int16_t MeterStatus;
-	int64_t TMeter;
-	struct selection_MeterInfoType isused;
-
-};
-
-struct ChargingStatusResType
-{
-	enum responseCodeType ResponseCode;
-	struct evseIDType EVSEID;
-	int16_t SAScheduleTupleID;
-	struct PhysicalValueType EVSEMaxCurrent;
-	struct MeterInfoType MeterInfo;
-	int ReceiptRequired;
-	struct AC_EVSEStatusType AC_EVSEStatus;
-	struct selection_ChargingStatusResType isused;
-
-};
-
-struct selection_MeteringReceiptReqType
-{
-	unsigned int attr_Id:1;
-	unsigned int SAScheduleTupleID:1;
-
-
-};
-
-struct MeteringReceiptReqType
-{
-	struct service_string attr_Id;
-	struct sessionIDType SessionID;
-	int16_t SAScheduleTupleID;
-	struct MeterInfoType MeterInfo;
-	struct selection_MeteringReceiptReqType isused;
-
-};
-
-struct MeteringReceiptResType
-{
-	enum responseCodeType ResponseCode;
-	struct AC_EVSEStatusType AC_EVSEStatus;
-
-
-};
-
-struct SessionStopType
-{
-
- 
-	int NO_MEMBER:1;
-	
-};
-
-struct SessionStopResType
-{
-	enum responseCodeType ResponseCode;
-
-
-};
-
-struct selection_CertificateUpdateReqType
-{
-	unsigned int attr_Id:1;
-
-
-};
-
-struct arraylen_rootCertificateIDType
-{
-	size_t data;
-
-
-};
-
-struct rootCertificateIDType
-{
-	uint32_t data[40];
-	struct arraylen_rootCertificateIDType arraylen;
-
-};
-
-struct arraylen_ListOfRootCertificateIDsType
-{
-	size_t RootCertificateID;
-
-
-};
-
-struct ListOfRootCertificateIDsType
-{
-	struct rootCertificateIDType RootCertificateID[20];
-	struct arraylen_ListOfRootCertificateIDsType arraylen;
-
-};
-
-struct arraylen_dHParamsType
-{
-	size_t data;
-
-
-};
-
-struct dHParamsType
-{
-	uint8_t data[256];
-	struct arraylen_dHParamsType arraylen;
-
-};
-
-struct CertificateUpdateReqType
-{
-	struct service_string attr_Id;
-	struct CertificateChainType ContractSignatureCertChain;
-	struct contractIDType ContractID;
-	struct ListOfRootCertificateIDsType ListOfRootCertificateIDs;
-	struct dHParamsType DHParams;
-	struct selection_CertificateUpdateReqType isused;
-
-};
-
-struct arraylen_privateKeyType
-{
-	size_t data;
-
-
-};
-
-struct privateKeyType
-{
-	uint8_t data[128];
-	struct arraylen_privateKeyType arraylen;
-
-};
-
-struct CertificateUpdateResType
-{
-	struct service_string attr_Id;
-	enum responseCodeType ResponseCode;
-	struct CertificateChainType ContractSignatureCertChain;
-	struct privateKeyType ContractSignatureEncryptedPrivateKey;
-	struct dHParamsType DHParams;
-	struct contractIDType ContractID;
-	int16_t RetryCounter;
-
-
-};
-
-struct selection_CertificateInstallationReqType
-{
-	unsigned int attr_Id:1;
-
-
-};
-
-struct CertificateInstallationReqType
-{
-	struct service_string attr_Id;
-	struct certificateType OEMProvisioningCert;
-	struct ListOfRootCertificateIDsType ListOfRootCertificateIDs;
-	struct dHParamsType DHParams;
-	struct selection_CertificateInstallationReqType isused;
-
-};
-
-struct CertificateInstallationResType
-{
-	struct service_string attr_Id;
-	enum responseCodeType ResponseCode;
-	struct CertificateChainType ContractSignatureCertChain;
-	struct privateKeyType ContractSignatureEncryptedPrivateKey;
-	struct dHParamsType DHParams;
-	struct contractIDType ContractID;
-
-
-};
-
-struct CableCheckReqType
-{
-	struct DC_EVStatusType DC_EVStatus;
-
-
-};
-
-struct CableCheckResType
-{
-	enum responseCodeType ResponseCode;
-	struct DC_EVSEStatusType DC_EVSEStatus;
-	enum EVSEProcessingType EVSEProcessing;
-
-
-};
-
-struct PreChargeReqType
-{
-	struct DC_EVStatusType DC_EVStatus;
-	struct PhysicalValueType EVTargetVoltage;
-	struct PhysicalValueType EVTargetCurrent;
-
-
-};
-
-struct PreChargeResType
-{
-	enum responseCodeType ResponseCode;
-	struct DC_EVSEStatusType DC_EVSEStatus;
-	struct PhysicalValueType EVSEPresentVoltage;
-
-
-};
-
-struct selection_CurrentDemandReqType
-{
-	unsigned int EVMaximumVoltageLimit:1;
-	unsigned int EVMaximumCurrentLimit:1;
-	unsigned int EVMaximumPowerLimit:1;
-	unsigned int BulkChargingComplete:1;
-	unsigned int RemainingTimeToFullSoC:1;
-	unsigned int RemainingTimeToBulkSoC:1;
-
-
-};
-
-struct CurrentDemandReqType
-{
-	struct DC_EVStatusType DC_EVStatus;
-	struct PhysicalValueType EVTargetCurrent;
-	struct PhysicalValueType EVMaximumVoltageLimit;
-	struct PhysicalValueType EVMaximumCurrentLimit;
-	struct PhysicalValueType EVMaximumPowerLimit;
-	int BulkChargingComplete;
-	int ChargingComplete;
-	struct PhysicalValueType RemainingTimeToFullSoC;
-	struct PhysicalValueType RemainingTimeToBulkSoC;
-	struct PhysicalValueType EVTargetVoltage;
-	struct selection_CurrentDemandReqType isused;
-
-};
-
-struct selection_CurrentDemandResType
-{
-	unsigned int EVSEMaximumVoltageLimit:1;
-	unsigned int EVSEMaximumCurrentLimit:1;
-	unsigned int EVSEMaximumPowerLimit:1;
-
-
-};
-
-struct CurrentDemandResType
-{
-	enum responseCodeType ResponseCode;
-	struct DC_EVSEStatusType DC_EVSEStatus;
-	struct PhysicalValueType EVSEPresentVoltage;
-	struct PhysicalValueType EVSEPresentCurrent;
-	int EVSECurrentLimitAchieved;
-	int EVSEVoltageLimitAchieved;
-	int EVSEPowerLimitAchieved;
-	struct PhysicalValueType EVSEMaximumVoltageLimit;
-	struct PhysicalValueType EVSEMaximumCurrentLimit;
-	struct PhysicalValueType EVSEMaximumPowerLimit;
-	struct selection_CurrentDemandResType isused;
-
-};
-
-struct WeldingDetectionReqType
-{
-	struct DC_EVStatusType DC_EVStatus;
-
-
-};
-
-struct WeldingDetectionResType
-{
-	enum responseCodeType ResponseCode;
-	struct DC_EVSEStatusType DC_EVSEStatus;
-	struct PhysicalValueType EVSEPresentVoltage;
-
-
-};
-
-struct BodyType
-{
-	struct SessionSetupReqType* SessionSetupReq;
-	struct SessionSetupResType* SessionSetupRes;
-	struct ServiceDiscoveryReqType* ServiceDiscoveryReq;
-	struct ServiceDiscoveryResType* ServiceDiscoveryRes;
-	struct ServiceDetailReqType* ServiceDetailReq;
-	struct ServiceDetailResType* ServiceDetailRes;
-	struct ServicePaymentSelectionReqType* ServicePaymentSelectionReq;
-	struct ServicePaymentSelectionResType* ServicePaymentSelectionRes;
-	struct PaymentDetailsReqType* PaymentDetailsReq;
-	struct PaymentDetailsResType* PaymentDetailsRes;
-	struct ContractAuthenticationReqType* ContractAuthenticationReq;
-	struct ContractAuthenticationResType* ContractAuthenticationRes;
-	struct ChargeParameterDiscoveryReqType* ChargeParameterDiscoveryReq;
-	struct ChargeParameterDiscoveryResType* ChargeParameterDiscoveryRes;
-	struct PowerDeliveryReqType* PowerDeliveryReq;
-	struct PowerDeliveryResType* PowerDeliveryRes;
-	struct ChargingStatusReqType* ChargingStatusReq;
-	struct ChargingStatusResType* ChargingStatusRes;
-	struct MeteringReceiptReqType* MeteringReceiptReq;
-	struct MeteringReceiptResType* MeteringReceiptRes;
-	struct SessionStopType* SessionStopReq;
-	struct SessionStopResType* SessionStopRes;
-	struct CertificateUpdateReqType* CertificateUpdateReq;
-	struct CertificateUpdateResType* CertificateUpdateRes;
-	struct CertificateInstallationReqType* CertificateInstallationReq;
-	struct CertificateInstallationResType* CertificateInstallationRes;
-	struct CableCheckReqType* CableCheckReq;
-	struct CableCheckResType* CableCheckRes;
-	struct PreChargeReqType* PreChargeReq;
-	struct PreChargeResType* PreChargeRes;
-	struct CurrentDemandReqType* CurrentDemandReq;
-	struct CurrentDemandResType* CurrentDemandRes;
-	struct WeldingDetectionReqType* WeldingDetectionReq;
-	struct WeldingDetectionResType* WeldingDetectionRes;
-	struct selection_BodyType isused;
-
-};
-
-struct AnonType_V2G_Message
-{
-	struct MessageHeaderType* Header;
-	struct BodyType Body;
-
-
-};
-
-struct EXIDocumentType
-{
-	struct AnonType_V2G_Message V2G_Message;
-
-
-};
-
-/* init methods */
-/*void init_EXIDocumentType(struct EXIDocumentType* type);
-void init_ServiceDiscoveryResType(struct ServiceDiscoveryResType* type);
-*/
-
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 83
src/service/v2g_service.h

@@ -1,83 +0,0 @@
-/*
- * Copyright (C) 2007-2010 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef EXI_SERVICE_H_
-#define EXI_SERVICE_H_
-
-#include "v2g_dataTypes.h"
-#include "EXITypes.h"
-
-struct uniqueIDPath
-{
-	int id[10];
-	size_t pos;
-};
-
-
-struct EXIService
-{
-	/* in-/ out-stream */
-	bitstream_t inStream;
-	bitstream_t outStream;
-
-	/* EXI */
-	exi_state_t stateDecode;
-	exi_state_t stateEncode;
-	exi_event_t event;
-	uint16_t qnameID;
-	exi_value_t val;
-
-	/* v2g message data structure */
-	struct EXIDocumentType exiMsg;
-
-	/* unique id for ambiguous elements */
-	struct uniqueIDPath idPath;
-
-	/* error code */
-	uint8_t errorCode;
-
-	/* offset for transported header data */
-	uint16_t transportHeaderOffset;
-};
-
-/* define error codes */
-#define EXI_NON_VALID_MESSAGE 0x01
-#define EXI_SERIALIZATION_FAILED 0x02
-#define EXI_DESERIALIZATION_FAILED 0x03
-#define EXI_DATATYPE_FAILED 0x04
-#define EXI_VALUE_RANGE_FAILED 0x05
-#define EXI_SERVICE_CALL_FAILED 0x06
-
-#define EXI_UNKNOWN_ERROR 0xFF
-
-#endif /* EXI_SERVICE_H_ */
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 44
src/service/v2g_serviceClientDataTransmitter.h

@@ -1,44 +0,0 @@
-
-/*
- * Copyright (C) 2007-2010 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef V2G_SERVICECLIENTDATATRANSMITTER_H_
-#define V2G_SERVICECLIENTDATATRANSMITTER_H_
-
-#include "EXITypes.h"
-
-/* This method has to be implemented!
- * This method sends EXI stream (outStream) to the EVSE and receives response stream (inStream)*/
-int serviceDataTransmitter(uint8_t* outStream, uint16_t outStreamLength, uint8_t* inStream);
-
-#endif /* V2G_SERVICECLIENTDATATRANSMITTER_H_ */
-
-#ifdef __cplusplus
-}
-#endif

تفاوت فایلی نمایش داده نمی شود زیرا این فایل بسیار بزرگ است
+ 0 - 2743
src/service/v2g_serviceClientStubs.c


+ 0 - 320
src/service/v2g_serviceClientStubs.h

@@ -1,320 +0,0 @@
-
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
- 
- 
- #ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef SERVICECLIENTSTUBS_H
-#define SERVICECLIENTSTUBS_H
-
- #include "v2g_service.h"
- #include "v2g_dataTypes.h"
- #include "v2g_serviceClientStubs.h"
-
-
-
-
-enum responseMessages
-{
-	 SESSIONSETUPRES,
-
-	 SERVICEDISCOVERYRES,
-
-	 SERVICEDETAILRES,
-
-	 SERVICEPAYMENTSELECTIONRES,
-
-	 PAYMENTDETAILSRES,
-
-	 CONTRACTAUTHENTICATIONRES,
-
-	 CHARGEPARAMETERDISCOVERYRES,
-
-	 POWERDELIVERYRES,
-
-	 CHARGINGSTATUSRES,
-
-	 METERINGRECEIPTRES,
-
-	 CERTIFICATEUPDATERES,
-
-	 CERTIFICATEINSTALLATIONRES,
-
-	 CABLECHECKRES,
-
-	 PRECHARGERES,
-
-	 CURRENTDEMANDRES,
-
-	 WELDINGDETECTIONRES,
-
-	 SESSIONSTOPRES
-};
- 
-/**  
- * \brief   Prepares the remote sessionSetup call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct SessionSetupReqType* Request data for the server (has to be set up before)
- * \param	result   struct SessionSetupResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_sessionSetup(struct EXIService* service, struct MessageHeaderType* header, struct SessionSetupReqType* params, struct SessionSetupResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote serviceDiscovery call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct ServiceDiscoveryReqType* Request data for the server (has to be set up before)
- * \param	result   struct ServiceDiscoveryResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_serviceDiscovery(struct EXIService* service, struct MessageHeaderType* header, struct ServiceDiscoveryReqType* params, struct ServiceDiscoveryResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote serviceDetail call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct ServiceDetailReqType* Request data for the server (has to be set up before)
- * \param	result   struct ServiceDetailResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_serviceDetail(struct EXIService* service, struct MessageHeaderType* header, struct ServiceDetailReqType* params, struct ServiceDetailResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote servicePaymentSelection call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct ServicePaymentSelectionReqType* Request data for the server (has to be set up before)
- * \param	result   struct ServicePaymentSelectionResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_servicePaymentSelection(struct EXIService* service, struct MessageHeaderType* header, struct ServicePaymentSelectionReqType* params, struct ServicePaymentSelectionResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote paymentDetails call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct PaymentDetailsReqType* Request data for the server (has to be set up before)
- * \param	result   struct PaymentDetailsResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_paymentDetails(struct EXIService* service, struct MessageHeaderType* header, struct PaymentDetailsReqType* params, struct PaymentDetailsResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote contractAuthentication call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct ContractAuthenticationReqType* Request data for the server (has to be set up before)
- * \param	result   struct ContractAuthenticationResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_contractAuthentication(struct EXIService* service, struct MessageHeaderType* header, struct ContractAuthenticationReqType* params, struct ContractAuthenticationResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote chargeParameterDiscovery call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct ChargeParameterDiscoveryReqType* Request data for the server (has to be set up before)
- * \param	result   struct ChargeParameterDiscoveryResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_chargeParameterDiscovery(struct EXIService* service, struct MessageHeaderType* header, struct ChargeParameterDiscoveryReqType* params, struct ChargeParameterDiscoveryResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote powerDelivery call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct PowerDeliveryReqType* Request data for the server (has to be set up before)
- * \param	result   struct PowerDeliveryResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_powerDelivery(struct EXIService* service, struct MessageHeaderType* header, struct PowerDeliveryReqType* params, struct PowerDeliveryResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote chargingStatus call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
-  * \param	result   struct ChargingStatusResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_chargingStatus(struct EXIService* service, struct MessageHeaderType* header, struct ChargingStatusResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote meteringReceipt call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct MeteringReceiptReqType* Request data for the server (has to be set up before)
- * \param	result   struct MeteringReceiptResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_meteringReceipt(struct EXIService* service, struct MessageHeaderType* header, struct MeteringReceiptReqType* params, struct MeteringReceiptResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote certificateUpdate call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct CertificateUpdateReqType* Request data for the server (has to be set up before)
- * \param	result   struct CertificateUpdateResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_certificateUpdate(struct EXIService* service, struct MessageHeaderType* header, struct CertificateUpdateReqType* params, struct CertificateUpdateResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote certificateInstallation call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct CertificateInstallationReqType* Request data for the server (has to be set up before)
- * \param	result   struct CertificateInstallationResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_certificateInstallation(struct EXIService* service, struct MessageHeaderType* header, struct CertificateInstallationReqType* params, struct CertificateInstallationResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote cableCheck call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct CableCheckReqType* Request data for the server (has to be set up before)
- * \param	result   struct CableCheckResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_cableCheck(struct EXIService* service, struct MessageHeaderType* header, struct CableCheckReqType* params, struct CableCheckResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote preCharge call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct PreChargeReqType* Request data for the server (has to be set up before)
- * \param	result   struct PreChargeResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_preCharge(struct EXIService* service, struct MessageHeaderType* header, struct PreChargeReqType* params, struct PreChargeResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote currentDemand call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct CurrentDemandReqType* Request data for the server (has to be set up before)
- * \param	result   struct CurrentDemandResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_currentDemand(struct EXIService* service, struct MessageHeaderType* header, struct CurrentDemandReqType* params, struct CurrentDemandResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote weldingDetection call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
- * \param	params   struct WeldingDetectionReqType* Request data for the server (has to be set up before)
- * \param	result   struct WeldingDetectionResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_weldingDetection(struct EXIService* service, struct MessageHeaderType* header, struct WeldingDetectionReqType* params, struct WeldingDetectionResType* result);
-
- 
-
-	
-/**  
- * \brief   Prepares the remote sessionStop call
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	header   struct MessageHeaderType* Header data structure
-  * \param	result   struct SessionStopResType* Contains the response data from the server 
- * \return  0 = 0K; -1 = ERROR */
-	int prepare_sessionStop(struct EXIService* service, struct MessageHeaderType* header, struct SessionStopResType* result);
-
- 
-
-	
-
-
- /** 
- * \brief   Determines which response message was received
- * \param	service  struct EXIService* Service data structure (has to be initialized before)
- * \param	respMsg   enum responseMessages* contains the name of the response message 
-  * \param	result   struct SessionStopResType* Contains the response data from the server 
- * \return  0 = 0K; 0 != ERROR */ 
-int determineResponseMesssage(struct EXIService* service, enum responseMessages* respMsg);
-
-
-
-/** 
- * \brief  Initialize the v2g client
- * \param	service   struct EXIService* Service data structure
- * \param	service_bytes exi_bytes_t  Reserved for byte handling
- * \param	service_string exi_string_ucs_t  Reserved for string handling
- * \param	inStream  uint8_t* Instream buffer
- * \param	max_inStream_size size_t  Max size for an instream message
- * \param	outStream  uint8_t* Outstream buffer
- * \param   outPayloadLength uint32_t* Provides the length of the encoded request EXI message
- * \param	max_outStream_size size_t  Max size for an outstream message
- * \param	transportHeaderOffset uint16_t Transport protocol offset
- * \return  0 = 0K; -1 = ERROR
- */
-int init_v2gServiceClient(struct EXIService* service, exi_bytes_t service_bytes, exi_string_ucs_t service_string, uint8_t* inStream, size_t max_inStream_size, uint8_t* outStream, size_t max_outStream_size,uint32_t* outPayloadLength, uint16_t transportHeaderOffset);
- 
- 
-
- 
- 
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 7399
src/service/v2g_serviceDataSerialization.c

@@ -1,7399 +0,0 @@
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-#include "v2g_service.h"
-#include "v2g_dataTypes.h"
-#include "EXITypes.h"
-#include "EXIEncoder.h"
-#include <string.h>
- 
- 
- 
- 
- 
-
-static int serialize_NotificationType(struct NotificationType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element FaultCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 326))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->FaultCode;
-		   
-			
-			/* encode character  FaultCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of FaultCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.FaultMsg)
-		{		
-						
-
-
-			/* encode start element FaultMsg */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 327))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->FaultMsg.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->FaultMsg.data,type->FaultMsg.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  FaultMsg */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of FaultMsg */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_CanonicalizationMethodType(struct CanonicalizationMethodType* type, 
-struct EXIService* service)
-{
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Algorithm.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Algorithm.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 0,&(service->val)))
-			{
-					return -1;
-			}
-
-
-	return 0;			
-}
-
-
-static int serialize_SignatureMethodType(struct SignatureMethodType* type, 
-struct EXIService* service)
-{
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Algorithm.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Algorithm.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 0,&(service->val)))
-			{
-					return -1;
-			}
-
-
-	return 0;			
-}
-
-
-static int serialize_DigestMethodType(struct DigestMethodType* type, 
-struct EXIService* service)
-{
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Algorithm.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Algorithm.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 0,&(service->val)))
-			{
-					return -1;
-			}
-
-
-	return 0;			
-}
-
-
-static int serialize_ReferenceType(struct ReferenceType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-
-	if(type->isused.attr_URI)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_URI.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_URI.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 7,&(service->val)))
-			{
-					return -1;
-			}
-		}
-
-	if(type->isused.attr_Type)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Type.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Type.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 6,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element DigestMethod */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 66))
-			{
-					return -1;
-			}
-						
-			/* encode children of DigestMethod */
-			if(serialize_DigestMethodType( &(type->DigestMethod),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DigestMethod */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DigestValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 68))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->DigestValue.arraylen.data;
-		    memcpy(service->val.binary.data, type->DigestValue.data,type->DigestValue.arraylen.data);
-		   
-
-		
-		
-		/* encode character  DigestValue */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of DigestValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_SignedInfoType(struct SignedInfoType* type, 
-struct EXIService* service)
-{
-
-
-	
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element CanonicalizationMethod */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 61))
-			{
-					return -1;
-			}
-						
-			/* encode children of CanonicalizationMethod */
-			if(serialize_CanonicalizationMethodType( &(type->CanonicalizationMethod),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CanonicalizationMethod */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element SignatureMethod */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 104))
-			{
-					return -1;
-			}
-						
-			/* encode children of SignatureMethod */
-			if(serialize_SignatureMethodType( &(type->SignatureMethod),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SignatureMethod */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-			/* encode start element Reference */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 95))
-			{
-					return -1;
-			}
-			
-			/* encode children of Reference */
-			if(serialize_ReferenceType(&(type->Reference[0]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of Reference */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-
-				
-
-	return 0;			
-}
-
-
-
-static int serialize_X509IssuerSerialType(struct X509IssuerSerialType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element X509IssuerName */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 123))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->X509IssuerName.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->X509IssuerName.data,type->X509IssuerName.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  X509IssuerName */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of X509IssuerName */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element X509SerialNumber */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 127))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int64=type->X509SerialNumber;
-		   
-			service->val.integer.type = EXI_INTEGER_64;
-			
-			/* encode character  X509SerialNumber */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of X509SerialNumber */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_X509DataType(struct X509DataType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element X509IssuerSerial */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 124))
-			{
-					return -1;
-			}
-						
-			/* encode children of X509IssuerSerial */
-			if(serialize_X509IssuerSerialType( &(type->X509IssuerSerial),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of X509IssuerSerial */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element X509SKI */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 126))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->X509SKI.arraylen.data;
-		    memcpy(service->val.binary.data, type->X509SKI.data,type->X509SKI.arraylen.data);
-		   
-
-		
-		
-		/* encode character  X509SKI */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of X509SKI */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element X509SubjectName */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 128))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->X509SubjectName.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->X509SubjectName.data,type->X509SubjectName.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  X509SubjectName */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of X509SubjectName */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element X509Certificate */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 120))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->X509Certificate.arraylen.data;
-		    memcpy(service->val.binary.data, type->X509Certificate.data,type->X509Certificate.arraylen.data);
-		   
-
-		
-		
-		/* encode character  X509Certificate */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of X509Certificate */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element X509CRL */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 119))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->X509CRL.arraylen.data;
-		    memcpy(service->val.binary.data, type->X509CRL.data,type->X509CRL.arraylen.data);
-		   
-
-		
-		
-		/* encode character  X509CRL */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of X509CRL */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_KeyInfoType(struct KeyInfoType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element X509Data */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 121))
-			{
-					return -1;
-			}
-						
-			/* encode children of X509Data */
-			if(serialize_X509DataType( &(type->X509Data),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of X509Data */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_SignatureType(struct SignatureType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element SignedInfo */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 113))
-			{
-					return -1;
-			}
-						
-			/* encode children of SignedInfo */
-			if(serialize_SignedInfoType( &(type->SignedInfo),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SignedInfo */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element SignatureValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 111))
-			{
-					return -1;
-			}
-						
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-			service->val.binary.len = type->SignatureValue.arraylen.data;
-			service->val.binary.data= type->SignatureValue.data;
-
-		/* encode character  DigestValue */
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-
-				return -1;
-		}
-
-
-
-			 
-			/* encode end element of SignatureValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.KeyInfo)
-		{		
-						
-
-
-			/* encode start element KeyInfo */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 75))
-			{
-					return -1;
-			}
-						
-			/* encode children of KeyInfo */
-			if(serialize_KeyInfoType( &(type->KeyInfo),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of KeyInfo */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_MessageHeaderType(struct MessageHeaderType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element SessionID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 445))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_HEX;
-		    service->val.binary.len = type->SessionID.arraylen.data;
-		    memcpy(service->val.binary.data, type->SessionID.data,type->SessionID.arraylen.data);
-		   
-
-		
-		
-		/* encode character  SessionID */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of SessionID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.Notification)
-		{		
-						
-
-
-			/* encode start element Notification */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 444))
-			{
-					return -1;
-			}
-						
-			/* encode children of Notification */
-			if(serialize_NotificationType( &(type->Notification),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of Notification */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.Signature)
-		{		
-						
-
-
-			/* encode start element Signature */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 103))
-			{
-					return -1;
-			}
-						
-			/* encode children of Signature */
-			if(serialize_SignatureType( (type->Signature),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of Signature */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SessionSetupReqType(struct SessionSetupReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element EVCCID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 171))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_HEX;
-		    service->val.binary.len = type->EVCCID.arraylen.data;
-		    memcpy(service->val.binary.data, type->EVCCID.data,type->EVCCID.arraylen.data);
-		   
-
-		
-		
-		/* encode character  EVCCID */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of EVCCID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_SessionSetupResType(struct SessionSetupResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 177))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_HEX;
-		    service->val.binary.len = type->EVSEID.arraylen.data;
-		    memcpy(service->val.binary.data, type->EVSEID.data,type->EVSEID.arraylen.data);
-		   
-
-		
-		
-		/* encode character  EVSEID */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of EVSEID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.DateTimeNow)
-		{		
-						
-
-
-			/* encode start element DateTimeNow */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 170))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int64=type->DateTimeNow;
-		   
-			service->val.integer.type = EXI_INTEGER_64;
-			
-			/* encode character  DateTimeNow */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of DateTimeNow */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceDiscoveryReqType(struct ServiceDiscoveryReqType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.ServiceScope)
-		{		
-						
-
-
-			/* encode start element ServiceScope */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 235))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ServiceScope.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ServiceScope.data,type->ServiceScope.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ServiceScope */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ServiceScope */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServiceCategory)
-		{		
-						
-
-
-			/* encode start element ServiceCategory */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 219))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ServiceCategory;
-		   
-			
-			/* encode character  ServiceCategory */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ServiceCategory */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_PaymentOptionsType(struct PaymentOptionsType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.PaymentOption;i_loop++)
-		{
-				
-
-
-			/* encode start element PaymentOption */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 352))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->PaymentOption[i_loop];
-			
-			/* encode character  PaymentOption */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of PaymentOption */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceTagType(struct ServiceTagType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ServiceID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 383))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint16=type->ServiceID;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_16;
-			
-			/* encode character  ServiceID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ServiceID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ServiceName)
-		{		
-						
-
-
-			/* encode start element ServiceName */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 384))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ServiceName.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ServiceName.data,type->ServiceName.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ServiceName */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ServiceName */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element ServiceCategory */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 380))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ServiceCategory;
-		   
-			
-			/* encode character  ServiceCategory */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ServiceCategory */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ServiceScope)
-		{		
-						
-
-
-			/* encode start element ServiceScope */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 386))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ServiceScope.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ServiceScope.data,type->ServiceScope.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ServiceScope */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ServiceScope */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceChargeType(struct ServiceChargeType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ServiceTag */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 387))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceTag */
-			if(serialize_ServiceTagType( &(type->ServiceTag),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceTag */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element FreeService */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 328))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->FreeService;
-		   
-			
-			/* encode character  FreeService */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of FreeService */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EnergyTransferType */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 323))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EnergyTransferType;
-		   
-			
-			/* encode character  EnergyTransferType */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EnergyTransferType */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ServiceType(struct ServiceType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ServiceTag */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 387))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceTag */
-			if(serialize_ServiceTagType( &(type->ServiceTag),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceTag */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element FreeService */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 328))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->FreeService;
-		   
-			
-			/* encode character  FreeService */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of FreeService */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ServiceTagListType(struct ServiceTagListType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.Service;i_loop++)
-		{
-				
-
-
-			/* encode start element Service */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 379))
-			{
-					return -1;
-			}
-			
-			/* encode children of Service */
-			if(serialize_ServiceType(&(type->Service[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of Service */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceDiscoveryResType(struct ServiceDiscoveryResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element PaymentOptions */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 201))
-			{
-					return -1;
-			}
-						
-			/* encode children of PaymentOptions */
-			if(serialize_PaymentOptionsType( &(type->PaymentOptions),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PaymentOptions */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ChargeService */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 149))
-			{
-					return -1;
-			}
-						
-			/* encode children of ChargeService */
-			if(serialize_ServiceChargeType( &(type->ChargeService),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ChargeService */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ServiceList)
-		{		
-						
-
-
-			/* encode start element ServiceList */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 229))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceList */
-			if(serialize_ServiceTagListType( &(type->ServiceList),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceList */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceDetailReqType(struct ServiceDetailReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ServiceID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 228))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint16=type->ServiceID;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_16;
-			
-			/* encode character  ServiceID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ServiceID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_PhysicalValueType(struct PhysicalValueType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element Multiplier */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 336))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.int8=type->Multiplier;
-		   
-			service->val.integer.type = EXI_INTEGER_8;
-			
-			/* encode character  Multiplier */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of Multiplier */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.Unit)
-		{		
-						
-
-
-			/* encode start element Unit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 396))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->Unit;
-		   
-			
-			/* encode character  Unit */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of Unit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element Value */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 397))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->Value;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  Value */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of Value */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ParameterType(struct ParameterType* type, 
-struct EXIService* service)
-{
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Name.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Name.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 4,&(service->val)))
-			{
-					return -1;
-			}
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_ValueType.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_ValueType.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 8,&(service->val)))
-			{
-					return -1;
-			}
-		
-
-
-			/* encode start element boolValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 400))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->boolValue;
-		   
-			
-			/* encode character  boolValue */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of boolValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element byteValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 401))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.int8=type->byteValue;
-		   
-			service->val.integer.type = EXI_INTEGER_8;
-			
-			/* encode character  byteValue */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of byteValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element shortValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 428))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->shortValue;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  shortValue */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of shortValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element intValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 413))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int32=type->intValue;
-		   
-			service->val.integer.type = EXI_INTEGER_32;
-			
-			/* encode character  intValue */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of intValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element physicalValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 419))
-			{
-					return -1;
-			}
-						
-			/* encode children of physicalValue */
-			if(serialize_PhysicalValueType( &(type->physicalValue),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of physicalValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element stringValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 432))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->stringValue.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->stringValue.data,type->stringValue.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  stringValue */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of stringValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ParameterSetType(struct ParameterSetType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-			
-
-
-			/* encode start element ParameterSetID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 349))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->ParameterSetID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  ParameterSetID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ParameterSetID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	for(i_loop=0;i_loop < type->arraylen.Parameter;i_loop++)
-		{
-				
-
-
-			/* encode start element Parameter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 347))
-			{
-					return -1;
-			}
-			
-			/* encode children of Parameter */
-			if(serialize_ParameterType(&(type->Parameter[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of Parameter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceParameterListType(struct ServiceParameterListType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.ParameterSet;i_loop++)
-		{
-				
-
-
-			/* encode start element ParameterSet */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 348))
-			{
-					return -1;
-			}
-			
-			/* encode children of ParameterSet */
-			if(serialize_ParameterSetType(&(type->ParameterSet[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of ParameterSet */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServiceDetailResType(struct ServiceDetailResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ServiceID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 228))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint16=type->ServiceID;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_16;
-			
-			/* encode character  ServiceID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ServiceID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ServiceParameterList)
-		{		
-						
-
-
-			/* encode start element ServiceParameterList */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 230))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceParameterList */
-			if(serialize_ServiceParameterListType( &(type->ServiceParameterList),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceParameterList */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SelectedServiceType(struct SelectedServiceType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ServiceID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 383))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint16=type->ServiceID;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_16;
-			
-			/* encode character  ServiceID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ServiceID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ParameterSetID)
-		{		
-						
-
-
-			/* encode start element ParameterSetID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 349))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->ParameterSetID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  ParameterSetID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ParameterSetID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SelectedServiceListType(struct SelectedServiceListType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.SelectedService;i_loop++)
-		{
-				
-
-
-			/* encode start element SelectedService */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 376))
-			{
-					return -1;
-			}
-			
-			/* encode children of SelectedService */
-			if(serialize_SelectedServiceType(&(type->SelectedService[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of SelectedService */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ServicePaymentSelectionReqType(struct ServicePaymentSelectionReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element SelectedPaymentOption */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 217))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->SelectedPaymentOption;
-		   
-			
-			/* encode character  SelectedPaymentOption */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SelectedPaymentOption */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element SelectedServiceList */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 218))
-			{
-					return -1;
-			}
-						
-			/* encode children of SelectedServiceList */
-			if(serialize_SelectedServiceListType( &(type->SelectedServiceList),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SelectedServiceList */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ServicePaymentSelectionResType(struct ServicePaymentSelectionResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_SubCertificatesType(struct SubCertificatesType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.Certificate;i_loop++)
-		{
-				
-
-
-			/* encode start element Certificate */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 257))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->Certificate[i_loop].arraylen.data;
-		    memcpy(service->val.binary.data, type->Certificate[i_loop].data,type->Certificate[i_loop].arraylen.data);
-
-		
-		
-		/* encode character  Certificate */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of Certificate */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_CertificateChainType(struct CertificateChainType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element Certificate */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 257))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->Certificate.arraylen.data;
-		    memcpy(service->val.binary.data, type->Certificate.data,type->Certificate.arraylen.data);
-		   
-
-		
-		
-		/* encode character  Certificate */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of Certificate */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.SubCertificates)
-		{		
-						
-
-
-			/* encode start element SubCertificates */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 392))
-			{
-					return -1;
-			}
-						
-			/* encode children of SubCertificates */
-			if(serialize_SubCertificatesType( &(type->SubCertificates),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SubCertificates */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_PaymentDetailsReqType(struct PaymentDetailsReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ContractID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 160))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ContractID.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ContractID.data,type->ContractID.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ContractID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ContractID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractSignatureCertChain */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 161))
-			{
-					return -1;
-			}
-						
-			/* encode children of ContractSignatureCertChain */
-			if(serialize_CertificateChainType( &(type->ContractSignatureCertChain),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ContractSignatureCertChain */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_PaymentDetailsResType(struct PaymentDetailsResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element GenChallenge */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 189))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->GenChallenge.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->GenChallenge.data,type->GenChallenge.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  GenChallenge */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of GenChallenge */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DateTimeNow */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 170))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int64=type->DateTimeNow;
-		   
-			service->val.integer.type = EXI_INTEGER_64;
-			
-			/* encode character  DateTimeNow */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of DateTimeNow */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ContractAuthenticationReqType(struct ContractAuthenticationReqType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-
-	if(type->isused.GenChallenge)
-		{		
-						
-
-
-			/* encode start element GenChallenge */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 189))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->GenChallenge.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->GenChallenge.data,type->GenChallenge.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  GenChallenge */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of GenChallenge */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ContractAuthenticationResType(struct ContractAuthenticationResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEProcessing */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 185))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSEProcessing;
-		   
-			
-			/* encode character  EVSEProcessing */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEProcessing */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_AC_EVChargeParameterType(struct AC_EVChargeParameterType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DepartureTime */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 279))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->DepartureTime;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  DepartureTime */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of DepartureTime */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EAmount */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 280))
-			{
-					return -1;
-			}
-						
-			/* encode children of EAmount */
-			if(serialize_PhysicalValueType( &(type->EAmount),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EAmount */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVMaxVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 289))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaxVoltage */
-			if(serialize_PhysicalValueType( &(type->EVMaxVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaxVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVMaxCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 288))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaxCurrent */
-			if(serialize_PhysicalValueType( &(type->EVMaxCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaxCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVMinCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 293))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMinCurrent */
-			if(serialize_PhysicalValueType( &(type->EVMinCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMinCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_DC_EVStatusType(struct DC_EVStatusType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element EVReady */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 298))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->EVReady;
-		   
-			
-			/* encode character  EVReady */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVReady */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVCabinConditioning)
-		{		
-						
-
-
-			/* encode start element EVCabinConditioning */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 282))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->EVCabinConditioning;
-		   
-			
-			/* encode character  EVCabinConditioning */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVCabinConditioning */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.EVRESSConditioning)
-		{		
-						
-
-
-			/* encode start element EVRESSConditioning */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 296))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->EVRESSConditioning;
-		   
-			
-			/* encode character  EVRESSConditioning */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVRESSConditioning */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element EVErrorCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 287))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVErrorCode;
-		   
-			
-			/* encode character  EVErrorCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVErrorCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVRESSSOC */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 297))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.int8=type->EVRESSSOC;
-		   
-			service->val.integer.type = EXI_INTEGER_8;
-			
-			/* encode character  EVRESSSOC */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVRESSSOC */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_DC_EVChargeParameterType(struct DC_EVChargeParameterType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 277))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVStatus */
-			if(serialize_DC_EVStatusType( &(type->DC_EVStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVMaximumCurrentLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 290))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaximumCurrentLimit */
-			if(serialize_PhysicalValueType( &(type->EVMaximumCurrentLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaximumCurrentLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVMaximumPowerLimit)
-		{		
-						
-
-
-			/* encode start element EVMaximumPowerLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 291))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaximumPowerLimit */
-			if(serialize_PhysicalValueType( &(type->EVMaximumPowerLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaximumPowerLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element EVMaximumVoltageLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 292))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaximumVoltageLimit */
-			if(serialize_PhysicalValueType( &(type->EVMaximumVoltageLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaximumVoltageLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVEnergyCapacity)
-		{		
-						
-
-
-			/* encode start element EVEnergyCapacity */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 285))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVEnergyCapacity */
-			if(serialize_PhysicalValueType( &(type->EVEnergyCapacity),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVEnergyCapacity */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.EVEnergyRequest)
-		{		
-						
-
-
-			/* encode start element EVEnergyRequest */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 286))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVEnergyRequest */
-			if(serialize_PhysicalValueType( &(type->EVEnergyRequest),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVEnergyRequest */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.FullSOC)
-		{		
-						
-
-
-			/* encode start element FullSOC */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 329))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.int8=type->FullSOC;
-		   
-			service->val.integer.type = EXI_INTEGER_8;
-			
-			/* encode character  FullSOC */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of FullSOC */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.BulkSOC)
-		{		
-						
-
-
-			/* encode start element BulkSOC */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 256))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.int8=type->BulkSOC;
-		   
-			service->val.integer.type = EXI_INTEGER_8;
-			
-			/* encode character  BulkSOC */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of BulkSOC */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ChargeParameterDiscoveryReqType(struct ChargeParameterDiscoveryReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element EVRequestedEnergyTransferType */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 175))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVRequestedEnergyTransferType;
-		   
-			
-			/* encode character  EVRequestedEnergyTransferType */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVRequestedEnergyTransferType */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.AC_EVChargeParameter)
-		{		
-						
-
-
-			/* encode start element AC_EVChargeParameter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 249))
-			{
-					return -1;
-			}
-						
-			/* encode children of AC_EVChargeParameter */
-			if(serialize_AC_EVChargeParameterType( (type->AC_EVChargeParameter),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of AC_EVChargeParameter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.DC_EVChargeParameter)
-		{		
-						
-
-
-			/* encode start element DC_EVChargeParameter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 267))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVChargeParameter */
-			if(serialize_DC_EVChargeParameterType( (type->DC_EVChargeParameter),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVChargeParameter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_RelativeTimeIntervalType(struct RelativeTimeIntervalType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element start */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 430))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->start;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  start */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of start */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.duration)
-		{		
-						
-
-
-			/* encode start element duration */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 407))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->duration;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  duration */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of duration */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_PMaxScheduleEntryType(struct PMaxScheduleEntryType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element RelativeTimeInterval */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 359))
-			{
-					return -1;
-			}
-						
-			/* encode children of RelativeTimeInterval */
-			if(serialize_RelativeTimeIntervalType( &(type->RelativeTimeInterval),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of RelativeTimeInterval */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element PMax */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 340))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->PMax;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  PMax */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of PMax */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_PMaxScheduleType(struct PMaxScheduleType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-			
-
-
-			/* encode start element PMaxScheduleID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 344))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->PMaxScheduleID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  PMaxScheduleID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of PMaxScheduleID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	for(i_loop=0;i_loop < type->arraylen.PMaxScheduleEntry;i_loop++)
-		{
-				
-
-
-			/* encode start element PMaxScheduleEntry */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 342))
-			{
-					return -1;
-			}
-			
-			/* encode children of PMaxScheduleEntry */
-			if(serialize_PMaxScheduleEntryType(&(type->PMaxScheduleEntry[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of PMaxScheduleEntry */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_CostType(struct CostType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element costKind */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 404))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->costKind;
-		   
-			
-			/* encode character  costKind */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of costKind */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element amount */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 398))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->amount;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  amount */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of amount */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.amountMultiplier)
-		{		
-						
-
-
-			/* encode start element amountMultiplier */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 399))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.int8=type->amountMultiplier;
-		   
-			service->val.integer.type = EXI_INTEGER_8;
-			
-			/* encode character  amountMultiplier */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of amountMultiplier */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ConsumptionCostType(struct ConsumptionCostType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-			
-
-
-			/* encode start element startValue */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 431))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->startValue;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  startValue */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of startValue */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.Cost)
-		{		
-				
-	for(i_loop=0;i_loop < type->arraylen.Cost;i_loop++)
-		{
-				
-
-
-			/* encode start element Cost */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 265))
-			{
-					return -1;
-			}
-			
-			/* encode children of Cost */
-			if(serialize_CostType(&(type->Cost[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of Cost */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SalesTariffEntryType(struct SalesTariffEntryType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-			
-
-
-			/* encode start element RelativeTimeInterval */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 359))
-			{
-					return -1;
-			}
-						
-			/* encode children of RelativeTimeInterval */
-			if(serialize_RelativeTimeIntervalType( &(type->RelativeTimeInterval),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of RelativeTimeInterval */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EPriceLevel */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 281))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint8=type->EPriceLevel;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_8;
-			
-			/* encode character  EPriceLevel */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EPriceLevel */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ConsumptionCost)
-		{		
-				
-	for(i_loop=0;i_loop < type->arraylen.ConsumptionCost;i_loop++)
-		{
-				
-
-
-			/* encode start element ConsumptionCost */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 263))
-			{
-					return -1;
-			}
-			
-			/* encode children of ConsumptionCost */
-			if(serialize_ConsumptionCostType(&(type->ConsumptionCost[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of ConsumptionCost */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SalesTariffType(struct SalesTariffType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-			
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		
-
-
-			/* encode start element SalesTariffID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 374))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->SalesTariffID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  SalesTariffID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SalesTariffID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.SalesTariffDescription)
-		{		
-						
-
-
-			/* encode start element SalesTariffDescription */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 371))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->SalesTariffDescription.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->SalesTariffDescription.data,type->SalesTariffDescription.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  SalesTariffDescription */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of SalesTariffDescription */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element NumEPriceLevels */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 339))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_NBIT_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint8=type->NumEPriceLevels;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_8;
-			
-			/* encode character  NumEPriceLevels */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of NumEPriceLevels */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	for(i_loop=0;i_loop < type->arraylen.SalesTariffEntry;i_loop++)
-		{
-				
-
-
-			/* encode start element SalesTariffEntry */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 372))
-			{
-					return -1;
-			}
-			
-			/* encode children of SalesTariffEntry */
-			if(serialize_SalesTariffEntryType(&(type->SalesTariffEntry[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of SalesTariffEntry */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SAScheduleTupleType(struct SAScheduleTupleType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element SAScheduleTupleID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 366))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->SAScheduleTupleID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  SAScheduleTupleID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SAScheduleTupleID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element PMaxSchedule */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 341))
-			{
-					return -1;
-			}
-						
-			/* encode children of PMaxSchedule */
-			if(serialize_PMaxScheduleType( &(type->PMaxSchedule),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PMaxSchedule */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.SalesTariff)
-		{		
-						
-
-
-			/* encode start element SalesTariff */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 370))
-			{
-					return -1;
-			}
-						
-			/* encode children of SalesTariff */
-			if(serialize_SalesTariffType( (type->SalesTariff),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SalesTariff */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_SAScheduleListType(struct SAScheduleListType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.SAScheduleTuple;i_loop++)
-		{
-				
-
-
-			/* encode start element SAScheduleTuple */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 365))
-			{
-					return -1;
-			}
-			
-			/* encode children of SAScheduleTuple */
-			if(serialize_SAScheduleTupleType(&(type->SAScheduleTuple[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of SAScheduleTuple */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_AC_EVSEStatusType(struct AC_EVSEStatusType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element PowerSwitchClosed */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 355))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->PowerSwitchClosed;
-		   
-			
-			/* encode character  PowerSwitchClosed */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of PowerSwitchClosed */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element RCD */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 358))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->RCD;
-		   
-			
-			/* encode character  RCD */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of RCD */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element NotificationMaxDelay */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 337))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->NotificationMaxDelay;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  NotificationMaxDelay */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of NotificationMaxDelay */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSENotification */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 313))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSENotification;
-		   
-			
-			/* encode character  EVSENotification */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSENotification */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_AC_EVSEChargeParameterType(struct AC_EVSEChargeParameterType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element AC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 253))
-			{
-					return -1;
-			}
-						
-			/* encode children of AC_EVSEStatus */
-			if(serialize_AC_EVSEStatusType( &(type->AC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of AC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEMaxVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 306))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaxVoltage */
-			if(serialize_PhysicalValueType( &(type->EVSEMaxVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaxVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEMaxCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 305))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaxCurrent */
-			if(serialize_PhysicalValueType( &(type->EVSEMaxCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaxCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEMinCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 310))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMinCurrent */
-			if(serialize_PhysicalValueType( &(type->EVSEMinCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMinCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_DC_EVSEStatusType(struct DC_EVSEStatusType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.EVSEIsolationStatus)
-		{		
-						
-
-
-			/* encode start element EVSEIsolationStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 304))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSEIsolationStatus;
-		   
-			
-			/* encode character  EVSEIsolationStatus */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEIsolationStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element EVSEStatusCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 318))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSEStatusCode;
-		   
-			
-			/* encode character  EVSEStatusCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEStatusCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element NotificationMaxDelay */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 337))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->NotificationMaxDelay;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  NotificationMaxDelay */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of NotificationMaxDelay */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSENotification */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 313))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSENotification;
-		   
-			
-			/* encode character  EVSENotification */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSENotification */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_DC_EVSEChargeParameterType(struct DC_EVSEChargeParameterType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 274))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEStatus */
-			if(serialize_DC_EVSEStatusType( &(type->DC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEMaximumCurrentLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 307))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaximumCurrentLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMaximumCurrentLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaximumCurrentLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVSEMaximumPowerLimit)
-		{		
-						
-
-
-			/* encode start element EVSEMaximumPowerLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 308))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaximumPowerLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMaximumPowerLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaximumPowerLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element EVSEMaximumVoltageLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 309))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaximumVoltageLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMaximumVoltageLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaximumVoltageLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEMinimumCurrentLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 311))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMinimumCurrentLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMinimumCurrentLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMinimumCurrentLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEMinimumVoltageLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 312))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMinimumVoltageLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMinimumVoltageLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMinimumVoltageLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVSECurrentRegulationTolerance)
-		{		
-						
-
-
-			/* encode start element EVSECurrentRegulationTolerance */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 302))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSECurrentRegulationTolerance */
-			if(serialize_PhysicalValueType( &(type->EVSECurrentRegulationTolerance),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSECurrentRegulationTolerance */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element EVSEPeakCurrentRipple */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 315))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEPeakCurrentRipple */
-			if(serialize_PhysicalValueType( &(type->EVSEPeakCurrentRipple),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEPeakCurrentRipple */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVSEEnergyToBeDelivered)
-		{		
-						
-
-
-			/* encode start element EVSEEnergyToBeDelivered */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 303))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEEnergyToBeDelivered */
-			if(serialize_PhysicalValueType( &(type->EVSEEnergyToBeDelivered),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEEnergyToBeDelivered */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ChargeParameterDiscoveryResType(struct ChargeParameterDiscoveryResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEProcessing */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 185))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSEProcessing;
-		   
-			
-			/* encode character  EVSEProcessing */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEProcessing */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element SAScheduleList */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 363))
-			{
-					return -1;
-			}
-						
-			/* encode children of SAScheduleList */
-			if(serialize_SAScheduleListType( &(type->SAScheduleList),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SAScheduleList */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.AC_EVSEChargeParameter)
-		{		
-						
-
-
-			/* encode start element AC_EVSEChargeParameter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 251))
-			{
-					return -1;
-			}
-						
-			/* encode children of AC_EVSEChargeParameter */
-			if(serialize_AC_EVSEChargeParameterType( (type->AC_EVSEChargeParameter),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of AC_EVSEChargeParameter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.DC_EVSEChargeParameter)
-		{		
-						
-
-
-			/* encode start element DC_EVSEChargeParameter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 272))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEChargeParameter */
-			if(serialize_DC_EVSEChargeParameterType( (type->DC_EVSEChargeParameter),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEChargeParameter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ProfileEntryType(struct ProfileEntryType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ChargingProfileEntryStart */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 261))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_UNSIGNED_INTEGER;
-		    service->val.integer.val.uint32=type->ChargingProfileEntryStart;
-		   
-			service->val.integer.type = EXI_UNSIGNED_INTEGER_32;
-			
-			/* encode character  ChargingProfileEntryStart */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ChargingProfileEntryStart */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ChargingProfileEntryMaxPower */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 260))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->ChargingProfileEntryMaxPower;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  ChargingProfileEntryMaxPower */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ChargingProfileEntryMaxPower */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ChargingProfileType(struct ChargingProfileType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-			
-
-
-			/* encode start element SAScheduleTupleID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 366))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->SAScheduleTupleID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  SAScheduleTupleID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SAScheduleTupleID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	for(i_loop=0;i_loop < type->arraylen.ProfileEntry;i_loop++)
-		{
-				
-
-
-			/* encode start element ProfileEntry */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 356))
-			{
-					return -1;
-			}
-			
-			/* encode children of ProfileEntry */
-			if(serialize_ProfileEntryType(&(type->ProfileEntry[i_loop]),service))
-			{
-				return -1;
-			}
-			
-			 
-			/* encode end element of ProfileEntry */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_DC_EVPowerDeliveryParameterType(struct DC_EVPowerDeliveryParameterType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 277))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVStatus */
-			if(serialize_DC_EVStatusType( &(type->DC_EVStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.BulkChargingComplete)
-		{		
-						
-
-
-			/* encode start element BulkChargingComplete */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 255))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->BulkChargingComplete;
-		   
-			
-			/* encode character  BulkChargingComplete */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of BulkChargingComplete */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element ChargingComplete */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 259))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->ChargingComplete;
-		   
-			
-			/* encode character  ChargingComplete */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ChargingComplete */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_PowerDeliveryReqType(struct PowerDeliveryReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ReadyToChargeState */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 210))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->ReadyToChargeState;
-		   
-			
-			/* encode character  ReadyToChargeState */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ReadyToChargeState */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.ChargingProfile)
-		{		
-						
-
-
-			/* encode start element ChargingProfile */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 151))
-			{
-					return -1;
-			}
-						
-			/* encode children of ChargingProfile */
-			if(serialize_ChargingProfileType( &(type->ChargingProfile),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ChargingProfile */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.DC_EVPowerDeliveryParameter)
-		{		
-						
-
-
-			/* encode start element DC_EVPowerDeliveryParameter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 270))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVPowerDeliveryParameter */
-			if(serialize_DC_EVPowerDeliveryParameterType( (type->DC_EVPowerDeliveryParameter),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVPowerDeliveryParameter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_PowerDeliveryResType(struct PowerDeliveryResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.AC_EVSEStatus)
-		{		
-						
-
-
-			/* encode start element AC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 253))
-			{
-					return -1;
-			}
-						
-			/* encode children of AC_EVSEStatus */
-			if(serialize_AC_EVSEStatusType( (type->AC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of AC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.DC_EVSEStatus)
-		{		
-						
-
-
-			/* encode start element DC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 274))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEStatus */
-			if(serialize_DC_EVSEStatusType( (type->DC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ChargingStatusReqType(struct ChargingStatusReqType* type, 
-struct EXIService* service)
-{
-
-
-	return 0;			
-}
-
-
-static int serialize_MeterInfoType(struct MeterInfoType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element MeterID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 332))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->MeterID.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->MeterID.data,type->MeterID.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  MeterID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of MeterID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.MeterReading)
-		{		
-						
-
-
-			/* encode start element MeterReading */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 334))
-			{
-					return -1;
-			}
-						
-			/* encode children of MeterReading */
-			if(serialize_PhysicalValueType( &(type->MeterReading),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of MeterReading */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.SigMeterReading)
-		{		
-						
-
-
-			/* encode start element SigMeterReading */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 391))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->SigMeterReading.arraylen.data;
-		    memcpy(service->val.binary.data, type->SigMeterReading.data,type->SigMeterReading.arraylen.data);
-		   
-
-		
-		
-		/* encode character  SigMeterReading */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of SigMeterReading */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.MeterStatus)
-		{		
-						
-
-
-			/* encode start element MeterStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 335))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->MeterStatus;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  MeterStatus */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of MeterStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.TMeter)
-		{		
-						
-
-
-			/* encode start element TMeter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 394))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int64=type->TMeter;
-		   
-			service->val.integer.type = EXI_INTEGER_64;
-			
-			/* encode character  TMeter */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of TMeter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_ChargingStatusResType(struct ChargingStatusResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 177))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_HEX;
-		    service->val.binary.len = type->EVSEID.arraylen.data;
-		    memcpy(service->val.binary.data, type->EVSEID.data,type->EVSEID.arraylen.data);
-		   
-
-		
-		
-		/* encode character  EVSEID */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of EVSEID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element SAScheduleTupleID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 216))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->SAScheduleTupleID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  SAScheduleTupleID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SAScheduleTupleID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVSEMaxCurrent)
-		{		
-						
-
-
-			/* encode start element EVSEMaxCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 178))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaxCurrent */
-			if(serialize_PhysicalValueType( &(type->EVSEMaxCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaxCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.MeterInfo)
-		{		
-						
-
-
-			/* encode start element MeterInfo */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 191))
-			{
-					return -1;
-			}
-						
-			/* encode children of MeterInfo */
-			if(serialize_MeterInfoType( &(type->MeterInfo),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of MeterInfo */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element ReceiptRequired */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 211))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->ReceiptRequired;
-		   
-			
-			/* encode character  ReceiptRequired */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ReceiptRequired */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element AC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 131))
-			{
-					return -1;
-			}
-						
-			/* encode children of AC_EVSEStatus */
-			if(serialize_AC_EVSEStatusType( &(type->AC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of AC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_MeteringReceiptReqType(struct MeteringReceiptReqType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element SessionID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 236))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_HEX;
-		    service->val.binary.len = type->SessionID.arraylen.data;
-		    memcpy(service->val.binary.data, type->SessionID.data,type->SessionID.arraylen.data);
-		   
-
-		
-		
-		/* encode character  SessionID */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of SessionID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.SAScheduleTupleID)
-		{		
-						
-
-
-			/* encode start element SAScheduleTupleID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 216))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->SAScheduleTupleID;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  SAScheduleTupleID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of SAScheduleTupleID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element MeterInfo */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 191))
-			{
-					return -1;
-			}
-						
-			/* encode children of MeterInfo */
-			if(serialize_MeterInfoType( &(type->MeterInfo),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of MeterInfo */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_MeteringReceiptResType(struct MeteringReceiptResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element AC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 131))
-			{
-					return -1;
-			}
-						
-			/* encode children of AC_EVSEStatus */
-			if(serialize_AC_EVSEStatusType( &(type->AC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of AC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_SessionStopType(struct SessionStopType* type, 
-struct EXIService* service)
-{
-
-
-	return 0;			
-}
-
-
-static int serialize_SessionStopResType(struct SessionStopResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_ListOfRootCertificateIDsType(struct ListOfRootCertificateIDsType* type, 
-struct EXIService* service)
-{
-
-			size_t i_loop;
-	
-	for(i_loop=0;i_loop < type->arraylen.RootCertificateID;i_loop++)
-		{
-				
-
-
-			/* encode start element RootCertificateID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 361))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-		    service->val.str.miss.len = type->RootCertificateID[i_loop].arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->RootCertificateID[i_loop].data,type->RootCertificateID[i_loop].arraylen.data*sizeof(uint32_t));
-			
-				
-		
-			/* encode character  RootCertificateID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of RootCertificateID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_CertificateUpdateReqType(struct CertificateUpdateReqType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element ContractSignatureCertChain */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 161))
-			{
-					return -1;
-			}
-						
-			/* encode children of ContractSignatureCertChain */
-			if(serialize_CertificateChainType( &(type->ContractSignatureCertChain),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ContractSignatureCertChain */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 160))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ContractID.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ContractID.data,type->ContractID.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ContractID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ContractID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ListOfRootCertificateIDs */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 190))
-			{
-					return -1;
-			}
-						
-			/* encode children of ListOfRootCertificateIDs */
-			if(serialize_ListOfRootCertificateIDsType( &(type->ListOfRootCertificateIDs),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ListOfRootCertificateIDs */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DHParams */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 169))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->DHParams.arraylen.data;
-		    memcpy(service->val.binary.data, type->DHParams.data,type->DHParams.arraylen.data);
-		   
-
-		
-		
-		/* encode character  DHParams */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of DHParams */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CertificateUpdateResType(struct CertificateUpdateResType* type, 
-struct EXIService* service)
-{
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractSignatureCertChain */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 161))
-			{
-					return -1;
-			}
-						
-			/* encode children of ContractSignatureCertChain */
-			if(serialize_CertificateChainType( &(type->ContractSignatureCertChain),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ContractSignatureCertChain */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractSignatureEncryptedPrivateKey */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 162))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->ContractSignatureEncryptedPrivateKey.arraylen.data;
-		    memcpy(service->val.binary.data, type->ContractSignatureEncryptedPrivateKey.data,type->ContractSignatureEncryptedPrivateKey.arraylen.data);
-		   
-
-		
-		
-		/* encode character  ContractSignatureEncryptedPrivateKey */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of ContractSignatureEncryptedPrivateKey */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DHParams */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 169))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->DHParams.arraylen.data;
-		    memcpy(service->val.binary.data, type->DHParams.data,type->DHParams.arraylen.data);
-		   
-
-		
-		
-		/* encode character  DHParams */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of DHParams */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 160))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ContractID.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ContractID.data,type->ContractID.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ContractID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ContractID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element RetryCounter */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 215))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_INTEGER;
-		    service->val.integer.val.int16=type->RetryCounter;
-		   
-			service->val.integer.type = EXI_INTEGER_16;
-			
-			/* encode character  RetryCounter */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of RetryCounter */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CertificateInstallationReqType(struct CertificateInstallationReqType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.attr_Id)
-		{		
-						
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		}
-		
-
-
-			/* encode start element OEMProvisioningCert */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 196))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->OEMProvisioningCert.arraylen.data;
-		    memcpy(service->val.binary.data, type->OEMProvisioningCert.data,type->OEMProvisioningCert.arraylen.data);
-		   
-
-		
-		
-		/* encode character  OEMProvisioningCert */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of OEMProvisioningCert */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ListOfRootCertificateIDs */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 190))
-			{
-					return -1;
-			}
-						
-			/* encode children of ListOfRootCertificateIDs */
-			if(serialize_ListOfRootCertificateIDsType( &(type->ListOfRootCertificateIDs),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ListOfRootCertificateIDs */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DHParams */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 169))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->DHParams.arraylen.data;
-		    memcpy(service->val.binary.data, type->DHParams.data,type->DHParams.arraylen.data);
-		   
-
-		
-		
-		/* encode character  DHParams */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of DHParams */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CertificateInstallationResType(struct CertificateInstallationResType* type, 
-struct EXIService* service)
-{
-		
-
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.miss.len = type->attr_Id.arraylen.data;
-			service->val.str.miss.codepoints= type->attr_Id.data;
-			if (exiEncodeAttribute(&(service->outStream), &(service->stateEncode), 2,&(service->val)))
-			{
-					return -1;
-			}
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractSignatureCertChain */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 161))
-			{
-					return -1;
-			}
-						
-			/* encode children of ContractSignatureCertChain */
-			if(serialize_CertificateChainType( &(type->ContractSignatureCertChain),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ContractSignatureCertChain */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractSignatureEncryptedPrivateKey */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 162))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->ContractSignatureEncryptedPrivateKey.arraylen.data;
-		    memcpy(service->val.binary.data, type->ContractSignatureEncryptedPrivateKey.data,type->ContractSignatureEncryptedPrivateKey.arraylen.data);
-		   
-
-		
-		
-		/* encode character  ContractSignatureEncryptedPrivateKey */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of ContractSignatureEncryptedPrivateKey */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DHParams */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 169))
-			{
-					return -1;
-			}
-			service->val.type = EXI_DATATYPE_BINARY_BASE64;
-		    service->val.binary.len = type->DHParams.arraylen.data;
-		    memcpy(service->val.binary.data, type->DHParams.data,type->DHParams.arraylen.data);
-		   
-
-		
-		
-		/* encode character  DHParams */	
-		if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-		{
-				 
-				return -1;
-		}
-
-			
-			 
-			/* encode end element of DHParams */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element ContractID */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 160))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_STRING;
-			service->val.str.type = EXI_STRING_VALUE_MISS;
-			service->val.str.miss.len = type->ContractID.arraylen.data;
-			memcpy(service->val.str.miss.codepoints, type->ContractID.data,type->ContractID.arraylen.data*sizeof(uint32_t));
-		   
-				
-		
-			/* encode character  ContractID */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-					return -1;
-			}
-			
-			 
-			/* encode end element of ContractID */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CableCheckReqType(struct CableCheckReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 168))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVStatus */
-			if(serialize_DC_EVStatusType( &(type->DC_EVStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CableCheckResType(struct CableCheckResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 167))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEStatus */
-			if(serialize_DC_EVSEStatusType( &(type->DC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEProcessing */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 185))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->EVSEProcessing;
-		   
-			
-			/* encode character  EVSEProcessing */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEProcessing */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_PreChargeReqType(struct PreChargeReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 168))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVStatus */
-			if(serialize_DC_EVStatusType( &(type->DC_EVStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVTargetVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 188))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVTargetVoltage */
-			if(serialize_PhysicalValueType( &(type->EVTargetVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVTargetVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVTargetCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 187))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVTargetCurrent */
-			if(serialize_PhysicalValueType( &(type->EVTargetCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVTargetCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_PreChargeResType(struct PreChargeResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 167))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEStatus */
-			if(serialize_DC_EVSEStatusType( &(type->DC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEPresentVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 184))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEPresentVoltage */
-			if(serialize_PhysicalValueType( &(type->EVSEPresentVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEPresentVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CurrentDemandReqType(struct CurrentDemandReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 168))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVStatus */
-			if(serialize_DC_EVStatusType( &(type->DC_EVStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVTargetCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 187))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVTargetCurrent */
-			if(serialize_PhysicalValueType( &(type->EVTargetCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVTargetCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVMaximumVoltageLimit)
-		{		
-						
-
-
-			/* encode start element EVMaximumVoltageLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 174))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaximumVoltageLimit */
-			if(serialize_PhysicalValueType( &(type->EVMaximumVoltageLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaximumVoltageLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.EVMaximumCurrentLimit)
-		{		
-						
-
-
-			/* encode start element EVMaximumCurrentLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 172))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaximumCurrentLimit */
-			if(serialize_PhysicalValueType( &(type->EVMaximumCurrentLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaximumCurrentLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.EVMaximumPowerLimit)
-		{		
-						
-
-
-			/* encode start element EVMaximumPowerLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 173))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVMaximumPowerLimit */
-			if(serialize_PhysicalValueType( &(type->EVMaximumPowerLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVMaximumPowerLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.BulkChargingComplete)
-		{		
-						
-
-
-			/* encode start element BulkChargingComplete */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 132))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->BulkChargingComplete;
-		   
-			
-			/* encode character  BulkChargingComplete */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of BulkChargingComplete */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element ChargingComplete */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 150))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->ChargingComplete;
-		   
-			
-			/* encode character  ChargingComplete */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ChargingComplete */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.RemainingTimeToFullSoC)
-		{		
-						
-
-
-			/* encode start element RemainingTimeToFullSoC */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 213))
-			{
-					return -1;
-			}
-						
-			/* encode children of RemainingTimeToFullSoC */
-			if(serialize_PhysicalValueType( &(type->RemainingTimeToFullSoC),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of RemainingTimeToFullSoC */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.RemainingTimeToBulkSoC)
-		{		
-						
-
-
-			/* encode start element RemainingTimeToBulkSoC */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 212))
-			{
-					return -1;
-			}
-						
-			/* encode children of RemainingTimeToBulkSoC */
-			if(serialize_PhysicalValueType( &(type->RemainingTimeToBulkSoC),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of RemainingTimeToBulkSoC */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-						
-
-
-			/* encode start element EVTargetVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 188))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVTargetVoltage */
-			if(serialize_PhysicalValueType( &(type->EVTargetVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVTargetVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_CurrentDemandResType(struct CurrentDemandResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 167))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEStatus */
-			if(serialize_DC_EVSEStatusType( &(type->DC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEPresentVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 184))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEPresentVoltage */
-			if(serialize_PhysicalValueType( &(type->EVSEPresentVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEPresentVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEPresentCurrent */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 183))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEPresentCurrent */
-			if(serialize_PhysicalValueType( &(type->EVSEPresentCurrent),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEPresentCurrent */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSECurrentLimitAchieved */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 176))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->EVSECurrentLimitAchieved;
-		   
-			
-			/* encode character  EVSECurrentLimitAchieved */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSECurrentLimitAchieved */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEVoltageLimitAchieved */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 186))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->EVSEVoltageLimitAchieved;
-		   
-			
-			/* encode character  EVSEVoltageLimitAchieved */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEVoltageLimitAchieved */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEPowerLimitAchieved */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 182))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_BOOLEAN;
-		    service->val.boolean=type->EVSEPowerLimitAchieved;
-		   
-			
-			/* encode character  EVSEPowerLimitAchieved */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of EVSEPowerLimitAchieved */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-	if(type->isused.EVSEMaximumVoltageLimit)
-		{		
-						
-
-
-			/* encode start element EVSEMaximumVoltageLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 181))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaximumVoltageLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMaximumVoltageLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaximumVoltageLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.EVSEMaximumCurrentLimit)
-		{		
-						
-
-
-			/* encode start element EVSEMaximumCurrentLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 179))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaximumCurrentLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMaximumCurrentLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaximumCurrentLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.EVSEMaximumPowerLimit)
-		{		
-						
-
-
-			/* encode start element EVSEMaximumPowerLimit */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 180))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEMaximumPowerLimit */
-			if(serialize_PhysicalValueType( &(type->EVSEMaximumPowerLimit),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEMaximumPowerLimit */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_WeldingDetectionReqType(struct WeldingDetectionReqType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element DC_EVStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 168))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVStatus */
-			if(serialize_DC_EVStatusType( &(type->DC_EVStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_WeldingDetectionResType(struct WeldingDetectionResType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element ResponseCode */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 214))
-			{
-					return -1;
-			}
-			
-			service->val.type = EXI_DATATYPE_ENUMERATION;
-		    service->val.enumeration=type->ResponseCode;
-		   
-			
-			/* encode character  ResponseCode */	
-			if (exiEncodeCharacters(&(service->outStream), &(service->stateEncode), &(service->val)))
-			{
-				 
-				return -1;
-			}
-				
-			 
-			/* encode end element of ResponseCode */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element DC_EVSEStatus */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 167))
-			{
-					return -1;
-			}
-						
-			/* encode children of DC_EVSEStatus */
-			if(serialize_DC_EVSEStatusType( &(type->DC_EVSEStatus),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of DC_EVSEStatus */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element EVSEPresentVoltage */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 184))
-			{
-					return -1;
-			}
-						
-			/* encode children of EVSEPresentVoltage */
-			if(serialize_PhysicalValueType( &(type->EVSEPresentVoltage),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of EVSEPresentVoltage */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_BodyType(struct BodyType* type, 
-struct EXIService* service)
-{
-
-	if(type->isused.SessionSetupReq)
-		{		
-						
-
-
-			/* encode start element SessionSetupReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 237))
-			{
-					return -1;
-			}
-						
-			/* encode children of SessionSetupReq */
-			if(serialize_SessionSetupReqType( (type->SessionSetupReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SessionSetupReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.SessionSetupRes)
-		{		
-						
-
-
-			/* encode start element SessionSetupRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 239))
-			{
-					return -1;
-			}
-						
-			/* encode children of SessionSetupRes */
-			if(serialize_SessionSetupResType( (type->SessionSetupRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SessionSetupRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServiceDiscoveryReq)
-		{		
-						
-
-
-			/* encode start element ServiceDiscoveryReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 224))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceDiscoveryReq */
-			if(serialize_ServiceDiscoveryReqType( (type->ServiceDiscoveryReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceDiscoveryReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServiceDiscoveryRes)
-		{		
-						
-
-
-			/* encode start element ServiceDiscoveryRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 226))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceDiscoveryRes */
-			if(serialize_ServiceDiscoveryResType( (type->ServiceDiscoveryRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceDiscoveryRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServiceDetailReq)
-		{		
-						
-
-
-			/* encode start element ServiceDetailReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 220))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceDetailReq */
-			if(serialize_ServiceDetailReqType( (type->ServiceDetailReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceDetailReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServiceDetailRes)
-		{		
-						
-
-
-			/* encode start element ServiceDetailRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 222))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServiceDetailRes */
-			if(serialize_ServiceDetailResType( (type->ServiceDetailRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServiceDetailRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServicePaymentSelectionReq)
-		{		
-						
-
-
-			/* encode start element ServicePaymentSelectionReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 231))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServicePaymentSelectionReq */
-			if(serialize_ServicePaymentSelectionReqType( (type->ServicePaymentSelectionReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServicePaymentSelectionReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ServicePaymentSelectionRes)
-		{		
-						
-
-
-			/* encode start element ServicePaymentSelectionRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 233))
-			{
-					return -1;
-			}
-						
-			/* encode children of ServicePaymentSelectionRes */
-			if(serialize_ServicePaymentSelectionResType( (type->ServicePaymentSelectionRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ServicePaymentSelectionRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.PaymentDetailsReq)
-		{		
-						
-
-
-			/* encode start element PaymentDetailsReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 197))
-			{
-					return -1;
-			}
-						
-			/* encode children of PaymentDetailsReq */
-			if(serialize_PaymentDetailsReqType( (type->PaymentDetailsReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PaymentDetailsReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.PaymentDetailsRes)
-		{		
-						
-
-
-			/* encode start element PaymentDetailsRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 199))
-			{
-					return -1;
-			}
-						
-			/* encode children of PaymentDetailsRes */
-			if(serialize_PaymentDetailsResType( (type->PaymentDetailsRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PaymentDetailsRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ContractAuthenticationReq)
-		{		
-						
-
-
-			/* encode start element ContractAuthenticationReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 156))
-			{
-					return -1;
-			}
-						
-			/* encode children of ContractAuthenticationReq */
-			if(serialize_ContractAuthenticationReqType( (type->ContractAuthenticationReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ContractAuthenticationReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ContractAuthenticationRes)
-		{		
-						
-
-
-			/* encode start element ContractAuthenticationRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 158))
-			{
-					return -1;
-			}
-						
-			/* encode children of ContractAuthenticationRes */
-			if(serialize_ContractAuthenticationResType( (type->ContractAuthenticationRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ContractAuthenticationRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ChargeParameterDiscoveryReq)
-		{		
-						
-
-
-			/* encode start element ChargeParameterDiscoveryReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 145))
-			{
-					return -1;
-			}
-						
-			/* encode children of ChargeParameterDiscoveryReq */
-			if(serialize_ChargeParameterDiscoveryReqType( (type->ChargeParameterDiscoveryReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ChargeParameterDiscoveryReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ChargeParameterDiscoveryRes)
-		{		
-						
-
-
-			/* encode start element ChargeParameterDiscoveryRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 147))
-			{
-					return -1;
-			}
-						
-			/* encode children of ChargeParameterDiscoveryRes */
-			if(serialize_ChargeParameterDiscoveryResType( (type->ChargeParameterDiscoveryRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ChargeParameterDiscoveryRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.PowerDeliveryReq)
-		{		
-						
-
-
-			/* encode start element PowerDeliveryReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 202))
-			{
-					return -1;
-			}
-						
-			/* encode children of PowerDeliveryReq */
-			if(serialize_PowerDeliveryReqType( (type->PowerDeliveryReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PowerDeliveryReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.PowerDeliveryRes)
-		{		
-						
-
-
-			/* encode start element PowerDeliveryRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 204))
-			{
-					return -1;
-			}
-						
-			/* encode children of PowerDeliveryRes */
-			if(serialize_PowerDeliveryResType( (type->PowerDeliveryRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PowerDeliveryRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ChargingStatusReq)
-		{		
-						
-
-
-			/* encode start element ChargingStatusReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 152))
-			{
-					return -1;
-			}
-						
-			/* encode children of ChargingStatusReq */
-			if(serialize_ChargingStatusReqType( (type->ChargingStatusReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ChargingStatusReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.ChargingStatusRes)
-		{		
-						
-
-
-			/* encode start element ChargingStatusRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 154))
-			{
-					return -1;
-			}
-						
-			/* encode children of ChargingStatusRes */
-			if(serialize_ChargingStatusResType( (type->ChargingStatusRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of ChargingStatusRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.MeteringReceiptReq)
-		{		
-						
-
-
-			/* encode start element MeteringReceiptReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 192))
-			{
-					return -1;
-			}
-						
-			/* encode children of MeteringReceiptReq */
-			if(serialize_MeteringReceiptReqType( (type->MeteringReceiptReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of MeteringReceiptReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.MeteringReceiptRes)
-		{		
-						
-
-
-			/* encode start element MeteringReceiptRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 194))
-			{
-					return -1;
-			}
-						
-			/* encode children of MeteringReceiptRes */
-			if(serialize_MeteringReceiptResType( (type->MeteringReceiptRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of MeteringReceiptRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.SessionStopReq)
-		{		
-						
-
-
-			/* encode start element SessionStopReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 241))
-			{
-					return -1;
-			}
-						
-			/* encode children of SessionStopReq */
-			if(serialize_SessionStopType( (type->SessionStopReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SessionStopReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.SessionStopRes)
-		{		
-						
-
-
-			/* encode start element SessionStopRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 242))
-			{
-					return -1;
-			}
-						
-			/* encode children of SessionStopRes */
-			if(serialize_SessionStopResType( (type->SessionStopRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of SessionStopRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CertificateUpdateReq)
-		{		
-						
-
-
-			/* encode start element CertificateUpdateReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 141))
-			{
-					return -1;
-			}
-						
-			/* encode children of CertificateUpdateReq */
-			if(serialize_CertificateUpdateReqType( (type->CertificateUpdateReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CertificateUpdateReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CertificateUpdateRes)
-		{		
-						
-
-
-			/* encode start element CertificateUpdateRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 143))
-			{
-					return -1;
-			}
-						
-			/* encode children of CertificateUpdateRes */
-			if(serialize_CertificateUpdateResType( (type->CertificateUpdateRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CertificateUpdateRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CertificateInstallationReq)
-		{		
-						
-
-
-			/* encode start element CertificateInstallationReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 137))
-			{
-					return -1;
-			}
-						
-			/* encode children of CertificateInstallationReq */
-			if(serialize_CertificateInstallationReqType( (type->CertificateInstallationReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CertificateInstallationReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CertificateInstallationRes)
-		{		
-						
-
-
-			/* encode start element CertificateInstallationRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 139))
-			{
-					return -1;
-			}
-						
-			/* encode children of CertificateInstallationRes */
-			if(serialize_CertificateInstallationResType( (type->CertificateInstallationRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CertificateInstallationRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CableCheckReq)
-		{		
-						
-
-
-			/* encode start element CableCheckReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 133))
-			{
-					return -1;
-			}
-						
-			/* encode children of CableCheckReq */
-			if(serialize_CableCheckReqType( (type->CableCheckReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CableCheckReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CableCheckRes)
-		{		
-						
-
-
-			/* encode start element CableCheckRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 135))
-			{
-					return -1;
-			}
-						
-			/* encode children of CableCheckRes */
-			if(serialize_CableCheckResType( (type->CableCheckRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CableCheckRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.PreChargeReq)
-		{		
-						
-
-
-			/* encode start element PreChargeReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 206))
-			{
-					return -1;
-			}
-						
-			/* encode children of PreChargeReq */
-			if(serialize_PreChargeReqType( (type->PreChargeReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PreChargeReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.PreChargeRes)
-		{		
-						
-
-
-			/* encode start element PreChargeRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 208))
-			{
-					return -1;
-			}
-						
-			/* encode children of PreChargeRes */
-			if(serialize_PreChargeResType( (type->PreChargeRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of PreChargeRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CurrentDemandReq)
-		{		
-						
-
-
-			/* encode start element CurrentDemandReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 163))
-			{
-					return -1;
-			}
-						
-			/* encode children of CurrentDemandReq */
-			if(serialize_CurrentDemandReqType( (type->CurrentDemandReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CurrentDemandReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.CurrentDemandRes)
-		{		
-						
-
-
-			/* encode start element CurrentDemandRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 165))
-			{
-					return -1;
-			}
-						
-			/* encode children of CurrentDemandRes */
-			if(serialize_CurrentDemandResType( (type->CurrentDemandRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of CurrentDemandRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.WeldingDetectionReq)
-		{		
-						
-
-
-			/* encode start element WeldingDetectionReq */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 245))
-			{
-					return -1;
-			}
-						
-			/* encode children of WeldingDetectionReq */
-			if(serialize_WeldingDetectionReqType( (type->WeldingDetectionReq),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of WeldingDetectionReq */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-	if(type->isused.WeldingDetectionRes)
-		{		
-						
-
-
-			/* encode start element WeldingDetectionRes */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 247))
-			{
-					return -1;
-			}
-						
-			/* encode children of WeldingDetectionRes */
-			if(serialize_WeldingDetectionResType( (type->WeldingDetectionRes),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of WeldingDetectionRes */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		}
-				
-
-	return 0;			
-}
-
-
-static int serialize_AnonType_V2G_Message(struct AnonType_V2G_Message* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element Header */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 441))
-			{
-					return -1;
-			}
-						
-			/* encode children of Header */
-			if(serialize_MessageHeaderType( (type->Header),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of Header */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-				
-
-
-			/* encode start element Body */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 437))
-			{
-					return -1;
-			}
-						
-			/* encode children of Body */
-			if(serialize_BodyType( &(type->Body),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of Body */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
-
-static int serialize_EXIDocumentType(struct EXIDocumentType* type, 
-struct EXIService* service)
-{
-		
-
-
-			/* encode start element V2G_Message */	
-			if (exiEncodeStartElement(&(service->outStream), &(service->stateEncode), 442))
-			{
-					return -1;
-			}
-						
-			/* encode children of V2G_Message */
-			if(serialize_AnonType_V2G_Message( &(type->V2G_Message),service))
-			{
-				return -1;
-			}
-
-			
-			 
-			/* encode end element of V2G_Message */
-			exiEncodeEndElement(&(service->outStream), &(service->stateEncode));
-
-		
-
-	return 0;			
-}
-
- 
- 
- 
- 
-  /* serialize data to EXI stream */
-static int serialize_message(struct EXIService* service)
-{	
-
-	/* encode start document */ 	
-	if (exiEncodeStartDocument(&(service->outStream), &(service->stateEncode)) )
-	{
-	 
-		return -1;
-	}
-
- 	
-	/* encode root element of V2G_Message */
-	if (serialize_EXIDocumentType(&(service->exiMsg), service))
-	 
-	 
-	{
-			 
-		return -1;
-	}
-
-
-	/* encode end document */
-	if (exiEncodeEndDocument(&(service->outStream), &(service->stateEncode))) {
-	 
-	return -1;
-	}	
- 	
- 	return 0;
- 	
- }
-
- 
- 
- 

+ 0 - 2712
src/service/v2g_serviceDispatcher.c

@@ -1,2712 +0,0 @@
-
-
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
-
-#include "v2g_service.h"
-#include "v2g_serviceDispatcher.h"
-#include "v2g_dataTypes.h"
-#include "v2g_dataTypes.c"
-#include "v2g_serviceMethods.h"
-#include "v2g_serviceDataSerialization.c"
-#include "EXITypes.h"
-#include "EXIDecoder.h"
-#include "EXIEncoder.h"
-#include "QNameDefines.h"
-#include "StringTable.h"
-#include <string.h>
-
-
-
-static int deserializeMessage(struct EXIService* service);
-
-uint16_t numberOfLocalStringsDecode[EXI_MAX_NUMBER_OF_QNAMES];
-uint16_t numberOfLocalStringsEncode[EXI_MAX_NUMBER_OF_QNAMES];
-
-
-static int _setInt64Value(exi_integer_t* iv, int64_t* int64) {
-	int errn = 0;
-	switch(iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		*int64 = iv->val.uint8;
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		*int64 = iv->val.uint16;
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		if (iv->val.uint32 <= 2147483647) {
-			*int64 = iv->val.uint32;
-		} else {
-			errn = -1;
-		}
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		*int64 = iv->val.uint64;
-		break;
-	/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		*int64 = iv->val.int8;
-		break;
-	case EXI_INTEGER_16:
-		*int64 = iv->val.int16;
-		break;
-	case EXI_INTEGER_32:
-		*int64 = iv->val.int32;
-		break;
-	case EXI_INTEGER_64:
-		*int64 = iv->val.int64;
-		break;
-	}
-	return errn;
-}
-
- static int _setUnsignedInt32Value(exi_integer_t* iv, uint32_t* int32) {
-	int errn = 0;
-	switch(iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		*int32 = iv->val.uint8;
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		*int32 = iv->val.uint16;
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		if (iv->val.uint32 <= 2147483647) {
-			*int32 = iv->val.uint32;
-		} else {
-			errn = -1;
-		}
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		errn = -1;
-		break;
-	/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		*int32 = iv->val.int8;
-		break;
-	case EXI_INTEGER_16:
-		*int32 = iv->val.int16;
-		break;
-	case EXI_INTEGER_32:
-		*int32 = iv->val.int32;
-		break;
-	case EXI_INTEGER_64:
-		errn = -1;
-		break;
-	}
-	return errn;
-}
-
-
-static int _setUnsignedInt16Value(exi_integer_t* iv, uint16_t* uint16) {
-	int errn = 0;
-	switch(iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		*uint16 = iv->val.uint8;
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		*uint16 = iv->val.uint16;
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-		if (iv->val.uint32 <= 2147483647) {
-			errn = -1;
-		} else {
-			errn = -1;
-		}
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		errn = -1;
-		break;
-	/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		*uint16 = iv->val.int8;
-		break;
-	case EXI_INTEGER_16:
-		*uint16 = iv->val.int16;
-		break;
-	case EXI_INTEGER_32:
-		errn = -1;
-		break;
-	case EXI_INTEGER_64:
-		errn = -1;
-		break;
-	}
-	return errn;
-}
-
-
-
-
-static int _setInt16Value(exi_integer_t* iv, int16_t* int16) {
-	int errn = 0;
-	switch(iv->type) {
-	/* Unsigned Integer */
-	case EXI_UNSIGNED_INTEGER_8:
-		*int16 = iv->val.uint8;
-		break;
-	case EXI_UNSIGNED_INTEGER_16:
-		*int16 = iv->val.int16;
-		break;
-	case EXI_UNSIGNED_INTEGER_32:
-			errn = -1;
-		break;
-	case EXI_UNSIGNED_INTEGER_64:
-		errn = -1;
-		break;
-	/* (Signed) Integer */
-	case EXI_INTEGER_8:
-		*int16 = iv->val.int8;
-		break;
-	case EXI_INTEGER_16:
-		*int16 = iv->val.int16;
-		break;
-	case EXI_INTEGER_32:
-		errn = -1;;
-		break;
-	case EXI_INTEGER_64:
-		errn = -1;
-		break;
-	}
-	return errn;
-}
-
-/**
- * Deserialize an element value of the EXI stream and assign it to the
- * service data structure 
- */
-static int deserializeElementAttributeCharacter(struct EXIService* service)
-{
-
-	switch(service->qnameID) {
-		case 326: /* FaultCode */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						service->exiMsg.V2G_Message.Header->Notification.FaultCode=service->val.enumeration;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 327: /* FaultMsg */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Notification.FaultMsg.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Notification.FaultMsg.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Notification.isused.FaultMsg=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 0: /* attr_Algorithm */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						if( service->idPath.id[4] == 61)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.CanonicalizationMethod.attr_Algorithm.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.CanonicalizationMethod.attr_Algorithm.arraylen.data = service->val.str.miss.len;
-
-						} else if(service->idPath.id[4] == 104)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.SignatureMethod.attr_Algorithm.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.SignatureMethod.attr_Algorithm.arraylen.data = service->val.str.miss.len;
-
-						} else if(service->idPath.id[4] == 95)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].DigestMethod.attr_Algorithm.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].DigestMethod.attr_Algorithm.arraylen.data = service->val.str.miss.len;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 2: /* attr_Id */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						if(service->idPath.id[3] == 113 && service->idPath.id[4] == 2)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Signature->SignedInfo.isused.attr_Id=1;
-
-						} else  if(service->idPath.id[3] == 75)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->KeyInfo.attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Signature->KeyInfo.isused.attr_Id=1;
-
-						} else if( service->idPath.id[1] == 441 && service->idPath.id[2] == 103)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Signature->isused.attr_Id=1;
-
-						} else if(service->idPath.id[2] == 156)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.ContractAuthenticationReq->attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.ContractAuthenticationReq->attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.ContractAuthenticationReq->isused.attr_Id=1;
-
-						} else if(service->idPath.id[2] == 192)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.MeteringReceiptReq->attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->isused.attr_Id=1;
-
-						} else if(service->idPath.id[2] == 141)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateUpdateReq->attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.CertificateUpdateReq->attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.CertificateUpdateReq->isused.attr_Id=1;
-
-						} else if(service->idPath.id[2] == 137)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateInstallationReq->attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.CertificateInstallationReq->attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.CertificateInstallationReq->isused.attr_Id=1;
-
-						} else if(service->idPath.id[4] == 95)
-						{
-							memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].attr_Id.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].attr_Id.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].isused.attr_Id=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 7: /* attr_URI */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].attr_URI.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].attr_URI.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].isused.attr_URI=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 6: /* attr_Type */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].attr_Type.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].attr_Type.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].isused.attr_Type=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 68: /* DigestValue */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].DigestValue.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Header->Signature->SignedInfo.Reference[0].DigestValue.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 111: /* SignatureValue */
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64)
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->SignatureValue.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Header->Signature->SignatureValue.arraylen.data = service->val.binary.len;
-
-					}
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-
-
-				break;
-
-		case 123: /* X509IssuerName */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509IssuerSerial.X509IssuerName.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509IssuerSerial.X509IssuerName.arraylen.data = service->val.str.miss.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 127: /* X509SerialNumber */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-
-					if(_setInt64Value(&(service->val.integer),&(service->val.integer.val.int64)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-
-
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509IssuerSerial.X509SerialNumber=service->val.integer.val.int64;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 126: /* X509SKI */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509SKI.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509SKI.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 128: /* X509SubjectName */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509SubjectName.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509SubjectName.arraylen.data = service->val.str.miss.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 120: /* X509Certificate */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509Certificate.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509Certificate.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 119: /* X509CRL */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509CRL.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Header->Signature->KeyInfo.X509Data.X509CRL.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 445: /* SessionID */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_HEX) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Header->SessionID.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Header->SessionID.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 171: /* EVCCID */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_HEX) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Body.SessionSetupReq->EVCCID.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.SessionSetupReq->EVCCID.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 235: /* ServiceScope */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq->ServiceScope.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq->ServiceScope.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq->isused.ServiceScope=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 219: /* ServiceCategory */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq->ServiceCategory=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq->isused.ServiceCategory=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 228: /* ServiceID */ 
-
-				if(service->val.type == EXI_DATATYPE_UNSIGNED_INTEGER) 
-					{
-						if(_setUnsignedInt16Value(&(service->val.integer),&(service->val.integer.val.uint16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ServiceDetailReq->ServiceID=service->val.integer.val.uint16;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 336: /* Multiplier */ 
-
-				if(service->val.type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) 
-					{
-						if( service->idPath.id[2] == 206 && service->idPath.id[3] == 188)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetVoltage.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 206 && service->idPath.id[3] == 187)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetCurrent.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 163 && service->idPath.id[3] == 187)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetCurrent.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[3] == 174)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumVoltageLimit.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[3] == 172)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumCurrentLimit.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[3] == 173)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumPowerLimit.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[3] == 213)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToFullSoC.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[3] == 212)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToBulkSoC.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 163 && service->idPath.id[3] == 188)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetVoltage.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 280)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EAmount.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 289)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxVoltage.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 288)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxCurrent.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 293)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMinCurrent.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 290)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumCurrentLimit.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 291)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumPowerLimit.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 292)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumVoltageLimit.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 285)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyCapacity.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[4] == 286)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyRequest.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 192)
-						{
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterReading.Multiplier=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 222)
-						{
-							service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].Parameter[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].arraylen.Parameter].physicalValue.Multiplier=service->val.integer.val.int8;						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 396: /* Unit */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						if( service->idPath.id[2] == 206 && service->idPath.id[3] == 188)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetVoltage.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetVoltage.isused.Unit=1;
-
-						} else if(service->idPath.id[2] == 206 && service->idPath.id[3] == 187)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetCurrent.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetCurrent.isused.Unit=1;
-
-						} else if(service->idPath.id[2] == 163 && service->idPath.id[3] == 187)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetCurrent.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetCurrent.isused.Unit=1;
-
-						} else if(service->idPath.id[3] == 174)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumVoltageLimit.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumVoltageLimit.isused.Unit=1;
-
-						} else if(service->idPath.id[3] == 172)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumCurrentLimit.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumCurrentLimit.isused.Unit=1;
-
-						} else if(service->idPath.id[3] == 173)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumPowerLimit.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumPowerLimit.isused.Unit=1;
-
-						} else if(service->idPath.id[3] == 213)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToFullSoC.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToFullSoC.isused.Unit=1;
-
-						} else if(service->idPath.id[3] == 212)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToBulkSoC.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToBulkSoC.isused.Unit=1;
-
-						} else if(service->idPath.id[2] == 163 && service->idPath.id[3] == 188)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetVoltage.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetVoltage.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 280)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EAmount.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EAmount.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 289)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxVoltage.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxVoltage.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 288)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxCurrent.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxCurrent.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 293)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMinCurrent.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMinCurrent.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 290)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumCurrentLimit.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumCurrentLimit.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 291)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumPowerLimit.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumPowerLimit.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 292)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumVoltageLimit.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumVoltageLimit.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 285)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyCapacity.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyCapacity.isused.Unit=1;
-
-						} else if(service->idPath.id[4] == 286)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyRequest.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyRequest.isused.Unit=1;
-
-						} else if(service->idPath.id[2] == 192)
-						{
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterReading.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterReading.isused.Unit=1;
-
-						} else if(service->idPath.id[2] == 222)
-						{
-							service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].Parameter[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].arraylen.Parameter].physicalValue.Unit=service->val.enumeration;
-							service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].Parameter[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].arraylen.Parameter].physicalValue.isused.Unit=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 397: /* Value */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-						if( service->idPath.id[2] == 206 && service->idPath.id[3] == 188)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetVoltage.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[2] == 206 && service->idPath.id[3] == 187)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.PreChargeReq->EVTargetCurrent.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[2] == 163 && service->idPath.id[3] == 187)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetCurrent.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[3] == 174)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumVoltageLimit.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[3] == 172)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumCurrentLimit.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[3] == 173)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVMaximumPowerLimit.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[3] == 213)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToFullSoC.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[3] == 212)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->RemainingTimeToBulkSoC.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[2] == 163 && service->idPath.id[3] == 188)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->EVTargetVoltage.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 280)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EAmount.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 289)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxVoltage.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 288)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMaxCurrent.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 293)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->EVMinCurrent.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 290)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumCurrentLimit.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 291)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumPowerLimit.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 292)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVMaximumVoltageLimit.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 285)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyCapacity.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[4] == 286)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->EVEnergyRequest.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[2] == 192)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterReading.Value=service->val.integer.val.int16;
-						} else if(service->idPath.id[2] == 222)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].Parameter[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.ParameterSet[service->exiMsg.V2G_Message.Body.ServiceDetailRes->ServiceParameterList.arraylen.ParameterSet].arraylen.Parameter].physicalValue.Value=service->val.integer.val.int16;						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 383: /* ServiceID */ 
-
-				if(service->val.type == EXI_DATATYPE_UNSIGNED_INTEGER) 
-					{
-						if(_setUnsignedInt16Value(&(service->val.integer),&(service->val.integer.val.uint16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.SelectedService[service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.arraylen.SelectedService].ServiceID=service->val.integer.val.uint16;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 349: /* ParameterSetID */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-						if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.SelectedService[service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.arraylen.SelectedService].ParameterSetID=service->val.integer.val.int16;
-							service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.SelectedService[service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.arraylen.SelectedService].isused.ParameterSetID=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 217: /* SelectedPaymentOption */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedPaymentOption=service->val.enumeration;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 257: /* Certificate */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						if(service->idPath.id[2] == 141 && service->idPath.id[4] == 392)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.SubCertificates.Certificate[service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.SubCertificates.arraylen.Certificate].data, service->val.binary.data,service->val.binary.len);
-							service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.SubCertificates.Certificate[service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.SubCertificates.arraylen.Certificate].arraylen.data = service->val.binary.len;
-
-							service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.SubCertificates.arraylen.Certificate++;
-
-						} else if(service->idPath.id[2] == 141)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.Certificate.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractSignatureCertChain.Certificate.arraylen.data = service->val.binary.len;
-
-						} else  if(service->idPath.id[4] == 257)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.Certificate.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.Certificate.arraylen.data = service->val.binary.len;
-
-						} else if(service->idPath.id[2] == 197 && service->idPath.id[4] == 392)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.SubCertificates.Certificate[service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.SubCertificates.arraylen.Certificate].data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.SubCertificates.Certificate[service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.SubCertificates.arraylen.Certificate].arraylen.data = service->val.binary.len;
-
-							service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractSignatureCertChain.SubCertificates.arraylen.Certificate++;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 160: /* ContractID */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						if( service->idPath.id[2] == 197)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractID.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.PaymentDetailsReq->ContractID.arraylen.data = service->val.str.miss.len;
-
-						} else if(service->idPath.id[2] == 141)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractID.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ContractID.arraylen.data = service->val.str.miss.len;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 189: /* GenChallenge */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Body.ContractAuthenticationReq->GenChallenge.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.ContractAuthenticationReq->GenChallenge.arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.ContractAuthenticationReq->isused.GenChallenge=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 279: /* DepartureTime */ 
-
-				if(service->val.type == EXI_DATATYPE_UNSIGNED_INTEGER) 
-					{
-						if(_setUnsignedInt32Value(&(service->val.integer),&(service->val.integer.val.uint32)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->AC_EVChargeParameter->DepartureTime=service->val.integer.val.uint32;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 298: /* EVReady */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						if( service->idPath.id[2] == 133)
-						{
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.EVReady=service->val.boolean;
-						} else if(service->idPath.id[2] == 206)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.EVReady=service->val.boolean;
-						} else if(service->idPath.id[2] == 163)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.EVReady=service->val.boolean;
-						} else if(service->idPath.id[2] == 245)
-						{
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.EVReady=service->val.boolean;
-						} else if(service->idPath.id[2] == 202)
-						{
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.EVReady=service->val.boolean;
-						} else if(service->idPath.id[2] == 145)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.EVReady=service->val.boolean;						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 282: /* EVCabinConditioning */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						if( service->idPath.id[2] == 133)
-						{
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.EVCabinConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.isused.EVCabinConditioning=1;
-
-						} else if(service->idPath.id[2] == 206)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.EVCabinConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.isused.EVCabinConditioning=1;
-
-						} else if(service->idPath.id[2] == 163)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.EVCabinConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.isused.EVCabinConditioning=1;
-
-						} else if(service->idPath.id[2] == 245)
-						{
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.EVCabinConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.isused.EVCabinConditioning=1;
-
-						} else if(service->idPath.id[2] == 202)
-						{
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.EVCabinConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.isused.EVCabinConditioning=1;
-
-						} else if(service->idPath.id[2] == 145)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.EVCabinConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.isused.EVCabinConditioning=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 296: /* EVRESSConditioning */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						if( service->idPath.id[2] == 133)
-						{
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.EVRESSConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.isused.EVRESSConditioning=1;
-
-						} else if(service->idPath.id[2] == 206)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.EVRESSConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.isused.EVRESSConditioning=1;
-
-						} else if(service->idPath.id[2] == 163)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.EVRESSConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.isused.EVRESSConditioning=1;
-
-						} else if(service->idPath.id[2] == 245)
-						{
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.EVRESSConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.isused.EVRESSConditioning=1;
-
-						} else if(service->idPath.id[2] == 202)
-						{
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.EVRESSConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.isused.EVRESSConditioning=1;
-
-						} else if(service->idPath.id[2] == 145)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.EVRESSConditioning=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.isused.EVRESSConditioning=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 287: /* EVErrorCode */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						if( service->idPath.id[2] == 133)
-						{
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.EVErrorCode=service->val.enumeration;
-						} else if(service->idPath.id[2] == 206)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.EVErrorCode=service->val.enumeration;
-						} else if(service->idPath.id[2] == 163)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.EVErrorCode=service->val.enumeration;
-						} else if(service->idPath.id[2] == 245)
-						{
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.EVErrorCode=service->val.enumeration;
-						} else if(service->idPath.id[2] == 202)
-						{
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.EVErrorCode=service->val.enumeration;
-						} else if(service->idPath.id[2] == 145)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.EVErrorCode=service->val.enumeration;						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 297: /* EVRESSSOC */ 
-
-				if(service->val.type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) 
-					{
-						if( service->idPath.id[2] == 133)
-						{
-							service->exiMsg.V2G_Message.Body.CableCheckReq->DC_EVStatus.EVRESSSOC=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 206)
-						{
-							service->exiMsg.V2G_Message.Body.PreChargeReq->DC_EVStatus.EVRESSSOC=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 163)
-						{
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->DC_EVStatus.EVRESSSOC=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 245)
-						{
-							service->exiMsg.V2G_Message.Body.WeldingDetectionReq->DC_EVStatus.EVRESSSOC=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 202)
-						{
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->DC_EVStatus.EVRESSSOC=service->val.integer.val.int8;
-						} else if(service->idPath.id[2] == 145)
-						{
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->DC_EVStatus.EVRESSSOC=service->val.integer.val.int8;						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 329: /* FullSOC */ 
-
-				if(service->val.type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) 
-					{
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->FullSOC=service->val.integer.val.int8;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->isused.FullSOC=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 256: /* BulkSOC */ 
-
-				if(service->val.type == EXI_DATATYPE_NBIT_UNSIGNED_INTEGER) 
-					{
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->BulkSOC=service->val.integer.val.int8;
-							service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->isused.BulkSOC=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 175: /* EVRequestedEnergyTransferType */ 
-
-				if(service->val.type == EXI_DATATYPE_ENUMERATION) 
-					{
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->EVRequestedEnergyTransferType=service->val.enumeration;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 261: /* ChargingProfileEntryStart */ 
-
-				if(service->val.type == EXI_DATATYPE_UNSIGNED_INTEGER) 
-					{
-						if(_setUnsignedInt32Value(&(service->val.integer),&(service->val.integer.val.uint32)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ChargingProfile.ProfileEntry[service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ChargingProfile.arraylen.ProfileEntry].ChargingProfileEntryStart=service->val.integer.val.uint32;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 260: /* ChargingProfileEntryMaxPower */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-						if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ChargingProfile.ProfileEntry[service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ChargingProfile.arraylen.ProfileEntry].ChargingProfileEntryMaxPower=service->val.integer.val.int16;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 366: /* SAScheduleTupleID */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-						if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ChargingProfile.SAScheduleTupleID=service->val.integer.val.int16;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 255: /* BulkChargingComplete */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->BulkChargingComplete=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->isused.BulkChargingComplete=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 259: /* ChargingComplete */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->DC_EVPowerDeliveryParameter->ChargingComplete=service->val.boolean;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 210: /* ReadyToChargeState */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ReadyToChargeState=service->val.boolean;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 332: /* MeterID */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						if( service->idPath.id[2] == 192)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterID.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterID.arraylen.data = service->val.str.miss.len;
-
-						} else if(service->idPath.id[2] == 154)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.MeterID.data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.MeterID.arraylen.data = service->val.str.miss.len;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 391: /* SigMeterReading */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						if( service->idPath.id[2] == 192)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.SigMeterReading.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.SigMeterReading.arraylen.data = service->val.binary.len;
-
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.isused.SigMeterReading=1;
-
-						} else if(service->idPath.id[2] == 154)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.SigMeterReading.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.SigMeterReading.arraylen.data = service->val.binary.len;
-
-							service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.isused.SigMeterReading=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 335: /* MeterStatus */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-						if( service->idPath.id[2] == 192)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.MeterStatus=service->val.integer.val.int16;
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.isused.MeterStatus=1;
-
-						} else if(service->idPath.id[2] == 154)
-						{
-							if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.MeterStatus=service->val.integer.val.int16;
-							service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.isused.MeterStatus=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 394: /* TMeter */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-
-						if(_setInt64Value(&(service->val.integer),&(service->val.integer.val.int64)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-
-						if( service->idPath.id[2] == 192)
-						{
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.TMeter=service->val.integer.val.int64;
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.isused.TMeter=1;
-
-						} else if(service->idPath.id[2] == 154)
-						{
-							service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.TMeter=service->val.integer.val.int64;
-							service->exiMsg.V2G_Message.Body.ChargingStatusRes->MeterInfo.isused.TMeter=1;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 236: /* SessionID */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_HEX) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Body.MeteringReceiptReq->SessionID.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->SessionID.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 216: /* SAScheduleTupleID */ 
-
-				if(service->val.type == EXI_DATATYPE_INTEGER) 
-					{
-						if(_setInt16Value(&(service->val.integer),&(service->val.integer.val.int16)))
-						{
-							service->errorCode=EXI_VALUE_RANGE_FAILED;
-							return -1;
-						}
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->SAScheduleTupleID=service->val.integer.val.int16;
-							service->exiMsg.V2G_Message.Body.MeteringReceiptReq->isused.SAScheduleTupleID=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 361: /* RootCertificateID */ 
-
-				if(service->val.type == EXI_DATATYPE_STRING) 
-					{
-						if( service->idPath.id[2] == 137)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateInstallationReq->ListOfRootCertificateIDs.RootCertificateID[service->exiMsg.V2G_Message.Body.CertificateInstallationReq->ListOfRootCertificateIDs.arraylen.RootCertificateID].data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.CertificateInstallationReq->ListOfRootCertificateIDs.RootCertificateID[service->exiMsg.V2G_Message.Body.CertificateInstallationReq->ListOfRootCertificateIDs.arraylen.RootCertificateID].arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.CertificateInstallationReq->ListOfRootCertificateIDs.arraylen.RootCertificateID++;
-
-						} else if(service->idPath.id[2] == 141)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ListOfRootCertificateIDs.RootCertificateID[service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ListOfRootCertificateIDs.arraylen.RootCertificateID].data, service->val.str.miss.codepoints,service->val.str.miss.len*sizeof(uint32_t));
-						service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ListOfRootCertificateIDs.RootCertificateID[service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ListOfRootCertificateIDs.arraylen.RootCertificateID].arraylen.data = service->val.str.miss.len;
-
-							service->exiMsg.V2G_Message.Body.CertificateUpdateReq->ListOfRootCertificateIDs.arraylen.RootCertificateID++;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 169: /* DHParams */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						if( service->idPath.id[2] == 141)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateUpdateReq->DHParams.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.CertificateUpdateReq->DHParams.arraylen.data = service->val.binary.len;
-
-						} else if(service->idPath.id[2] == 137)
-						{
-							memcpy(service->exiMsg.V2G_Message.Body.CertificateInstallationReq->DHParams.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.CertificateInstallationReq->DHParams.arraylen.data = service->val.binary.len;
-						}
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 196: /* OEMProvisioningCert */ 
-
-				if(service->val.type == EXI_DATATYPE_BINARY_BASE64) 
-					{
-						memcpy(service->exiMsg.V2G_Message.Body.CertificateInstallationReq->OEMProvisioningCert.data, service->val.binary.data,service->val.binary.len);
-						service->exiMsg.V2G_Message.Body.CertificateInstallationReq->OEMProvisioningCert.arraylen.data = service->val.binary.len;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 132: /* BulkChargingComplete */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->BulkChargingComplete=service->val.boolean;
-							service->exiMsg.V2G_Message.Body.CurrentDemandReq->isused.BulkChargingComplete=1;
-
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-		case 150: /* ChargingComplete */ 
-
-				if(service->val.type == EXI_DATATYPE_BOOLEAN) 
-					{
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->ChargingComplete=service->val.boolean;
-					} 
-					else
-					{
-						service->errorCode=EXI_DATATYPE_FAILED;
-						return -1; /* wrong data type */
-					}
-		
-
-				break;
-
-	
-	} 
-	return 0;
-}
-
-/**
- * Depending on the current EXI event a message element is deserialized or a
- * defined service method is called in here
- */
-static int deserializeElementOrServiceCall(struct EXIService* service)
-{
-	switch(service->qnameID) {
-		case 75: /* KeyInfo */ 
-						service->exiMsg.V2G_Message.Header->Signature->isused.KeyInfo=1;
-	
-			break;
-		case 444: /* Notification */ 
-						service->exiMsg.V2G_Message.Header->isused.Notification=1;
-	
-			break;
-		case 103: /* Signature */ 
-						service->exiMsg.V2G_Message.Header->isused.Signature=1;
-	
-			break;
-		case 376: /* SelectedService */ 
-						service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq->SelectedServiceList.arraylen.SelectedService++;
-	
-			break;
-		case 392: /* SubCertificates */ 
-						
-			break;
-		case 291: /* EVMaximumPowerLimit */ 
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->isused.EVMaximumPowerLimit=1;
-	
-			break;
-		case 285: /* EVEnergyCapacity */ 
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->isused.EVEnergyCapacity=1;
-	
-			break;
-		case 286: /* EVEnergyRequest */ 
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->DC_EVChargeParameter->isused.EVEnergyRequest=1;
-	
-			break;
-		case 249: /* AC_EVChargeParameter */ 
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->isused.AC_EVChargeParameter=1;
-	
-			break;
-		case 267: /* DC_EVChargeParameter */ 
-						service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq->isused.DC_EVChargeParameter=1;
-	
-			break;
-		case 356: /* ProfileEntry */ 
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->ChargingProfile.arraylen.ProfileEntry++;
-	
-			break;
-		case 151: /* ChargingProfile */ 
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->isused.ChargingProfile=1;
-	
-			break;
-		case 270: /* DC_EVPowerDeliveryParameter */ 
-						service->exiMsg.V2G_Message.Body.PowerDeliveryReq->isused.DC_EVPowerDeliveryParameter=1;
-	
-			break;
-		case 334: /* MeterReading */ 
-						service->exiMsg.V2G_Message.Body.MeteringReceiptReq->MeterInfo.isused.MeterReading=1;
-			break;
-		case 174: /* EVMaximumVoltageLimit */ 
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->isused.EVMaximumVoltageLimit=1;
-	
-			break;
-		case 172: /* EVMaximumCurrentLimit */ 
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->isused.EVMaximumCurrentLimit=1;
-	
-			break;
-		case 173: /* EVMaximumPowerLimit */ 
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->isused.EVMaximumPowerLimit=1;
-	
-			break;
-		case 213: /* RemainingTimeToFullSoC */ 
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->isused.RemainingTimeToFullSoC=1;
-	
-			break;
-		case 212: /* RemainingTimeToBulkSoC */ 
-						service->exiMsg.V2G_Message.Body.CurrentDemandReq->isused.RemainingTimeToBulkSoC=1;
-	
-			break;
-		case 237: /* SessionSetupReq */ 
-					
-			
-					/* service call */
-					if(sessionSetup((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.SessionSetupReq), (service->exiMsg.V2G_Message.Body.SessionSetupRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.SessionSetupRes=1;
-					service->exiMsg.V2G_Message.Body.isused.SessionSetupReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 224: /* ServiceDiscoveryReq */ 
-					
-			
-					/* service call */
-					if(serviceDiscovery((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq), (service->exiMsg.V2G_Message.Body.ServiceDiscoveryRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.ServiceDiscoveryRes=1;
-					service->exiMsg.V2G_Message.Body.isused.ServiceDiscoveryReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 220: /* ServiceDetailReq */ 
-					
-			
-					/* service call */
-					if(serviceDetail((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.ServiceDetailReq), (service->exiMsg.V2G_Message.Body.ServiceDetailRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.ServiceDetailRes=1;
-					service->exiMsg.V2G_Message.Body.isused.ServiceDetailReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 231: /* ServicePaymentSelectionReq */ 
-					
-			
-					/* service call */
-					if(servicePaymentSelection((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq), (service->exiMsg.V2G_Message.Body.ServicePaymentSelectionRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.ServicePaymentSelectionRes=1;
-					service->exiMsg.V2G_Message.Body.isused.ServicePaymentSelectionReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 197: /* PaymentDetailsReq */ 
-					
-			
-					/* service call */
-					if(paymentDetails((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.PaymentDetailsReq), (service->exiMsg.V2G_Message.Body.PaymentDetailsRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.PaymentDetailsRes=1;
-					service->exiMsg.V2G_Message.Body.isused.PaymentDetailsReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 156: /* ContractAuthenticationReq */ 
-					
-			
-					/* service call */
-					if(contractAuthentication((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.ContractAuthenticationReq), (service->exiMsg.V2G_Message.Body.ContractAuthenticationRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.ContractAuthenticationRes=1;
-					service->exiMsg.V2G_Message.Body.isused.ContractAuthenticationReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 145: /* ChargeParameterDiscoveryReq */ 
-					
-			
-					/* service call */
-					if(chargeParameterDiscovery((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq), (service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.ChargeParameterDiscoveryRes=1;
-					service->exiMsg.V2G_Message.Body.isused.ChargeParameterDiscoveryReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 202: /* PowerDeliveryReq */ 
-					
-			
-					/* service call */
-					if(powerDelivery((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.PowerDeliveryReq), (service->exiMsg.V2G_Message.Body.PowerDeliveryRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.PowerDeliveryRes=1;
-					service->exiMsg.V2G_Message.Body.isused.PowerDeliveryReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 152: /* ChargingStatusReq */ 
-					
-			
-					/* service call */
-					if(chargingStatus((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.ChargingStatusReq), (service->exiMsg.V2G_Message.Body.ChargingStatusRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.ChargingStatusRes=1;
-					service->exiMsg.V2G_Message.Body.isused.ChargingStatusReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 192: /* MeteringReceiptReq */ 
-					
-			
-					/* service call */
-					if(meteringReceipt((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.MeteringReceiptReq), (service->exiMsg.V2G_Message.Body.MeteringReceiptRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.MeteringReceiptRes=1;
-					service->exiMsg.V2G_Message.Body.isused.MeteringReceiptReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 241: /* SessionStopReq */ 
-					
-			
-					/* service call */
-					if(sessionStop((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.SessionStopReq), (service->exiMsg.V2G_Message.Body.SessionStopRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.SessionStopRes=1;
-					service->exiMsg.V2G_Message.Body.isused.SessionStopReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 141: /* CertificateUpdateReq */ 
-					
-			
-					/* service call */
-					if(certificateUpdate((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.CertificateUpdateReq), (service->exiMsg.V2G_Message.Body.CertificateUpdateRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.CertificateUpdateRes=1;
-					service->exiMsg.V2G_Message.Body.isused.CertificateUpdateReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 137: /* CertificateInstallationReq */ 
-					
-			
-					/* service call */
-					if(certificateInstallation((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.CertificateInstallationReq), (service->exiMsg.V2G_Message.Body.CertificateInstallationRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.CertificateInstallationRes=1;
-					service->exiMsg.V2G_Message.Body.isused.CertificateInstallationReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 133: /* CableCheckReq */ 
-					
-			
-					/* service call */
-					if(cableCheck((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.CableCheckReq), (service->exiMsg.V2G_Message.Body.CableCheckRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.CableCheckRes=1;
-					service->exiMsg.V2G_Message.Body.isused.CableCheckReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 206: /* PreChargeReq */ 
-					
-			
-					/* service call */
-					if(preCharge((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.PreChargeReq), (service->exiMsg.V2G_Message.Body.PreChargeRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.PreChargeRes=1;
-					service->exiMsg.V2G_Message.Body.isused.PreChargeReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 163: /* CurrentDemandReq */ 
-					
-			
-					/* service call */
-					if(currentDemand((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.CurrentDemandReq), (service->exiMsg.V2G_Message.Body.CurrentDemandRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.CurrentDemandRes=1;
-					service->exiMsg.V2G_Message.Body.isused.CurrentDemandReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-			case 245: /* WeldingDetectionReq */ 
-					
-			
-					/* service call */
-					if(weldingDetection((service->exiMsg.V2G_Message.Header),(service->exiMsg.V2G_Message.Body.WeldingDetectionReq), (service->exiMsg.V2G_Message.Body.WeldingDetectionRes)))
-					{
-						service->errorCode=EXI_SERVICE_CALL_FAILED;
-						return -1;
-					}
-							
-					/* signalize the response message */
-					service->exiMsg.V2G_Message.Body.isused.WeldingDetectionRes=1;
-					service->exiMsg.V2G_Message.Body.isused.WeldingDetectionReq=0;
-					
-					/* serialize the response data */
-					if(serialize_message(service))
-					{
-						/* serializiation error*/
-						service->errorCode= EXI_SERIALIZATION_FAILED;
-						return -1;
-					} 
-			break;
-			
-		
-	}
-	return 0;
-}
-
-
-
-static int deserializeSessionSetupReqMsg(struct EXIService* service)
-{
-	struct SessionSetupReqType reqMsg;
-	struct SessionSetupResType resMsg;
-	service->exiMsg.V2G_Message.Body.SessionSetupReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.SessionSetupRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeServiceDiscoveryReqMsg(struct EXIService* service)
-{
-	struct ServiceDiscoveryReqType reqMsg;
-	struct ServiceDiscoveryResType resMsg;
-	init_ServiceDiscoveryReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.ServiceDiscoveryReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.ServiceDiscoveryRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeServiceDetailReqMsg(struct EXIService* service)
-{
-	struct ServiceDetailReqType reqMsg;
-	struct ServiceDetailResType resMsg;
-	service->exiMsg.V2G_Message.Body.ServiceDetailReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.ServiceDetailRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeServicePaymentSelectionReqMsg(struct EXIService* service)
-{
-	struct ServicePaymentSelectionReqType reqMsg;
-	struct ServicePaymentSelectionResType resMsg;
-	init_ServicePaymentSelectionReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.ServicePaymentSelectionReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.ServicePaymentSelectionRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializePaymentDetailsReqMsg(struct EXIService* service)
-{
-	struct PaymentDetailsReqType reqMsg;
-	struct PaymentDetailsResType resMsg;
-	init_PaymentDetailsReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.PaymentDetailsReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.PaymentDetailsRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeContractAuthenticationReqMsg(struct EXIService* service)
-{
-	struct ContractAuthenticationReqType reqMsg;
-	struct ContractAuthenticationResType resMsg;
-	service->exiMsg.V2G_Message.Body.ContractAuthenticationReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.ContractAuthenticationRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeChargeParameterDiscoveryReqMsg(struct EXIService* service)
-{
-	struct ChargeParameterDiscoveryReqType reqMsg;
-	struct ChargeParameterDiscoveryResType resMsg;
-	struct DC_EVChargeParameterType dc_pev;
-	struct AC_EVChargeParameterType ac_pev;
-	struct DC_EVSEChargeParameterType dc_evse;
-	struct AC_EVSEChargeParameterType ac_evse;
-	struct SAScheduleListType tuple;
-	struct SalesTariffType sales1;
-	struct SalesTariffType sales2;
-
-	init_AC_EVChargeParameterType(&ac_pev);
-
-	init_ChargeParameterDiscoveryReqType(&reqMsg);
-	init_DC_EVSEChargeParameterType(&dc_evse);
-	init_AC_EVSEChargeParameterType(&ac_evse);
-	init_DC_EVChargeParameterType(&dc_pev);
-	init_SAScheduleListType(&tuple);
-	init_SalesTariffType(&sales1);
-	init_SalesTariffType(&sales2);
-
-	reqMsg.AC_EVChargeParameter = &ac_pev;
-	reqMsg.DC_EVChargeParameter = &dc_pev;
-	resMsg.AC_EVSEChargeParameter = &ac_evse;
-	resMsg.DC_EVSEChargeParameter= &dc_evse;
-
-	service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.ChargeParameterDiscoveryRes = &resMsg;
-
-	tuple.SAScheduleTuple[0].SalesTariff = &sales1;
-	tuple.SAScheduleTuple[1].SalesTariff =  &sales2;
-	resMsg.SAScheduleList = tuple;
-
-
-	
-	return deserializeMessage(service);
-}
-
-static int deserializePowerDeliveryReqMsg(struct EXIService* service)
-{
-	struct PowerDeliveryReqType reqMsg;
-	struct PowerDeliveryResType resMsg;
-	struct DC_EVPowerDeliveryParameterType EVPowerDelivery;
-
-	struct DC_EVSEStatusType dc_evse;
-	struct AC_EVSEStatusType ac_evse;
-
-	init_DC_EVPowerDeliveryParameterType(&EVPowerDelivery);
-	init_PowerDeliveryReqType(&reqMsg);
-
-
-	resMsg.AC_EVSEStatus = &ac_evse;
-	resMsg.DC_EVSEStatus = &dc_evse;
-
-	reqMsg.DC_EVPowerDeliveryParameter = &EVPowerDelivery;
-
-	service->exiMsg.V2G_Message.Body.PowerDeliveryReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.PowerDeliveryRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeChargingStatusReqMsg(struct EXIService* service)
-{
-	struct ChargingStatusReqType reqMsg;
-	struct ChargingStatusResType resMsg;
-	service->exiMsg.V2G_Message.Body.ChargingStatusReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.ChargingStatusRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeMeteringReceiptReqMsg(struct EXIService* service)
-{
-	struct MeteringReceiptReqType reqMsg;
-	struct MeteringReceiptResType resMsg;
-	init_MeteringReceiptReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.MeteringReceiptReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.MeteringReceiptRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeCertificateUpdateReqMsg(struct EXIService* service)
-{
-	struct CertificateUpdateReqType reqMsg;
-	struct CertificateUpdateResType resMsg;
-	init_CertificateUpdateReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.CertificateUpdateReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.CertificateUpdateRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeCertificateInstallationReqMsg(struct EXIService* service)
-{
-	struct CertificateInstallationReqType reqMsg;
-	struct CertificateInstallationResType resMsg;
-	init_CertificateInstallationReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.CertificateInstallationReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.CertificateInstallationRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeCableCheckReqMsg(struct EXIService* service)
-{
-	struct CableCheckReqType reqMsg;
-	struct CableCheckResType resMsg;
-	service->exiMsg.V2G_Message.Body.CableCheckReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.CableCheckRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializePreChargeReqMsg(struct EXIService* service)
-{
-	struct PreChargeReqType reqMsg;
-	struct PreChargeResType resMsg;
-	init_PreChargeReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.PreChargeReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.PreChargeRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeCurrentDemandReqMsg(struct EXIService* service)
-{
-	struct CurrentDemandReqType reqMsg;
-	struct CurrentDemandResType resMsg;
-	init_CurrentDemandReqType(&reqMsg);
-	
-	service->exiMsg.V2G_Message.Body.CurrentDemandReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.CurrentDemandRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeWeldingDetectionReqMsg(struct EXIService* service)
-{
-	struct WeldingDetectionReqType reqMsg;
-	struct WeldingDetectionResType resMsg;
-	service->exiMsg.V2G_Message.Body.WeldingDetectionReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.WeldingDetectionRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-static int deserializeSessionStopReqMsg(struct EXIService* service)
-{
-	struct SessionStopType reqMsg;
-	struct SessionStopResType resMsg;
-	service->exiMsg.V2G_Message.Body.SessionStopReq = &reqMsg;
-	service->exiMsg.V2G_Message.Body.SessionStopRes = &resMsg;
-	
-	return deserializeMessage(service);
-}
-
-/** 
- * Deserialize the EXI stream
- * @return 0 = 0K; -1 = ERROR
- */
-static int deserializeMessage(struct EXIService* service)
-{
-	int noEndOfDocument = 1; /* true */
-	int returnCode=0;
-	static int derivationCounter = 0;
-
-	do {
-			exiDecodeNextEvent(&(service->inStream), &(service->stateDecode), &(service->event));
-			if (returnCode) 
-			{
-				
-				if(service->errorCode==0) 
-				{
-					service->errorCode= EXI_NON_VALID_MESSAGE;
-				}
-			
-				return returnCode;
-			}
-
-			switch (service->event) {
-			case EXI_EVENT_START_DOCUMENT:
-
-				returnCode = exiDecodeStartDocument(&(service->inStream), &(service->stateDecode));
-
-				break;
-			case EXI_EVENT_END_DOCUMENT:
-
-				returnCode = exiDecodeEndDocument(&(service->inStream), &(service->stateDecode));
-				noEndOfDocument = 0; /* false */
-				break;
-				break;
-			case EXI_EVENT_START_ELEMENT_GENERIC:
-			case EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED:
-				derivationCounter++;
-			case EXI_EVENT_START_ELEMENT:
-				returnCode = exiDecodeStartElement(&(service->inStream), &(service->stateDecode), &(service->qnameID));
-				service->idPath.id[service->idPath.pos++]=service->qnameID;
-				 
-				 /* setup the request context*/
-				 if(service->qnameID==237 )
-				  {
-				 	return deserializeSessionSetupReqMsg(service);
-				   } else if(service->qnameID==224)
-				  {
-				 	return deserializeServiceDiscoveryReqMsg(service);
-				   } else if(service->qnameID==220)
-				  {
-				 	return deserializeServiceDetailReqMsg(service);
-				   } else if(service->qnameID==231)
-				  {
-				 	return deserializeServicePaymentSelectionReqMsg(service);
-				   } else if(service->qnameID==197)
-				  {
-				 	return deserializePaymentDetailsReqMsg(service);
-				   } else if(service->qnameID==156)
-				  {
-				 	return deserializeContractAuthenticationReqMsg(service);
-				   } else if(service->qnameID==145)
-				  {
-				 	return deserializeChargeParameterDiscoveryReqMsg(service);
-				   } else if(service->qnameID==202)
-				  {
-				 	return deserializePowerDeliveryReqMsg(service);
-				   } else if(service->qnameID==152)
-				  {
-				 	return deserializeChargingStatusReqMsg(service);
-				   } else if(service->qnameID==192)
-				  {
-				 	return deserializeMeteringReceiptReqMsg(service);
-				   } else if(service->qnameID==241)
-				  {
-				 	return deserializeSessionStopReqMsg(service);
-				   } else if(service->qnameID==141)
-				  {
-				 	return deserializeCertificateUpdateReqMsg(service);
-				   } else if(service->qnameID==137)
-				  {
-				 	return deserializeCertificateInstallationReqMsg(service);
-				   } else if(service->qnameID==133)
-				  {
-				 	return deserializeCableCheckReqMsg(service);
-				   } else if(service->qnameID==206)
-				  {
-				 	return deserializePreChargeReqMsg(service);
-				   } else if(service->qnameID==163)
-				  {
-				 	return deserializeCurrentDemandReqMsg(service);
-				   } else if(service->qnameID==245)
-				  {
-				 	return deserializeWeldingDetectionReqMsg(service);
-				   } 				 
-				 
-				 
-				break;
-			case EXI_EVENT_END_ELEMENT_UNDECLARED:
-			case EXI_EVENT_END_ELEMENT:
-
-				returnCode = exiDecodeEndElement(&(service->inStream), &(service->stateDecode), &(service->qnameID));
-
-				if(derivationCounter==0)
-					returnCode = deserializeElementOrServiceCall(service);
-
-				service->idPath.pos--;
-
-				if(derivationCounter>0)
-					derivationCounter--;
-
-				break;
-			case EXI_EVENT_CHARACTERS_GENERIC:
-			case EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED:
-			case EXI_EVENT_CHARACTERS:
-				/* decode */
-				returnCode = exiDecodeCharacters(&(service->inStream), &(service->stateDecode), &(service->val));
-				 
-				/* assign data to the EXI message structure; only if there was no derivation */
-				if(derivationCounter==0)
-					returnCode = deserializeElementAttributeCharacter(service);
-
-				break;
-			case EXI_EVENT_ATTRIBUTE_GENERIC:
-			case EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED:
-			case EXI_EVENT_ATTRIBUTE_INVALID_VALUE:
-			case EXI_EVENT_ATTRIBUTE:
-				/* decode */
-				returnCode = exiDecodeAttribute(&(service->inStream), &(service->stateDecode), &(service->qnameID), &(service->val));
-				if(derivationCounter==0)
-					returnCode = deserializeElementAttributeCharacter(service);
-
-				break;
-			case EXI_EVENT_ATTRIBUTE_ANY_INVALID_VALUE:
-				break;
-			default:
-				/* ERROR */
-				return -1;
-			}
-
-		} while (noEndOfDocument);
-
-	return 0;
-}
-
-
-/** 
- * \brief Takes the EXI stream, invokes the called service method, and provides the response EXI stream
- * \param	service   struct EXIService* Represent the service data structure
- * \param	inStream   uint8_t* EXI in stream
- * \param	sizeInStream   uint16_t Length of the inStream
- * \param	outStream   uint8_t* Represent the out stream
- * \param	sizeOutStream   uint16_t Size of the out stream
- * \param	outStreamLength   uint16_t* Length of the stream
- * \return  0 = 0K; -1 = ERROR
- */
-int messageDispatcher(struct EXIService* service, uint8_t* inStream, uint32_t sizeInStream, uint8_t* outStream, uint32_t sizeOutStream, uint32_t* outStreamLength)
-{
-	struct MessageHeaderType header;	
-	struct SignatureType signature;
-
-	uint32_t inPos, outPos;
-	
-	exi_name_table_runtime_t runtimeTableDecode;
-	exi_name_table_runtime_t runtimeTableEncode;
-	
-	exi_string_table_t stringTableDecode = { 0, EXI_MAX_NUMBER_OF_QNAMES, numberOfLocalStringsDecode};
-	exi_string_table_t stringTableEncode = { 0, EXI_MAX_NUMBER_OF_QNAMES, numberOfLocalStringsEncode};
-
-
-	/* assign inStream data to service EXI structure */
-	inPos = service->transportHeaderOffset;
-	service->inStream.data = inStream;
-	service->inStream.size = sizeInStream+inPos;
-	service->inStream.pos = &inPos;
-	service->inStream.buffer=0;
-	service->inStream.capacity=0;
-
-	
-	/* assign outStream data to service EXI structure */
-	outPos=service->transportHeaderOffset;
-	service->outStream.data = outStream;
-	service->outStream.size = sizeOutStream;
-	service->outStream.pos = &outPos;
-	service->outStream.buffer=0;
-	service->outStream.capacity=8;
-	
-	/* clear error code */
-	service->errorCode = 0;
-	
-	/* init decoder (read header, set initial state) */
-	/* init runtime table */
-	exiInitNameTableRuntime(&runtimeTableDecode);
-	exiInitDecoder(&(service->inStream), &(service->stateDecode), runtimeTableDecode,stringTableDecode);
-	
-	/* init encoder (write header, set initial state) */
-	exiInitNameTableRuntime(&runtimeTableEncode);
-	exiInitEncoder(&(service->outStream), &(service->stateEncode), runtimeTableEncode,stringTableEncode);
-
-	/* init uniqueID stack */
-	service->idPath.pos=0;
-
-	init_MessageHeaderType(&header);
-	service->exiMsg.V2G_Message.Header = &header;	
-	init_SignatureType(&signature);
-	service->exiMsg.V2G_Message.Header->Signature=&signature;
-
-	/* init EXI message */
-	init_EXIDocumentType(&(service->exiMsg));
-
-	/* deserialize the input stream and call the corresponding service */
-	if(deserializeMessage(service))
-	{
-		/* something went wrong */
-
-		return -1;
-
-	}
-
-	/* determine payload size (without transport offset) */	
-	outPos -= service->transportHeaderOffset;
-	*outStreamLength = outPos;
-
-	
-	return 0;
-}
-
-/** 
- * \brief Init the v2g service data structure
- * \param	service   struct EXIService* Service data structure
- * \param	bytes   bytes_t setted up byte data structure
- * \param	string_ucs_t   setted up string data structure
- * \param	transportHeaderOffset uint16_t Transport protocol offset
- * \return  0 = 0K; -1 = ERROR
- */
-int init_v2gservice(struct EXIService* service, exi_bytes_t service_bytes, exi_string_ucs_t service_string, uint16_t transportHeaderOffset)
-{
-
-	/* init byte array */
-	 service->val.binary = service_bytes;
-
-	/* init string array */
-	 service->val.str.miss = service_string;
-
-
-	 service->idPath.pos=0;
-
-	 /* init offset for transport protocol */
-	service->transportHeaderOffset=transportHeaderOffset;
-
-
-	return 0;
-}

+ 0 - 43
src/service/v2g_serviceDispatcher.h

@@ -1,43 +0,0 @@
-/*
- * Copyright (C) 2007-2010 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef V2GSERVER_H_
-#define V2GSERVER_H_
-
-#include "v2g_dataTypes.h"
-
-
-int init_v2gservice(struct EXIService* service, exi_bytes_t service_bytes, exi_string_ucs_t service_string, uint16_t transportHeaderOffset);
-int messageDispatcher(struct EXIService* service, uint8_t* inStream, uint32_t sizeInStream, uint8_t* outStream, uint32_t sizeOutStream, uint32_t* outPos);
-
-#endif /* V2GSERVER_H_ */
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 189
src/service/v2g_serviceMethods.h

@@ -1,189 +0,0 @@
-
-
-
-
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXISeGen</p>
- *
- ********************************************************************/
-
- 
- #ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifndef SERVICEMETHODS_H
-#define SERVICEMETHODS_H
-
-#include "v2g_dataTypes.h"
-#include "EXITypes.h"
-
-/** This service methods has to be implemented by the EVSE server */
-/** 
- * \brief   This sessionSetup method is called by the service dispatcher if there was passed a sessionSetup-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct SessionSetupReqType Parameter dataset of the sessionSetup request message
- * \param	result  struct SessionSetupResType Result dataset for the sessionSetup response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	sessionSetup(struct MessageHeaderType* header, struct SessionSetupReqType* param, struct SessionSetupResType* result);
-					
-/** 
- * \brief   This serviceDiscovery method is called by the service dispatcher if there was passed a serviceDiscovery-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct ServiceDiscoveryReqType Parameter dataset of the serviceDiscovery request message
- * \param	result  struct ServiceDiscoveryResType Result dataset for the serviceDiscovery response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	serviceDiscovery(struct MessageHeaderType* header, struct ServiceDiscoveryReqType* param, struct ServiceDiscoveryResType* result);
-					
-/** 
- * \brief   This serviceDetail method is called by the service dispatcher if there was passed a serviceDetail-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct ServiceDetailReqType Parameter dataset of the serviceDetail request message
- * \param	result  struct ServiceDetailResType Result dataset for the serviceDetail response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	serviceDetail(struct MessageHeaderType* header, struct ServiceDetailReqType* param, struct ServiceDetailResType* result);
-					
-/** 
- * \brief   This servicePaymentSelection method is called by the service dispatcher if there was passed a servicePaymentSelection-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct ServicePaymentSelectionReqType Parameter dataset of the servicePaymentSelection request message
- * \param	result  struct ServicePaymentSelectionResType Result dataset for the servicePaymentSelection response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	servicePaymentSelection(struct MessageHeaderType* header, struct ServicePaymentSelectionReqType* param, struct ServicePaymentSelectionResType* result);
-					
-/** 
- * \brief   This paymentDetails method is called by the service dispatcher if there was passed a paymentDetails-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct PaymentDetailsReqType Parameter dataset of the paymentDetails request message
- * \param	result  struct PaymentDetailsResType Result dataset for the paymentDetails response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	paymentDetails(struct MessageHeaderType* header, struct PaymentDetailsReqType* param, struct PaymentDetailsResType* result);
-					
-/** 
- * \brief   This contractAuthentication method is called by the service dispatcher if there was passed a contractAuthentication-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct ContractAuthenticationReqType Parameter dataset of the contractAuthentication request message
- * \param	result  struct ContractAuthenticationResType Result dataset for the contractAuthentication response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	contractAuthentication(struct MessageHeaderType* header, struct ContractAuthenticationReqType* param, struct ContractAuthenticationResType* result);
-					
-/** 
- * \brief   This chargeParameterDiscovery method is called by the service dispatcher if there was passed a chargeParameterDiscovery-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct ChargeParameterDiscoveryReqType Parameter dataset of the chargeParameterDiscovery request message
- * \param	result  struct ChargeParameterDiscoveryResType Result dataset for the chargeParameterDiscovery response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	chargeParameterDiscovery(struct MessageHeaderType* header, struct ChargeParameterDiscoveryReqType* param, struct ChargeParameterDiscoveryResType* result);
-					
-/** 
- * \brief   This powerDelivery method is called by the service dispatcher if there was passed a powerDelivery-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct PowerDeliveryReqType Parameter dataset of the powerDelivery request message
- * \param	result  struct PowerDeliveryResType Result dataset for the powerDelivery response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	powerDelivery(struct MessageHeaderType* header, struct PowerDeliveryReqType* param, struct PowerDeliveryResType* result);
-					
-/** 
- * \brief   This chargingStatus method is called by the service dispatcher if there was passed a chargingStatus-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct ChargingStatusReqType Parameter dataset of the chargingStatus request message
- * \param	result  struct ChargingStatusResType Result dataset for the chargingStatus response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	chargingStatus(struct MessageHeaderType* header, struct ChargingStatusReqType* param, struct ChargingStatusResType* result);
-					
-/** 
- * \brief   This meteringReceipt method is called by the service dispatcher if there was passed a meteringReceipt-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct MeteringReceiptReqType Parameter dataset of the meteringReceipt request message
- * \param	result  struct MeteringReceiptResType Result dataset for the meteringReceipt response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	meteringReceipt(struct MessageHeaderType* header, struct MeteringReceiptReqType* param, struct MeteringReceiptResType* result);
-					
-/** 
- * \brief   This sessionStop method is called by the service dispatcher if there was passed a sessionStop-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct SessionStopType Parameter dataset of the sessionStop request message
- * \param	result  struct SessionStopResType Result dataset for the sessionStop response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	sessionStop(struct MessageHeaderType* header, struct SessionStopType* param, struct SessionStopResType* result);
-					
-/** 
- * \brief   This certificateUpdate method is called by the service dispatcher if there was passed a certificateUpdate-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct CertificateUpdateReqType Parameter dataset of the certificateUpdate request message
- * \param	result  struct CertificateUpdateResType Result dataset for the certificateUpdate response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	certificateUpdate(struct MessageHeaderType* header, struct CertificateUpdateReqType* param, struct CertificateUpdateResType* result);
-					
-/** 
- * \brief   This certificateInstallation method is called by the service dispatcher if there was passed a certificateInstallation-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct CertificateInstallationReqType Parameter dataset of the certificateInstallation request message
- * \param	result  struct CertificateInstallationResType Result dataset for the certificateInstallation response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	certificateInstallation(struct MessageHeaderType* header, struct CertificateInstallationReqType* param, struct CertificateInstallationResType* result);
-					
-/** 
- * \brief   This cableCheck method is called by the service dispatcher if there was passed a cableCheck-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct CableCheckReqType Parameter dataset of the cableCheck request message
- * \param	result  struct CableCheckResType Result dataset for the cableCheck response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	cableCheck(struct MessageHeaderType* header, struct CableCheckReqType* param, struct CableCheckResType* result);
-					
-/** 
- * \brief   This preCharge method is called by the service dispatcher if there was passed a preCharge-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct PreChargeReqType Parameter dataset of the preCharge request message
- * \param	result  struct PreChargeResType Result dataset for the preCharge response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	preCharge(struct MessageHeaderType* header, struct PreChargeReqType* param, struct PreChargeResType* result);
-					
-/** 
- * \brief   This currentDemand method is called by the service dispatcher if there was passed a currentDemand-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct CurrentDemandReqType Parameter dataset of the currentDemand request message
- * \param	result  struct CurrentDemandResType Result dataset for the currentDemand response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	currentDemand(struct MessageHeaderType* header, struct CurrentDemandReqType* param, struct CurrentDemandResType* result);
-					
-/** 
- * \brief   This weldingDetection method is called by the service dispatcher if there was passed a weldingDetection-based request message.
- * \param	header  struct MessageHeaderType* Header dataset
- * \param	param   struct WeldingDetectionReqType Parameter dataset of the weldingDetection request message
- * \param	result  struct WeldingDetectionResType Result dataset for the weldingDetection response message 
- * \return  0 = 0K; -1 = ERROR (message dispatcher will return an error) */
-int	weldingDetection(struct MessageHeaderType* header, struct WeldingDetectionReqType* param, struct WeldingDetectionResType* result);
-						
-	
-
-	
-	
-	
-#endif
-
-#ifdef __cplusplus
-}
-#endif

+ 0 - 188
src/test/evse_server.c

@@ -1,188 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-
-
-/* includes for the application handshake protocol */
-#include "appHand_service.h"
-#include "appHand_dataTypes.h"
-#include "v2g_service.h"
-#include "v2gtp.h"
-#include "evse_server.h"
-
-#include "v2g_serviceDispatcher.h"
-
-
-#define MAX_BYTE_SIZE 64
-#define MAX_STRING_SIZE 64
-#define MAX_STREAM_SIZE 100
-
-static int appHandshakeHandler(struct EXIDatabinder* appHandService, uint8_t* inStream, uint32_t sizeInStream, uint8_t* outStream, uint32_t* outStreamLength);
-static void printASCIIString(uint32_t* string, uint32_t len);
-
-int testV2GService(uint8_t* inStream, uint16_t inStreamLength, uint8_t* outStream, uint32_t* outStreamLength)
-{
-	static uint8_t byte_array[MAX_BYTE_SIZE]; /* define MAX_BYTE_SIZE before*/
-	static uint32_t string_array[MAX_STRING_SIZE]; /* define MAX_STRING_SIZE before*/
-	uint32_t exiMsgLength;
-
-	struct EXIDatabinder appHandService;
-	struct EXIService service;
-
-	static uint8_t isHandshake = 1;
-
-	/* BINARY memory setup */
-	exi_bytes_t bytes = { MAX_BYTE_SIZE, byte_array, 0 };
-
-	/* STRING memory setup */
-	exi_string_ucs_t string = { MAX_STRING_SIZE, string_array, 0 };
-
-	/**********************************************
-	 * Init V2G server and initialize array types *
-	 * for the EXI decoding	as well as the offset *
-	 * for the transportation header			  *
-	 **********************************************/
-
-	init_v2gservice(&service, bytes, string, V2GTP_HEADER_LENGTH);
-
-	/* check, if the DoIP header is correct and determine payload */
-	if(read_v2gtpHeader(inStream,inStreamLength, &exiMsgLength))
-	{
-		/* v2gtp header not correct */
-		return -1;
-	}
-
-	/* Here, it is assumed the first message is always the application handshake protocol.
-	 * The successor messages are 15118 charging based messages and handled by the message
-	 * dispatcher. */
-
-	if(isHandshake)
-		{
-
-
-
-			/* init the de- / serializer */
-			init_appHandDeserializer(&appHandService,bytes,string,V2GTP_HEADER_LENGTH);
-			init_appHandSerializer(&appHandService,bytes,string,MAX_STREAM_SIZE,V2GTP_HEADER_LENGTH);
-
-			if(appHandshakeHandler(&appHandService, inStream,inStreamLength,outStream,outStreamLength))
-			{
-				return -1; /* an error occured */
-			}
-
-			isHandshake = 0; /* here: next time a charging message is expected */
-		}
-	else
-	{
-
-
-		/****************************************************************************
-		 * Pass the received EXI message stream (inStream + exiMsgLength) to the    *
-		 * v2g message dispatcher. 	The outStream contains the response message     *
-		 * stream.  																*
-		 ****************************************************************************/
-
-		if(messageDispatcher(&service, inStream, exiMsgLength, outStream, MAX_STREAM_SIZE, outStreamLength))
-		{
-
-			/* an error occurred */
-
-
-		}
-
-	}
-
-	/* write v2gtp header */
-	write_v2gtpHeader(outStream, outStreamLength, V2GTP_EXI_TYPE);
-
-
-
-	return 0;
-
-}
-
-
-/** Example implementation of the app handshake protocol for the EVSE side  */
-static int appHandshakeHandler(struct EXIDatabinder* appHandService, uint8_t* inStream, uint32_t sizeInStream, uint8_t* outStream, uint32_t* outStreamLength)
-{
-	struct EXIDocumentType_appHand exiDoc;
-	struct AnonType_supportedAppProtocolReq handshake;
-	struct AnonType_supportedAppProtocolRes resultHandshake;
-	size_t i;
-
-	init_AnonType_supportedAppProtocolReq(&handshake);
-	init_EXIDocumentType_appHand(&exiDoc);
-
-	/* we expect a supportedAppProtocolReq */
-	exiDoc.supportedAppProtocolReq = &handshake;
-
-
-	if(deserialize_appHand(appHandService,inStream,sizeInStream,&exiDoc))
-	{
-		/* an error occured */
-		return -1;
-	}
-
-	printf("EVSE side: List of application handshake protocols of the EV \n");
-
-	for(i=0;i<handshake.arraylen.AppProtocol;i++)
-	{
-		printf("\tProtocol entry #=%d\n",(i+1));
-		printf("\t\tProtocolNamespace=");
-		printASCIIString(handshake.AppProtocol[i].ProtocolNamespace.data,handshake.AppProtocol[i].ProtocolNamespace.arraylen.data);
-		printf("\t\tVersion=%d.%d\n", handshake.AppProtocol[i].VersionNumberMajor,handshake.AppProtocol[i].VersionNumberMinor);
-		printf("\t\tSchemaID=%d\n", handshake.AppProtocol[i].SchemaID);
-		printf("\t\tPriority=%d\n", handshake.AppProtocol[i].Priority);
-	}
-
-	/* prepare response handshake response:
-	 * it is assumed, we support the 15118 1.0 version :-) */
-	resultHandshake.ResponseCode=OK_SuccessfulNegotiation_responseCodeType;
-	resultHandshake.SchemaID=handshake.AppProtocol[0].SchemaID; /* signal the protocol by the provided schema id*/
-	resultHandshake.isused.SchemaID=1;
-
-	/* assign the response message to the exiDoc */
-	init_EXIDocumentType_appHand(&exiDoc);
-	exiDoc.supportedAppProtocolRes=&resultHandshake;
-	exiDoc.isused.supportedAppProtocolRes=1;
-
-	if(serialize_appHand(appHandService, outStream,outStreamLength, &exiDoc))
-	{
-		return -1;
-	}
-
-
-	return 0;
-}
-
-static void printASCIIString(uint32_t* string, uint32_t len) {
-	unsigned int i;
-	for(i=0; i<len; i++) {
-		printf("%c",(char)string[i]);
-	}
-	printf("\n");
-}
-
-

+ 0 - 33
src/test/evse_server.h

@@ -1,33 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @@version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#ifndef V2G_SERVER_H_
-#define V2G_SERVER_H_
-
-#include "EXITypes.h"
-
-int testV2GService(uint8_t* inStream, uint16_t inStreamLength, uint8_t* outStream,uint32_t* outStreamLength);
-
-#endif /* V2G_SERVER_H_ */

+ 0 - 722
src/test/evse_serviceMethods.c

@@ -1,722 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#include "v2g_serviceMethods.h"
-#include "v2g_dataTypes.h"
-#include <stdio.h>
-#include <string.h>
-
-static void printBinaryArray(uint8_t* byte, uint32_t len);
-
-int	sessionSetup(struct MessageHeaderType* header, struct SessionSetupReqType* param, struct SessionSetupResType* result)
-{
-
-
-
-	printf("EVSE side: sessionSetup called\n"  );
-	printf("\tReceived data:\n");
-	printf("\tHeader SessionID=");
-	printBinaryArray(header->SessionID.data,header->SessionID.arraylen.data );
-	printf("\t\t EVCCID=%d\n",param->EVCCID.data[0]);
-
-	/* generate an unique sessionID */
-	header->SessionID.data[0] = 12;
-	header->SessionID.data[1] = 3;
-	header->SessionID.data[2] = 12;
-	header->SessionID.data[3] = 42;
-	header->SessionID.data[4] = 12;
-	header->SessionID.data[5] = 1;
-	header->SessionID.data[6] = 2;
-	header->SessionID.data[7] = 10;
-	header->SessionID.arraylen.data=8;
-
-	/* Prepare data for EV */
-	result->ResponseCode = OK_responseCodeType;
-	result->EVSEID.data[0]=1;
-	result->EVSEID.arraylen.data=1;
-	result->DateTimeNow=123456789;
-	result->isused.DateTimeNow=1;
-
-
-	return 0;
-
-}
-
-int	serviceDiscovery(struct MessageHeaderType* header, struct ServiceDiscoveryReqType* param, struct ServiceDiscoveryResType* result)
-{
-	printf("EVSE side: serviceDiscovery called\n"  );
-	printf("\tReceived data:\n");
-	printf("\tHeader SessionID=");
-	printBinaryArray(header->SessionID.data,header->SessionID.arraylen.data );
-
-	printf("\t\t ServiceCategory=%d\n", param->ServiceCategory);
-
-	/* generate an unique sessionID */
-	header->SessionID.data[0] = 1;
-	header->SessionID.data[1] = 2;
-	header->SessionID.data[2] = 3;
-	header->SessionID.data[3] = 4;
-	header->SessionID.data[4] = 5;
-	header->SessionID.data[5] = 6;
-	header->SessionID.data[6] = 7;
-	header->SessionID.data[7] = 8;
-	header->SessionID.arraylen.data=8;
-
-	result->isused.ServiceList=0; /* we do not provide VAS */
-	result->ResponseCode= OK_responseCodeType;
-
-
-	result->ChargeService.EnergyTransferType = AC_single_DC_core_EVSESupportedEnergyTransferType;
-	result->ChargeService.ServiceTag.ServiceID=1; /* ID of the charge service */
-	result->ChargeService.ServiceTag.ServiceName.data[0]='A';
-	result->ChargeService.ServiceTag.ServiceName.data[1]='C';
-	result->ChargeService.ServiceTag.ServiceName.data[2]='_';
-	result->ChargeService.ServiceTag.ServiceName.data[3]='D';
-	result->ChargeService.ServiceTag.ServiceName.data[4]='C';
-	result->ChargeService.ServiceTag.ServiceName.arraylen.data=5;
-	result->ChargeService.ServiceTag.isused.ServiceName=1;
-	result->ChargeService.ServiceTag.isused.ServiceScope=0;
-
-	result->ChargeService.FreeService = 1;
-	result->PaymentOptions.PaymentOption[0] = ExternalPayment_paymentOptionType; /* EVSE handles the payment */
-	result->PaymentOptions.arraylen.PaymentOption=1;
-
-	if(param->ServiceCategory==Internet_serviceCategoryType || param->ServiceCategory==OtherCustom_serviceCategoryType || param->isused.ServiceCategory==0)
-	{
-	result->ServiceList.Service[0].FreeService=1;
-	result->ServiceList.Service[0].ServiceTag.ServiceID=22; /* ID of the charge service */
-	result->ServiceList.Service[0].ServiceTag.ServiceName.data[0]='W';
-	result->ServiceList.Service[0].ServiceTag.ServiceName.data[1]='W';
-	result->ServiceList.Service[0].ServiceTag.ServiceName.data[2]='W';
-	result->ServiceList.Service[0].ServiceTag.ServiceName.arraylen.data=3;
-	result->ServiceList.Service[0].ServiceTag.ServiceCategory=Internet_serviceCategoryType;
-	result->ServiceList.Service[0].ServiceTag.isused.ServiceName=1;
-	result->ServiceList.Service[0].ServiceTag.isused.ServiceScope=0;
-
-	result->ServiceList.arraylen.Service=1;
-	result->isused.ServiceList=1;
-
-	} else {
-		result->isused.ServiceList=0; /* no value added service requested */
-	}
-	return 0;
-}
-
-int	servicePaymentSelection(struct MessageHeaderType* header, struct ServicePaymentSelectionReqType* param, struct ServicePaymentSelectionResType* result)
-{
-	printf("EVSE side: servicePaymentSelection called\n"  );
-	printf("\tReceived data:\n");
-	printf("\tHeader SessionID=");
-	printBinaryArray(header->SessionID.data,header->SessionID.arraylen.data );
-
-	if(param->SelectedPaymentOption == ExternalPayment_paymentOptionType)
-		printf("\t\t SelectedPaymentOption=ExternalPayment\n");
-
-	printf("\t\t ServiceID=%d\n",param->SelectedServiceList.SelectedService[0].ServiceID);
-
-	result->ResponseCode = OK_responseCodeType;
-
-	return 0;
-}
-
-int	paymentDetails(struct MessageHeaderType* header, struct PaymentDetailsReqType* param, struct PaymentDetailsResType* result)
-{
-	return 0;
-}
-
-int	chargeParameterDiscovery(struct MessageHeaderType* header, struct ChargeParameterDiscoveryReqType* param, struct ChargeParameterDiscoveryResType* result)
-{
-	struct PhysicalValueType f;
-
-	printf("EVSE side: chargeParameterDiscovery called\n"  );
-	printf("\tReceived data:\n");
-	printf("\t\t EVRequestedEnergyTransferType=%d\n",param->EVRequestedEnergyTransferType);
-
-	/* check,if DC or AC is requested */
-	if(param->EVRequestedEnergyTransferType==DC_core_EVRequestedEnergyTransferType || param->isused.DC_EVChargeParameter==1)
-	{
-
-		printf("\t\t EVStatus:\n");
-		printf("\t\t\t EVReady=%d\n", param->DC_EVChargeParameter->DC_EVStatus.EVReady);
-		printf("\t\t\t EVRESSSOC=%d\n", param->DC_EVChargeParameter->DC_EVStatus.EVRESSSOC);
-		printf("\t\t\t EVErrorCode=%d\n", param->DC_EVChargeParameter->DC_EVStatus.EVErrorCode);
-		printf("\t\t\t EVRESSConditioning=%d\n", param->DC_EVChargeParameter->DC_EVStatus.EVRESSConditioning);
-		printf("\t\t\t EVCabinConditioning=%d\n", param->DC_EVChargeParameter->DC_EVStatus.EVCabinConditioning);
-
-
-		printf("\t\t EVMaximumCurrentLimit=%d\n", param->DC_EVChargeParameter->EVMaximumCurrentLimit.Value);
-		printf("\t\t EVMaximumPowerLimit=%d\n", param->DC_EVChargeParameter->EVMaximumPowerLimit.Value);
-		printf("\t\t EVMaximumVoltageLimit=%d\n", param->DC_EVChargeParameter->EVMaximumVoltageLimit.Value);
-		printf("\t\t EVEnergyCapacity=%d\n", param->DC_EVChargeParameter->EVEnergyCapacity.Value);
-		printf("\t\t EVEnergyRequest=%d\n", param->DC_EVChargeParameter->EVEnergyRequest.Value);
-		printf("\t\t FullSOC=%d\n", param->DC_EVChargeParameter->FullSOC);
-		printf("\t\t BulkSOC=%d\n", param->DC_EVChargeParameter->BulkSOC);
-
-		result->ResponseCode = OK_responseCodeType;
-		result->EVSEProcessing = Finished_EVSEProcessingType;
-
-		result->isused.DC_EVSEChargeParameter = 1;
-		result->isused.AC_EVSEChargeParameter = 0;
-		result->DC_EVSEChargeParameter->DC_EVSEStatus.EVSEStatusCode = EVSE_Ready_DC_EVSEStatusCodeType;
-		result->DC_EVSEChargeParameter->DC_EVSEStatus.EVSEIsolationStatus = Valid_isolationLevelType;
-		result->DC_EVSEChargeParameter->DC_EVSEStatus.isused.EVSEIsolationStatus = 1;
-		result->DC_EVSEChargeParameter->DC_EVSEStatus.EVSENotification = None_EVSENotificationType;
-		result->DC_EVSEChargeParameter->DC_EVSEStatus.NotificationMaxDelay = 0;
-
-		f.Multiplier = 0;
-		f.Unit = A_unitSymbolType;
-		f.isused.Unit=1;
-		f.Value = 50;
-
-		result->DC_EVSEChargeParameter->EVSEMaximumCurrentLimit=f;
-
-		f.Unit = W_unitSymbolType;
-		f.Value = 20000;
-
-		result->DC_EVSEChargeParameter->EVSEMaximumPowerLimit=f;
-		result->DC_EVSEChargeParameter->isused.EVSEMaximumPowerLimit=1;
-
-		f.Unit = V_unitSymbolType;
-		f.Value = 400;
-
-		result->DC_EVSEChargeParameter->EVSEMaximumVoltageLimit=f;
-
-		f.Unit = A_unitSymbolType;
-		f.Value = 5;
-
-		result->DC_EVSEChargeParameter->EVSEMinimumCurrentLimit=f;
-
-		f.Unit = V_unitSymbolType;
-		f.Value = 200;
-
-		result->DC_EVSEChargeParameter->EVSEMinimumVoltageLimit=f;
-
-		f.Unit = A_unitSymbolType;
-		f.Value = 2;
-
-		result->DC_EVSEChargeParameter->EVSECurrentRegulationTolerance=f;
-		result->DC_EVSEChargeParameter->isused.EVSECurrentRegulationTolerance=1;
-
-		f.Unit = A_unitSymbolType;
-		f.Value = 1;
-
-		result->DC_EVSEChargeParameter->EVSEPeakCurrentRipple=f;
-
-		f.Unit = W_unitSymbolType;
-		f.Value = 5000;
-
-		result->DC_EVSEChargeParameter->EVSEEnergyToBeDelivered=f;
-		result->DC_EVSEChargeParameter->isused.EVSEEnergyToBeDelivered=1;
-
-		/* set up a PMax schedule */
-		result->SAScheduleList.SAScheduleTuple[0].SAScheduleTupleID=10;
-		result->SAScheduleList.SAScheduleTuple[0].isused.SalesTariff=0; /* no tariffs */
-
-		/* set up two PMax entries */
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleID=20;
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[0].PMax=20000;
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[0].RelativeTimeInterval.start=0;
-
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[1].PMax=0;
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[1].RelativeTimeInterval.start=1200; /* 20 min */
-
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.arraylen.PMaxScheduleEntry=2; /* we set up two time entries */
-
-
-		/* set up two PMax entries */
-		result->SAScheduleList.SAScheduleTuple[1].SAScheduleTupleID=15;
-		result->SAScheduleList.SAScheduleTuple[1].PMaxSchedule.PMaxScheduleID=30;
-		result->SAScheduleList.SAScheduleTuple[1].PMaxSchedule.PMaxScheduleEntry[0].PMax=10000;
-		result->SAScheduleList.SAScheduleTuple[1].PMaxSchedule.PMaxScheduleEntry[0].RelativeTimeInterval.start=0;
-
-		result->SAScheduleList.SAScheduleTuple[1].PMaxSchedule.PMaxScheduleEntry[1].PMax=0;
-		result->SAScheduleList.SAScheduleTuple[1].PMaxSchedule.PMaxScheduleEntry[1].RelativeTimeInterval.start=1800; /* 30 min */
-
-		result->SAScheduleList.SAScheduleTuple[1].PMaxSchedule.arraylen.PMaxScheduleEntry=2; /* we set up two time entries */
-
-		result->SAScheduleList.arraylen.SAScheduleTuple=2; /* we used 2 tuple */
-
-
-
-
-	} else { /* AC related */
-
-		printf("\t\t DepartureTime=%d\n", param->AC_EVChargeParameter->DepartureTime);
-		printf("\t\t EAmount=%d\n", param->AC_EVChargeParameter->EAmount.Value);
-		printf("\t\t EVMaxCurrent=%d\n", param->AC_EVChargeParameter->EVMaxCurrent.Value);
-		printf("\t\t EVMaxVoltage=%d\n", param->AC_EVChargeParameter->EVMaxVoltage.Value);
-		printf("\t\t EVMinCurrent=%d\n", param->AC_EVChargeParameter->EVMinCurrent.Value);
-
-
-		result->ResponseCode = OK_responseCodeType;
-		result->EVSEProcessing = Finished_EVSEProcessingType;
-
-		result->isused.AC_EVSEChargeParameter = 1;
-		result->isused.DC_EVSEChargeParameter = 0;
-
-		result->AC_EVSEChargeParameter->AC_EVSEStatus.PowerSwitchClosed=1;
-		result->AC_EVSEChargeParameter->AC_EVSEStatus.RCD=1;
-		result->AC_EVSEChargeParameter->AC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-		result->AC_EVSEChargeParameter->AC_EVSEStatus.NotificationMaxDelay=123;
-
-
-		f.Multiplier = 0;
-		f.Unit = A_unitSymbolType;
-		f.isused.Unit=1;
-		f.Value = 100;
-
-		result->AC_EVSEChargeParameter->EVSEMaxCurrent=f;
-
-		f.Unit = V_unitSymbolType;
-		f.Value = 200;
-		result->AC_EVSEChargeParameter->EVSEMaxVoltage=f;
-
-		f.Unit = A_unitSymbolType;
-		f.Value = 300;
-		result->AC_EVSEChargeParameter->EVSEMinCurrent=f;
-
-		/* set up a sales schedule */
-		result->SAScheduleList.SAScheduleTuple[0].SAScheduleTupleID=10;
-		result->SAScheduleList.SAScheduleTuple[0].isused.SalesTariff=1;
-
-		/* set up PMax entries */
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleID=20;
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[0].PMax=20000;
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[0].RelativeTimeInterval.start=0;
-
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[1].PMax=0;
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.PMaxScheduleEntry[1].RelativeTimeInterval.start=1200; /* 20 min */
-
-		result->SAScheduleList.SAScheduleTuple[0].PMaxSchedule.arraylen.PMaxScheduleEntry=2; /* we set up two time entries */
-
-		/* set up sale entries */
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->NumEPriceLevels=2;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffID=20;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->attr_Id.data[0]=100;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->attr_Id.arraylen.data=1;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].EPriceLevel=2;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].RelativeTimeInterval.start=0;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].RelativeTimeInterval.duration=10;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].RelativeTimeInterval.isused.duration=1;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].arraylen.ConsumptionCost=0;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].isused.ConsumptionCost=0;
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->arraylen.SalesTariffEntry=1;
-
-
-		result->SAScheduleList.SAScheduleTuple[0].SalesTariff->isused.SalesTariffDescription=0;
-		result->SAScheduleList.arraylen.SAScheduleTuple=1;
-
-	}
-
-
-
-	return 0;
-}
-
-int	powerDelivery(struct MessageHeaderType* header, struct PowerDeliveryReqType* param, struct PowerDeliveryResType* result)
-{
-
-	int i;
-
-	printf("EVSE side: powerDelivery called\n"  );
-	printf("\tReceived data:\n");
-	printf("\t\t\t ReadyToChargeState=%d\n", param->ReadyToChargeState);
-
-
-
-	if(param->isused.DC_EVPowerDeliveryParameter)
-	{
-
-		printf("\t\t EVStatus:\n");
-		printf("\t\t\t EVReady=%d\n", param->DC_EVPowerDeliveryParameter->DC_EVStatus.EVReady);
-		printf("\t\t\t EVRESSSOC=%d\n", param->DC_EVPowerDeliveryParameter->DC_EVStatus.EVRESSSOC);
-		printf("\t\t\t EVErrorCode=%d\n", param->DC_EVPowerDeliveryParameter->DC_EVStatus.EVErrorCode);
-		printf("\t\t\t EVRESSConditioning=%d\n", param->DC_EVPowerDeliveryParameter->DC_EVStatus.EVRESSConditioning);
-		printf("\t\t\t EVCabinConditioning=%d\n", param->DC_EVPowerDeliveryParameter->DC_EVStatus.EVCabinConditioning);
-
-
-		if(param->isused.ChargingProfile)
-		{
-			printf("\t\t\tChargingProfile:\n");
-			printf("\t\t\t SAScheduleTupleID=%d\n",param->ChargingProfile.SAScheduleTupleID );
-			for(i=0;i<param->ChargingProfile.arraylen.ProfileEntry;i++)
-			{
-				printf("\t\t\t Entry#%d\n",i);
-				printf("\t\t\t\t ChargingProfileEntryMaxPower=%d\n", param->ChargingProfile.ProfileEntry[i].ChargingProfileEntryMaxPower);
-				printf("\t\t\t\t ChargingProfileEntryStart=%d\n", param->ChargingProfile.ProfileEntry[i].ChargingProfileEntryStart);
-
-			}
-
-
-		}
-
-
-		result->ResponseCode = OK_responseCodeType;
-		result->DC_EVSEStatus->EVSEIsolationStatus =1;
-		result->DC_EVSEStatus->isused.EVSEIsolationStatus = 1;
-		result->DC_EVSEStatus->EVSEStatusCode = EVSE_Ready_DC_EVSEStatusCodeType;
-		result->DC_EVSEStatus->EVSENotification=None_EVSENotificationType;
-		result->DC_EVSEStatus->NotificationMaxDelay=123;
-
-		result->isused.DC_EVSEStatus=1;
-		result->isused.AC_EVSEStatus=0;
-
-
-
-
-
-	} else {
-
-
-		result->ResponseCode = OK_responseCodeType;
-		result->AC_EVSEStatus->PowerSwitchClosed=1;
-		result->AC_EVSEStatus->RCD=1;
-		result->AC_EVSEStatus->EVSENotification=None_EVSENotificationType;
-		result->AC_EVSEStatus->NotificationMaxDelay=123;
-
-
-		result->isused.AC_EVSEStatus=1;
-		result->isused.DC_EVSEStatus=0;
-
-	}
-
-	return 0;
-}
-
-int	chargingStatus(struct MessageHeaderType* header, struct ChargingStatusReqType* param, struct ChargingStatusResType* result)
-{
-	printf("EVSE side: chargingStatus called\n"  );
-
-
-
-	result->ResponseCode=OK_responseCodeType;
-	result->EVSEID.data[0]=1;
-	result->EVSEID.arraylen.data=1;
-	result->AC_EVSEStatus.PowerSwitchClosed=1;
-	result->AC_EVSEStatus.RCD=1;
-	result->AC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-	result->AC_EVSEStatus.NotificationMaxDelay=123;
-	result->ReceiptRequired=0;
-	result->EVSEMaxCurrent.Multiplier = 2;
-	result->EVSEMaxCurrent.Unit = A_unitSymbolType;
-	result->EVSEMaxCurrent.isused.Unit=1;
-	result->EVSEMaxCurrent.Value = 400;
-	result->isused.EVSEMaxCurrent=1;
-	result->SAScheduleTupleID=10;
-
-	result->isused.MeterInfo=1;
-	result->MeterInfo.MeterID.arraylen.data=1;
-	result->MeterInfo.MeterID.data[0]=2;
-	result->MeterInfo.MeterReading.Multiplier = 0;
-	result->MeterInfo.MeterReading.Unit = A_unitSymbolType;
-	result->MeterInfo.MeterReading.Value = 500;
-	result->MeterInfo.MeterStatus = 4321;
-	result->MeterInfo.TMeter =123456789;
-	result->MeterInfo.isused.MeterReading = 1;
-	result->MeterInfo.isused.MeterStatus=1;
-	result->MeterInfo.isused.TMeter=1;
-	result->MeterInfo.isused.SigMeterReading=0;
-
-	return 0;
-}
-
-int	meteringReceipt(struct MessageHeaderType* header, struct MeteringReceiptReqType* param, struct MeteringReceiptResType* result)
-{
-
-	printf("EVSE side: meteringReceipt called\n"  );
-	printf("\tReceived data:\n");
-
-	printf("\t\t SAScheduleTupleID=%d\n", param->SAScheduleTupleID);
-	printf("\t\t MeterInfo.MeterStatus=%d\n", param->MeterInfo.MeterStatus);
-	printf("\t\t MeterInfo.MeterID=%d\n",		param->MeterInfo.MeterID.data[0]);
-	printf("\t\t MeterInfo.isused.MeterReading=%d\n", param->MeterInfo.isused.MeterReading);
-	printf("\t\t MeterReading.Value=%d\n",		param->MeterInfo.MeterReading.Value);
-	printf("\t\t MeterInfo.TMeter=%lld\n",		param->MeterInfo.TMeter);
-
-	result->ResponseCode = OK_responseCodeType;
-
-	result->AC_EVSEStatus.PowerSwitchClosed=1;
-	result->AC_EVSEStatus.RCD=1;
-	result->AC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-	result->AC_EVSEStatus.NotificationMaxDelay=123;
-
-
-
-	return 0;
-}
-
-int	cableCheck(struct MessageHeaderType* header, struct CableCheckReqType* param, struct CableCheckResType* result)
-{
-	printf("EVSE side: cableCheck called\n"  );
-	printf("\tReceived data:\n");
-
-
-	printf("\t\t EVStatus:\n");
-	printf("\t\t\t EVReady=%d\n", param->DC_EVStatus.EVReady);
-	printf("\t\t\t EVRESSSOC=%d\n", param->DC_EVStatus.EVRESSSOC);
-	printf("\t\t\t EVErrorCode=%d\n", param->DC_EVStatus.EVErrorCode);
-	printf("\t\t\t EVRESSConditioning=%d\n", param->DC_EVStatus.EVRESSConditioning);
-	printf("\t\t\t EVCabinConditioning=%d\n", param->DC_EVStatus.EVCabinConditioning);
-
-
-	result->ResponseCode = OK_responseCodeType;
-	result->EVSEProcessing = Ongoing_EVSEProcessingType;
-	result->DC_EVSEStatus.EVSEIsolationStatus= Valid_isolationLevelType;
-	result->DC_EVSEStatus.isused.EVSEIsolationStatus = 1;
-	result->DC_EVSEStatus.EVSEStatusCode = EVSE_Ready_DC_EVSEStatusCodeType;
-	result->DC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-	result->DC_EVSEStatus.NotificationMaxDelay=123;
-
-	return 0;
-}
-
-
-int	preCharge(struct MessageHeaderType* header, struct PreChargeReqType* param, struct PreChargeResType* result)
-{
-	struct PhysicalValueType float_type;
-
-
-	printf("EVSE side: preCharge called\n"  );
-	printf("\tReceived data:\n");
-	printf("\t\t EVStatus:\n");
-	printf("\t\t\t EVReady=%d\n", param->DC_EVStatus.EVReady);
-	printf("\t\t\t EVRESSSOC=%d\n", param->DC_EVStatus.EVRESSSOC);
-	printf("\t\t\t EVErrorCode=%d\n", param->DC_EVStatus.EVErrorCode);
-	printf("\t\t\t EVRESSConditioning=%d\n", param->DC_EVStatus.EVRESSConditioning);
-	printf("\t\t\t EVCabinConditioning=%d\n", param->DC_EVStatus.EVCabinConditioning);
-
-	result->ResponseCode = OK_responseCodeType;
-	result->DC_EVSEStatus.EVSEIsolationStatus= Valid_isolationLevelType;
-	result->DC_EVSEStatus.isused.EVSEIsolationStatus = 1;
-	result->DC_EVSEStatus.EVSEStatusCode = EVSE_Ready_DC_EVSEStatusCodeType;
-	result->DC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-	result->DC_EVSEStatus.NotificationMaxDelay=123;
-
-	float_type.Multiplier = 0;
-	float_type.Unit = V_unitSymbolType;
-	float_type.isused.Unit=1;
-	float_type.Value = 100;
-	result->EVSEPresentVoltage = float_type;
-
-
-
-
-	return 0;
-
-
-}
-
-int	currentDemand(struct MessageHeaderType* header, struct CurrentDemandReqType* param, struct CurrentDemandResType* result)
-{
-
-	struct PhysicalValueType f;
-
-	printf("EVSE side: currentDemand called\n"  );
-	printf("\tReceived data:\n");
-	printf("\t\t EVStatus:\n");
-	printf("\t\t\t EVReady=%d\n", param->DC_EVStatus.EVReady);
-	printf("\t\t\t EVRESSSOC=%d\n", param->DC_EVStatus.EVRESSSOC);
-	printf("\t\t\t EVErrorCode=%d\n", param->DC_EVStatus.EVErrorCode);
-	printf("\t\t\t EVRESSConditioning=%d\n", param->DC_EVStatus.EVRESSConditioning);
-	printf("\t\t\t EVCabinConditioning=%d\n", param->DC_EVStatus.EVCabinConditioning);
-
-	printf("\t\t EVTargetCurrent=%d\n", param->EVTargetCurrent.Value);
-	printf("\t\t EVMaximumVoltageLimit=%d\n", param->EVMaximumVoltageLimit.Value);
-	printf("\t\t EVMaximumPowerLimit=%d\n", param->EVMaximumPowerLimit.Value);
-	printf("\t\t EVMaximumCurrentLimit=%d\n", param->EVMaximumCurrentLimit.Value);
-	printf("\t\t BulkChargingComplete=%d\n", param->BulkChargingComplete);
-	printf("\t\t ChargingComplete=%d\n", param->ChargingComplete);
-	printf("\t\t RemainingTimeToFullSoC=%d\n", param->RemainingTimeToFullSoC.Value);
-	printf("\t\t RemainingTimeToBulkSoC=%d\n", param->RemainingTimeToBulkSoC.Value);
-
-	printf("\t\t EVTargetVoltage=%d\n", param->EVTargetVoltage.Value);
-
-
-	result->ResponseCode = OK_responseCodeType;
-	result->DC_EVSEStatus.EVSEIsolationStatus= Valid_isolationLevelType;
-	result->DC_EVSEStatus.isused.EVSEIsolationStatus = 1;
-	result->DC_EVSEStatus.EVSEStatusCode = EVSE_Ready_DC_EVSEStatusCodeType;
-	result->DC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-	result->DC_EVSEStatus.NotificationMaxDelay=123;
-
-	f.Multiplier = 0;
-	f.Unit = V_unitSymbolType;
-	f.isused.Unit=1;
-	f.Value = 400;
-
-	result->EVSEPresentVoltage=f;
-
-	f.Unit = A_unitSymbolType;
-	f.Value = 45;
-
-	result->EVSEPresentCurrent=f;
-
-	result->EVSECurrentLimitAchieved=0;
-
-	result->EVSEVoltageLimitAchieved=1;
-
-	result->EVSEPowerLimitAchieved=0;
-
-	f.Unit = V_unitSymbolType;
-	f.Value = 400;
-
-	result->EVSEMaximumVoltageLimit=f;
-	result->isused.EVSEMaximumVoltageLimit=1;
-
-	f.Unit = A_unitSymbolType;
-	f.Value = 50;
-
-	result->EVSEMaximumCurrentLimit=f;
-	result->isused.EVSEMaximumCurrentLimit=1;
-
-	f.Unit = W_unitSymbolType;
-	f.Value = 20000;
-
-	result->EVSEMaximumPowerLimit=f;
-	result->isused.EVSEMaximumPowerLimit=1;
-
-	return 0;
-}
-
-int	weldingDetection(struct MessageHeaderType* header, struct WeldingDetectionReqType* param, struct WeldingDetectionResType* result)
-{
-
-	printf("EVSE side: weldingDetection called\n"  );
-	printf("\tReceived data:\n");
-	printf("\t\t EVStatus:\n");
-	printf("\t\t\t EVReady=%d\n", param->DC_EVStatus.EVReady);
-	printf("\t\t\t EVRESSSOC=%d\n", param->DC_EVStatus.EVRESSSOC);
-	printf("\t\t\t EVErrorCode=%d\n", param->DC_EVStatus.EVErrorCode);
-	printf("\t\t\t EVRESSConditioning=%d\n", param->DC_EVStatus.EVRESSConditioning);
-	printf("\t\t\t EVCabinConditioning=%d\n", param->DC_EVStatus.EVCabinConditioning);
-
-	result->ResponseCode = OK_responseCodeType;
-	result->DC_EVSEStatus.EVSEIsolationStatus= Valid_isolationLevelType;
-	result->DC_EVSEStatus.isused.EVSEIsolationStatus = 1;
-	result->DC_EVSEStatus.EVSEStatusCode = EVSE_Ready_DC_EVSEStatusCodeType;
-	result->DC_EVSEStatus.EVSENotification=None_EVSENotificationType;
-	result->DC_EVSEStatus.NotificationMaxDelay=1234;
-	result->EVSEPresentVoltage.Value = 123;
-	result->EVSEPresentVoltage.Unit = V_unitSymbolType;
-	result->EVSEPresentVoltage.Multiplier = 0;
-
-	return 0;
-}
-
-int	sessionStop(struct MessageHeaderType* header, struct SessionStopType* param, struct SessionStopResType* result)
-{
-
-
-	printf("EVSE side: sessionStop called\n"  );
-
-
-	result->ResponseCode = OK_responseCodeType;
-
-
-
-	return 0;
-
-}
-
-int	serviceDetail(struct MessageHeaderType* header, struct ServiceDetailReqType* param, struct ServiceDetailResType* result)
-{
-	return 0;
-}
-
-int	contractAuthentication(struct MessageHeaderType* header, struct ContractAuthenticationReqType* param, struct ContractAuthenticationResType* result)
-{
-
-	printf("EVSE: contractAuthentication called\n"  );
-	printf("\tReceived data:\n");
-
-	if(param->isused.GenChallenge)
-		printf("\t\t\t GenChallenge=%d\n", param->GenChallenge.data[0]);
-
-	result->ResponseCode=OK_responseCodeType;
-	result->EVSEProcessing=Ongoing_EVSEProcessingType;
-
-
-	return 0;
-}
-
-int	certificateUpdate(struct MessageHeaderType* header, struct CertificateUpdateReqType* param, struct CertificateUpdateResType* result)
-{
-	return 0;
-}
-
-int	certificateInstallation(struct MessageHeaderType* header, struct CertificateInstallationReqType* param, struct CertificateInstallationResType* result)
-{
-
-	printf("EVSE: certificateInstallation called\n"  );
-	printf("\tReceived data:\n");
-	printf("\t\t\t OEMProvisioningCert=%d\n", param->OEMProvisioningCert.data[0]);
-	printf("\t\t\t RootCertificateID[0]=%d\n", param->ListOfRootCertificateIDs.RootCertificateID[0].data[0]);
-	printf("\t\t\t DHParams[0]=%d\n", param->DHParams.data[0]);
-
-
-
-
-/*	result->ContractEncryptionEncryptedPrivateKey.data[0]=200;
-	result->ContractEncryptionEncryptedPrivateKey.arraylen.data=1;
-*/
-
-	result->ContractID.data[0]=50;
-	result->ContractID.arraylen.data=1;
-
-	result->ContractSignatureEncryptedPrivateKey.data[0]=12;
-	result->ContractSignatureEncryptedPrivateKey.arraylen.data=1;
-
-
-
-	result->ContractSignatureCertChain.Certificate.data[0]=40;
-	result->ContractSignatureCertChain.Certificate.arraylen.data=1;
-
-	result->ContractSignatureCertChain.SubCertificates.arraylen.Certificate=2;
-	result->ContractSignatureCertChain.SubCertificates.Certificate[0].data[0]=20;
-	result->ContractSignatureCertChain.SubCertificates.Certificate[0].arraylen.data=1;
-	result->ContractSignatureCertChain.SubCertificates.Certificate[1].data[0]=80;
-	result->ContractSignatureCertChain.SubCertificates.Certificate[1].arraylen.data=1;
-	result->ContractSignatureCertChain.isused.SubCertificates=1;
-
-	result->DHParams.data[0]=99;
-	result->DHParams.arraylen.data=1;
-
-	result->attr_Id.data[0]=33;
-	result->attr_Id.arraylen.data=1;
-
-	result->ResponseCode = OK_responseCodeType;
-
-	return 0;
-}
-
-static void printBinaryArray(uint8_t* byte, uint32_t len) {
-	unsigned int i;
-	for(i=0; i<len; i++) {
-		printf("%d ",byte[i]);
-	}
-	printf("\n");
-}
-
-

+ 0 - 44
src/test/main.c

@@ -1,44 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Switch for sample programs: EXI codec only or for entire V2G service</p>
- *
- ********************************************************************/
-
-#include <stdio.h>
-#include <stdlib.h>
-
-#include "main.h"
-
-int main(int argc, char *argv[]) {
-#if CODE_VERSION == CODE_VERSION_EXI
-	/* EXI codec only */
-	return main_codec(argc, argv);
-#elif CODE_VERSION == CODE_VERSION_SERVICE
-	/* V2G client / service example scenario */
-	return main_service(argc, argv);
-#endif
-
-}
-

+ 0 - 43
src/test/main.h

@@ -1,43 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- *
- ********************************************************************/
-
-
-#define CODE_VERSION_EXI 1
-#define CODE_VERSION_SERVICE 2
-#define CODE_VERSION CODE_VERSION_SERVICE
-/* #define CODE_VERSION CODE_VERSION_EXI */
-
-#ifndef MAIN_H_
-#define MAIN_H_
-
-#if CODE_VERSION == CODE_VERSION_EXI
-int main_codec(int argc, char *argv[]);
-#elif CODE_VERSION == CODE_VERSION_SERVICE
-int main_service(int argc, char *argv[]);
-#endif
-
-#endif

+ 0 - 466
src/test/main_codec.c

@@ -1,466 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Daniel.Peintner.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- * <p>Code generated by EXIdizer.com</p>
- ********************************************************************/
-
-
-
-/*******************************************************************
- *
- * <p>Sample program to illustrate how to read an EXI stream and
- *  directly write it again to an output</p>
- *
- *  <p>e.g., <executable> in.exi out.exi</p>
- ********************************************************************/
-
-/* Avoid VS warning, put before your included header files */
-/* warning C4996: ‘fopen’: This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. */
-#define _CRT_SECURE_NO_DEPRECATE
-
-#include <stdio.h>
-#include <stdarg.h>
-#include <stdlib.h>
-
-#include "EXIDecoder.h"
-#include "StringTable.h"
-#include "EXIEncoder.h"
-#include "EXITypes.h"
-#include "ByteStream.h"
-#include "ErrorCodes.h"
-#include "QNameDefines.h"
-
-
-/** EXI Debug mode */
-#define EXI_DEBUG 1
-
-
-#if EXI_STREAM == BYTE_ARRAY
-/* 64 kilobytes = 65 536 bytes */
-/* 1 megabyte = 1 048 576 bytes*/
-#define BUFFER_SIZE 256
-uint8_t bufferIn[BUFFER_SIZE];
-uint8_t bufferOut[BUFFER_SIZE];
-#endif /* EXI_STREAM == BYTE_ARRAY */
-
-/* avoids warning: initializer element is not computable at load time */
-#define ARRAY_SIZE_BYTES 100
-uint8_t bytesData[ARRAY_SIZE_BYTES];
-#define ARRAY_SIZE_STRINGS 100
-uint32_t codepoints[ARRAY_SIZE_STRINGS];
-#define ARRAY_SIZE_STRINGS_ASCII 100
-char charsNamespaceURI[ARRAY_SIZE_STRINGS_ASCII];
-char charsLocalName[ARRAY_SIZE_STRINGS_ASCII];
-
-/* String table memory setup */
-uint16_t numberOfLocalStringsDecode[EXI_MAX_NUMBER_OF_QNAMES];
-uint16_t numberOfLocalStringsEncode[EXI_MAX_NUMBER_OF_QNAMES];
-
-#ifndef NULL
-#define NULL   ((void *) 0)
-#endif
-
-#if EXI_DEBUG == 1
-# define DEBUG_PRINTF(x) printf x
-#else
-# define DEBUG_PRINTF(x) do {} while (0)
-#endif
-
-static void debugValue(exi_value_t* val);
-
-
-int main_codec(int argc, char *argv[]) {
-
-	int errn = 0;
-
-	unsigned int k;
-
-	bitstream_t iStream, oStream;
-	uint32_t posDecode;
-	uint32_t posEncode;
-
-	/* EXI set-up */
-	exi_state_t stateDecode;
-	exi_state_t stateEncode;
-	exi_event_t event;
-	uint16_t qnameID = 0; /* qname */
-	uint16_t lastKnownQNameID = EXI_NUMBER_OF_PREPOPULATED_QNAMES - 1;
-	exi_qname_t* qname;
-	exi_value_t val;
-
-	exi_name_table_runtime_t runtimeTableDecode;
-	exi_name_table_runtime_t runtimeTableEncode;
-
-	exi_string_table_t stringTableDecode = { 0, EXI_MAX_NUMBER_OF_QNAMES, numberOfLocalStringsDecode};
-	exi_string_table_t stringTableEncode = { 0, EXI_MAX_NUMBER_OF_QNAMES, numberOfLocalStringsEncode};
-
-	/* BINARY memory setup */
-	exi_bytes_t bytes = { ARRAY_SIZE_BYTES, bytesData, 0 };
-
-	int noEndOfDocument = 1; /* true */
-
-	/* STRING miss memory setup */
-	exi_string_ucs_t string = { ARRAY_SIZE_STRINGS, codepoints, 0 };
-
-#if EXI_DEBUG == 1
-	/* The Eclipse console has buffering problems on Windows e.g, Debug mode */
-	setvbuf(stdout, NULL, _IONBF, 0);
-	setvbuf(stderr, NULL, _IONBF, 0);
-#endif /*EXI_DEBUG*/
-
-	if (argc != 3) {
-		printf("Usage: %s exiInput exiOutput\n", argv[0]);
-		return -1;
-	}
-
-	/* input pos */
-	posDecode = 0;
-
-#if EXI_STREAM == BYTE_ARRAY
-	/* parse EXI stream to internal byte structures  */
-	errn = readBytesFromFile(argv[1], bufferIn, BUFFER_SIZE, posDecode);
-	if (errn < 0) {
-		printf("Problems while reading file into buffer\n");
-		return errn;
-	}
-#endif /* EXI_STREAM == BYTE_ARRAY */
-
-	/* setup input stream */
-#if EXI_STREAM == BYTE_ARRAY
-	iStream.size = BUFFER_SIZE;
-	iStream.data = bufferIn;
-	iStream.pos = &posDecode;
-#endif /* EXI_STREAM == BYTE_ARRAY */
-#if EXI_STREAM == FILE_STREAM
-	iStream.file = fopen(argv[1], "rb");
-#endif /* EXI_STREAM == FILE_STREAM */
-
-	iStream.buffer = 0;
-	iStream.capacity = 0;
-
-	/* setup output stream */
-	posEncode = 0;
-#if EXI_STREAM == BYTE_ARRAY
-	oStream.size = BUFFER_SIZE;
-	oStream.data = bufferOut;
-	oStream.pos = &posEncode;
-#endif
-#if EXI_STREAM == FILE_STREAM
-	oStream.file = fopen(argv[2], "wb");
-#endif /* EXI_STREAM == FILE_STREAM */
-	oStream.buffer = 0;
-	oStream.capacity = 8;
-
-	val.binary = bytes;
-	val.str.type = EXI_STRING_VALUE_MISS;
-	val.str.miss = string;
-
-	/* init decoder (read header, set initial state) */
-	/* init runtime table */
-	errn = exiInitNameTableRuntime(&runtimeTableDecode);
-	exiInitDecoder(&iStream, &stateDecode, runtimeTableDecode, stringTableDecode);
-
-	/* init encoder (write header, set initial state) */
-	errn = exiInitNameTableRuntime(&runtimeTableEncode);
-	exiInitEncoder(&oStream, &stateEncode, runtimeTableEncode, stringTableEncode);
-
-	DEBUG_PRINTF(("[DECODE] >>> EXI  >>> [ENCODE] \n"));
-
-	do {
-		if (errn) {
-			DEBUG_PRINTF(("[Encode-ERROR] %d \n", errn));
-			return errn;
-		}
-
-		errn = exiDecodeNextEvent(&iStream, &stateDecode,
-				&event);
-		if (errn) {
-			DEBUG_PRINTF(("[Decode-ERROR] %d \n", errn));
-			return errn;
-		}
-
-		switch (event) {
-		case EXI_EVENT_START_DOCUMENT:
-			/* decode */
-			errn = exiDecodeStartDocument(&iStream,
-					&stateDecode);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-SD] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((">> START_DOCUMENT \n"));
-			/* encode */
-			errn = exiEncodeStartDocument(&oStream,
-					&stateEncode);
-			break;
-		case EXI_EVENT_END_DOCUMENT:
-			/* decode */
-			errn = exiDecodeEndDocument(&iStream,
-					&stateDecode);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-ED] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((">> END_DOCUMENT \n"));
-			/* encode */
-			errn = exiEncodeEndDocument(&oStream,
-					&stateEncode);
-			/* signalize end of document */
-			noEndOfDocument = 0; /* false */
-			break;
-		case EXI_EVENT_START_ELEMENT:
-		case EXI_EVENT_START_ELEMENT_GENERIC:
-		case EXI_EVENT_START_ELEMENT_GENERIC_UNDECLARED:
-			/* decode */
-			errn = exiDecodeStartElement(&iStream,
-					&stateDecode, &qnameID);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-SE] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((">> SE (%d) \n", qnameID));
-			/* encode */
-			if(qnameID > lastKnownQNameID) {
-				/* new qname */
-				lastKnownQNameID = qnameID;
-				/* URI or LocalName known ? */
-				errn = exiGetLastQName(&qname);
-				if(qname->uri.type == EXI_NAME_ENTRY_TYPE_ID) {
-					/* local name only new */
-					errn = exiEncodeStartElementNS(&oStream,
-							&stateEncode, qname->uri.id, &qname->localName.str);
-				} else {
-					/* both, uri and localname new */
-					errn = exiEncodeStartElementGeneric(&oStream,
-							&stateEncode, &qname->uri.str, &qname->localName.str);
-				}
-			} else {
-				errn = exiEncodeStartElement(&oStream,
-						&stateEncode, qnameID);
-			}
-			break;
-		case EXI_EVENT_END_ELEMENT:
-		case EXI_EVENT_END_ELEMENT_UNDECLARED:
-			/* decode */
-			errn = exiDecodeEndElement(&iStream,
-					&stateDecode, &qnameID);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-EE] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF(("<< EE \n"));
-			/* encode */
-			errn = exiEncodeEndElement(&oStream,
-							&stateEncode);
-			break;
-		case EXI_EVENT_CHARACTERS:
-		case EXI_EVENT_CHARACTERS_GENERIC:
-		case EXI_EVENT_CHARACTERS_GENERIC_UNDECLARED:
-			/* decode */
-			errn = exiDecodeCharacters(&iStream,
-					&stateDecode, &val);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-CH] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((" CH: "));
-			debugValue(&val);
-			/* encode */
-			errn = exiEncodeCharacters(&oStream,
-						&stateEncode, &val);
-
-			/* list value: special behavior */
-			if (val.type == EXI_DATATYPE_LIST) {
-				for(k=0; k<val.list.len; k++) {
-					errn = exiDecodeListValue(&iStream, &stateDecode, qnameID, &val, val.list);
-					if (errn) {
-						DEBUG_PRINTF(("[Decode-ERROR-CH_LIST] %d \n", errn));
-						return errn;
-					}
-					DEBUG_PRINTF((" CH: "));
-					debugValue(&val);
-					/* encode list value */
-					errn = exiEncodeListValue(&oStream, &stateEncode, qnameID,
-									&val, val.list);
-				}
-			}
-			break;
-		case EXI_EVENT_ATTRIBUTE:
-		case EXI_EVENT_ATTRIBUTE_GENERIC:
-		case EXI_EVENT_ATTRIBUTE_GENERIC_UNDECLARED:
-		case EXI_EVENT_ATTRIBUTE_INVALID_VALUE:
-			/* decode */
-			errn = exiDecodeAttribute(&iStream, &stateDecode,
-					&qnameID, &val);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-AT] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((" AT (%d): ", qnameID));
-			debugValue(&val);
-			/* encode */
-			if(qnameID > lastKnownQNameID) {
-				/* new qname */
-				lastKnownQNameID = qnameID;
-				/* URI or LocalName known ? */
-				errn = exiGetLastQName(&qname);
-				if(qname->uri.type == EXI_NAME_ENTRY_TYPE_ID) {
-					/* local name only new */
-					errn = exiEncodeAttributeNS(&oStream,
-							&stateEncode, qname->uri.id, &qname->localName.str, &val);
-				} else {
-					/* both, uri and localname new */
-					errn = exiEncodeAttributeGeneric(&oStream,
-							&stateEncode, &qname->uri.str, &qname->localName.str, &val);
-				}
-			} else {
-				errn = exiEncodeAttribute(&oStream, &stateEncode,
-						qnameID, &val);
-			}
-			break;
-		case EXI_EVENT_ATTRIBUTE_XSI_NIL:
-			/* decode */
-			errn = exiDecodeAttributeXsiNil(&iStream,
-					&stateDecode, &val);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-AT-NIL] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((" AT {xsi}nil == %i \n", val.boolean));
-			/* encode */
-			errn = exiEncodeAttributeXsiNil(&oStream,
-					&stateEncode, &val);
-			break;
-		case EXI_EVENT_ATTRIBUTE_XSI_TYPE:
-			/* decode */
-			errn = exiDecodeAttributeXsiType(&iStream,
-					&stateDecode, &val);
-			if (errn) {
-				DEBUG_PRINTF(("[Decode-ERROR-AT-TYPE] %d \n", errn));
-				return errn;
-			}
-			DEBUG_PRINTF((" AT {type}type == {%d}%d \n", val.eqname.namespaceURI, val.eqname.localPart));
-			/* encode */
-			errn = exiEncodeAttributeXsiType(&oStream,
-					&stateEncode, &val);
-			break;
-		default:
-			/* ERROR */
-			DEBUG_PRINTF(("[Unknown-Event] %d \n", event));
-			return EXI_ERROR_UNKOWN_EVENT;
-		}
-
-	} while (noEndOfDocument);
-
-#if EXI_STREAM == BYTE_ARRAY
-	/* write to file */
-	writeBytesToFile(oStream.data, posEncode, argv[2]);
-#endif
-#if EXI_STREAM == FILE_STREAM
-	fclose(iStream.file);
-	fclose(oStream.file);
-#endif
-
-	return 0;
-}
-
-
-
-static void debugValue(exi_value_t* val) {
-#if EXI_DEBUG == 1
-	int i;
-	switch (val->type) {
-	case EXI_DATATYPE_INTEGER:
-		switch (val->integer.type) {
-		/* Unsigned Integer */
-		case EXI_UNSIGNED_INTEGER_8:
-			printf("uint8 : %d \n", val->integer.val.uint8);
-			break;
-		case EXI_UNSIGNED_INTEGER_16:
-			printf("uint16 : %d \n", val->integer.val.uint16);
-			break;
-		case EXI_UNSIGNED_INTEGER_32:
-			printf("uint32 : %d \n", val->integer.val.uint32);
-			break;
-		case EXI_UNSIGNED_INTEGER_64:
-			printf("uint64 : %ld \n",
-					(long unsigned int) val->integer.val.uint64);
-			break;
-			/* (Signed) Integer */
-		case EXI_INTEGER_8:
-			printf("int8 : %d \n", val->integer.val.int8);
-			break;
-		case EXI_INTEGER_16:
-			printf("int16 : %d \n", val->integer.val.int16);
-			break;
-		case EXI_INTEGER_32:
-			printf("int32 : %d \n", val->integer.val.int32);
-			break;
-		case EXI_INTEGER_64:
-			printf("int64 : %ld \n", (long int) val->integer.val.int64);
-			break;
-		}
-		break;
-	case EXI_DATATYPE_BINARY_BASE64:
-	case EXI_DATATYPE_BINARY_HEX:
-		printf("Binary (len == %d) : ", val->binary.len);
-		for (i = 0; i < val->binary.len; i++) {
-			printf(" [%d]", val->binary.data[i]);
-		}
-		printf("\n");
-		break;
-	case EXI_DATATYPE_BOOLEAN:
-		printf("Boolean : %d \n", val->boolean);
-		break;
-	case EXI_DATATYPE_STRING:
-		switch(val->str.type) {
-		case EXI_STRING_VALUE_MISS:
-			printf("String Miss (len==%d) : '", val->str.miss.len);
-			for (i = 0; i < val->str.miss.len; i++) {
-				printf("%c", (char) val->str.miss.codepoints[i]);
-			}
-			printf("'\n");
-			break;
-		case EXI_STRING_VALUE_LOCAL_HIT:
-			printf("String LocalHit: %d \n", val->str.localID);
-			break;
-		case EXI_STRING_VALUE_GLOBAL_HIT:
-			printf("String GlobalHit: %d \n", val->str.globalID);
-			break;
-		}
-		break;
-	case EXI_DATATYPE_LIST:
-		printf("List (len==%d) \n", val->list.len);
-		break;
-	case EXI_DATATYPE_QNAME:
-		printf("QName (uri==%d, localName=%d) \n", val->eqname.namespaceURI, val->eqname.localPart);
-		break;
-	default:
-		printf(" ?Value-Type? \n");
-		break;
-	}
-#endif /*EXI_DEBUG*/
-}
-
-

+ 0 - 1615
src/test/pev_service.c

@@ -1,1615 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-/* includes for the application handshake protocol */
-#include "appHand_service.h"
-#include "appHand_dataTypes.h"
-
-
-/* includes V2GTP */
-#include "v2gtp.h"
-
-/* includes for example data transmitter */
-#include "v2g_serviceClientDataTransmitter.h"
-
-/* includes of the 15118 messaging */
-#include "v2g_service.h"
-#include "v2g_dataTypes.h"
-#include "v2g_dataTypes.c"
-#include "v2g_serviceClientStubs.h"
-#include "EXITypes.h"
-
-
-
-
-#include <stdio.h>
-
-#define MAX_BYTE_SIZE 128
-#define MAX_STRING_SIZE 256
-#define MAX_STREAM_SIZE 100
-
-
-static void printErrorMessage(struct EXIService* service);
-static void printDCEVSEStatus(struct DC_EVSEStatusType* status);
-static void printACEVSEStatus(struct AC_EVSEStatusType* status);
-static void printASCIIString(uint32_t* string, uint32_t len);
-static void printBinaryArray(uint8_t* byte, uint32_t len);
-static int writeStringToEXIString(char* string, uint32_t* exiString);
-
-
-
-static int appHandshake()
-{
-	static uint8_t byte_array[MAX_BYTE_SIZE]; /* define MAX_BYTE_SIZE before*/
-	static uint32_t string_array[MAX_STRING_SIZE]; /* define MAX_STRING_SIZE before*/
-
-	/* define in and out byte stream */
-	uint8_t inStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
-	uint8_t outStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
-
-	/* BINARY memory setup */
-	exi_bytes_t bytes = { MAX_BYTE_SIZE, byte_array, 0 };
-
-	/* STRING memory setup */
-	exi_string_ucs_t string = { MAX_STRING_SIZE, string_array, 0 };
-
-	struct EXIDatabinder appHandService;
-	struct EXIDocumentType_appHand exiDoc;
-	struct AnonType_supportedAppProtocolReq handshake;
-	struct AnonType_supportedAppProtocolRes resultHandshake;
-	uint32_t length, payloadLength;
-
-	/* init the app handshake serializer.
-	 * Important: also provide the offset of the V2GTP header length */
-	init_appHandSerializer(&appHandService,bytes,string,MAX_STREAM_SIZE, V2GTP_HEADER_LENGTH);
-
-	init_EXIDocumentType_appHand(&exiDoc);
-
-	printf("EV side: setup data for the supported application handshake request message\n");
-
-	/* set up ISO/IEC 15118 Version 1.0 information */
-	length = writeStringToEXIString("urn:iso:15118:2:2010:MsgDef", handshake.AppProtocol[0].ProtocolNamespace.data);
-	handshake.AppProtocol[0].ProtocolNamespace.arraylen.data = length; /* length of the string */
-	handshake.AppProtocol[0].SchemaID=1;
-	handshake.AppProtocol[0].VersionNumberMajor=1;
-	handshake.AppProtocol[0].VersionNumberMinor=0;
-	handshake.AppProtocol[0].Priority=1;
-
-	length = writeStringToEXIString("urn:din:70121:2012:MsgDef", handshake.AppProtocol[1].ProtocolNamespace.data);
-	handshake.AppProtocol[1].ProtocolNamespace.arraylen.data = length; /* length of the string */
-	handshake.AppProtocol[1].SchemaID=2;
-	handshake.AppProtocol[1].VersionNumberMajor=1;
-	handshake.AppProtocol[1].VersionNumberMinor=0;
-	handshake.AppProtocol[1].Priority=2;
-
-
-	handshake.arraylen.AppProtocol=2; /* we have only one protocol implemented */
-
-	/* assign handshake request structure to the exiDoc and signal it */
-	exiDoc.supportedAppProtocolReq = &handshake;
-	exiDoc.isused.supportedAppProtocolReq=1;
-
-	payloadLength=0;
-	if(serialize_appHand(&appHandService, outStream,&payloadLength, &exiDoc))
-	{
-		/* an error occured */
-		return -1;
-	}
-	printf("EV side: send message to the EVSE\n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, payloadLength, inStream);
-
-	/* Init deserializer
-	 * Provide here also the offset of the transport protocol */
-	init_appHandDeserializer(&appHandService,bytes,string,V2GTP_HEADER_LENGTH);
-
-
-	/* setup the */
- 	init_EXIDocumentType_appHand(&exiDoc);
-	exiDoc.supportedAppProtocolRes=&resultHandshake;
-	exiDoc.isused.supportedAppProtocolRes=1;
-
-	if(deserialize_appHand(&appHandService,inStream,100,&exiDoc))
-	{
-		/* an error occurred */
-		return -1;
-	}
-
-	printf("EV side: Response of the EVSE \n");
-	if(resultHandshake.ResponseCode==OK_SuccessfulNegotiation_responseCodeType)
-	{
-		printf("\t\tResponseCode=OK_SuccessfulNegotiation\n");
-		printf("\t\tSchemaID=%d\n",resultHandshake.SchemaID );
-	}
-
-	return 0;
-
-}
-
-
-
-
-
-
-static int ac_charging()
-{
-
-
-	static uint8_t byte_array[MAX_BYTE_SIZE]; /* define MAX_BYTE_SIZE before*/
-	static uint32_t string_array[MAX_STRING_SIZE]; /* define MAX_STRING_SIZE before*/
-
-	/* define in and out byte stream */
-	uint8_t inStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
-	uint8_t outStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
-
-
-
-	/* define offset variable for transport header data */
-	uint16_t transportHeaderOffset;
-
-
-	/* service data structure for AC*/
-	struct EXIService service;
-	struct MessageHeaderType v2gHeader;
-	struct SessionSetupReqType sessionSetup;
-	struct SessionSetupResType resultSessionSetup;
-	struct ServiceDiscoveryReqType serviceDiscovery;
-	struct ServiceDiscoveryResType resultServiceDiscovery;
-	struct ServicePaymentSelectionReqType servicePayment;
-	struct ServicePaymentSelectionResType resultServicePayment;
-	struct ChargeParameterDiscoveryReqType powerDiscovery;
-	struct ChargeParameterDiscoveryResType resultPowerDiscovery;
-	struct PowerDeliveryReqType powerDelivery;
-	struct PowerDeliveryResType resultPowerDelivery;
-	struct ChargingStatusResType resultChargingStatus;
-	struct MeteringReceiptReqType meteringReceipt;
-	struct MeteringReceiptResType resultMeteringReceipt;
-	struct SessionStopResType resultSessionStop;
-	struct AC_EVSEStatusType evseStatus;
-	struct AC_EVChargeParameterType EVChargeParameter;
-	struct AC_EVSEChargeParameterType evseChargeParameter;
-
-	struct SalesTariffType sales;
-
-	struct PhysicalValueType float_type;
-
-	enum responseMessages resMsg;
-
-	uint32_t outPayloadLength;
-
-
-	/* BINARY memory setup */
-	exi_bytes_t bytes = { MAX_BYTE_SIZE, byte_array, 0 };
-
-	/* STRING memory setup */
-	exi_string_ucs_t string = { MAX_STRING_SIZE, string_array, 0 };
-
-	/* setup offset for DoIP header (otherwise set
-	 * transportHeaderOffset=0 if no transfer protocol is used)*/
-	transportHeaderOffset = V2GTP_HEADER_LENGTH;
-
-
-	/*******************
-	 * Init V2G Client *
-	 *******************/
-
-	init_v2gServiceClient(&service,bytes,string,inStream,MAX_STREAM_SIZE, outStream, MAX_STREAM_SIZE, &outPayloadLength, transportHeaderOffset);
-
-
-	/*******************************
-	 * Setup data for sessionSetup *
-	 *******************************/
-
-	/* setup header information */
-	v2gHeader.SessionID.data[0] = 0; /* sessionID is always '0' at the beginning (the response contains the valid sessionID)*/
-	v2gHeader.SessionID.data[1] = 0;
-	v2gHeader.SessionID.data[2] = 0;
-	v2gHeader.SessionID.data[3] = 0;
-	v2gHeader.SessionID.data[4] = 0;
-	v2gHeader.SessionID.data[5] = 0;
-	v2gHeader.SessionID.data[6] = 0;
-	v2gHeader.SessionID.data[7] = 0;
-	v2gHeader.SessionID.arraylen.data = 8; /* length of the byte session array is always 8*/
-
-	v2gHeader.isused.Notification=0; /* no notification */
-	v2gHeader.isused.Signature=0; /* no security */
-
-	/* setup sessionSetup parameter */
-	sessionSetup.EVCCID.data[0]=10;
-	sessionSetup.EVCCID.arraylen.data=1;
-
-
-	printf("EV side: prepare EVSE sessionSetup\n");
-
-	/************************
-	 * Prepare sessionSetup *
-	 ************************/
-
-	if(prepare_sessionSetup(&service,&v2gHeader, &sessionSetup,&resultSessionSetup))
-	{
-
-		printErrorMessage(&service);
-		return 0;
-	}
-
-	printf("EV side: call EVSE sessionSetup");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream */
-	if(	determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-
-
-	/* check, if this is the sessionSetup response message */
-	if(resMsg==SESSIONSETUPRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup */
-		printf("EV side: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\tResponseCode=%d\n",resultSessionSetup.ResponseCode);
-		printf("\tEVSEID=%d\n",	resultSessionSetup.EVSEID.data[0]);
-		printf("\tDateTimeNow=%lld\n",resultSessionSetup.DateTimeNow);
-
-	}
-
-	/*******************************************
-	 * Setup data for serviceDiscovery *
-	 *******************************************/
-
-	serviceDiscovery.isused.ServiceCategory=1;
-	serviceDiscovery.ServiceCategory = 	Internet_serviceCategoryType;
-	serviceDiscovery.isused.ServiceScope=0;
-
-
-	printf("\n\nEV side: prepare EVSE serviceDiscovery\n");
-
-	/****************************
-	 * Prepare serviceDiscovery *
-	 ****************************/
-
-	prepare_serviceDiscovery(&service,&v2gHeader, &serviceDiscovery,&resultServiceDiscovery);
-
-	printf("EV side: call EVSE serviceDiscovery ");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-	/* check, if this is the serviceDiscovery response message */
-	if(resMsg==SERVICEDISCOVERYRES)
-	{
-		/* show result of the answer message of EVSE serviceDiscovery */
-		printf("EV side: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\t ResponseCode=%d\n",resultServiceDiscovery.ResponseCode);
-		printf("\t ServiceID=%d\n",	resultServiceDiscovery.ChargeService.ServiceTag.ServiceID);
-		printf("\t ServiceName=");
-		printASCIIString(resultServiceDiscovery.ChargeService.ServiceTag.ServiceName.data,(uint32_t)resultServiceDiscovery.ChargeService.ServiceTag.ServiceName.arraylen.data );
-		if(	resultServiceDiscovery.PaymentOptions.PaymentOption[0]==ExternalPayment_paymentOptionType)
-		printf("\t PaymentOption=ExternalPayment\n");
-		if(resultServiceDiscovery.ChargeService.EnergyTransferType==AC_single_DC_core_EVSESupportedEnergyTransferType)
-		printf("\t EnergyTransferType=AC_single_DC_core\n");
-		printf("\t Value added service list:\n");
-		printf("\t\t ServiceID=%d\n",	resultServiceDiscovery.ServiceList.Service[0].ServiceTag.ServiceID);
-		printf("\t\t ServiceName=");
-		printASCIIString(resultServiceDiscovery.ServiceList.Service[0].ServiceTag.ServiceName.data,(uint32_t)resultServiceDiscovery.ServiceList.Service[0].ServiceTag.ServiceName.arraylen.data );
-		if(resultServiceDiscovery.ServiceList.Service[0].ServiceTag.ServiceCategory==Internet_serviceCategoryType)
-		printf("\t\t ServiceCategory=Internet\n");
-
-	}
-
-
-	/*******************************************
-	 * Setup data for ServicePaymentSelection *
-	 *******************************************/
-
-	servicePayment.SelectedPaymentOption = ExternalPayment_paymentOptionType;
-	servicePayment.SelectedServiceList.SelectedService[0].ServiceID=1; /* charge server ID */
-	servicePayment.SelectedServiceList.SelectedService[0].isused.ParameterSetID=0; /* is not used */
-	servicePayment.SelectedServiceList.arraylen.SelectedService=1; /* only one service was selected */
-
-	printf("\n\nEV side: prepare EVSE servicePaymentSelection\n");
-
-	/***********************************
-	 * Prepare ServicePaymentSelection *
-	 ***********************************/
-
-	if(prepare_servicePaymentSelection(&service,&v2gHeader, &servicePayment,&resultServicePayment))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-	printf("EV side: call EVSE ServicePaymentSelection \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-
-
-	/* check, if this is the servicePaymentSelection response message */
-	if(resMsg==SERVICEPAYMENTSELECTIONRES)
-	{
-		/* show result of the answer message of EVSE servicePaymentSelection */
-		printf("EV side: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\t ResponseCode=%d\n",resultServicePayment.ResponseCode);
-	}
-
-
-
-
-
-
-
-	/*******************************************
-	 * Setup data for chargeParameterDiscovery *
-	 *******************************************/
-	printf("\n\nEV side: prepare EVSE chargeParameterDiscovery\n");
-
-	powerDiscovery.EVRequestedEnergyTransferType = AC_three_phase_core_EVRequestedEnergyTransferType;
-
-	EVChargeParameter.DepartureTime = 12345;
-
-	float_type.Multiplier = 0;
-	float_type.Unit = W_unitSymbolType;
-	float_type.isused.Unit=1;
-	float_type.Value = 100;
-
-	EVChargeParameter.EAmount = float_type;
-
-	float_type.Unit = A_unitSymbolType;
-	float_type.Value = 200;
-
-	EVChargeParameter.EVMaxCurrent= float_type;
-
-	float_type.Unit = V_unitSymbolType;
-	float_type.Value = 400;
-
-	EVChargeParameter.EVMaxVoltage=float_type;
-
-	float_type.Unit = A_unitSymbolType;
-	float_type.Value = 500;
-
-	EVChargeParameter.EVMinCurrent=float_type;
-
-	powerDiscovery.AC_EVChargeParameter = &EVChargeParameter;
-	powerDiscovery.isused.AC_EVChargeParameter = 1; /* we use here DC based charging parameters */
-	powerDiscovery.isused.DC_EVChargeParameter = 0;
-
-	resultPowerDiscovery.AC_EVSEChargeParameter = &evseChargeParameter; /* we expect AC-based parameters from the evse*/
-
-	init_SalesTariffType(&sales);
-	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff = &sales;
-
-	prepare_chargeParameterDiscovery(&service,&v2gHeader,&powerDiscovery,&resultPowerDiscovery);
-
-
-	printf("EV side: call EVSE chargeParameterDiscovery");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the chargeParameterDiscovery response message */
-	if(resMsg==CHARGEPARAMETERDISCOVERYRES)
-
-	{
-
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\tResponseCode=%d\n",resultPowerDiscovery.ResponseCode);
-		printACEVSEStatus(&(resultPowerDiscovery.AC_EVSEChargeParameter->AC_EVSEStatus));
-
-		if(resultPowerDiscovery.EVSEProcessing==Finished_EVSEProcessingType)
-			printf("\tEVSEProcessing=Finished\n");
-
-
-		printf("\t EVSEMaxCurrent=%d\n",resultPowerDiscovery.AC_EVSEChargeParameter->EVSEMaxCurrent.Value);
-		printf("\t EVSEMaxVoltage=%d\n",resultPowerDiscovery.AC_EVSEChargeParameter->EVSEMaxVoltage.Value);
-		printf("\t EVSEMinimumCurrentLimit=%d\n",resultPowerDiscovery.AC_EVSEChargeParameter->EVSEMinCurrent.Value);
-
-		printf("\t NumEPriceLevels=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->NumEPriceLevels);
-		printf("\t SalesTariffID=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffID);
-		printf("\t NumEPriceLevels=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->NumEPriceLevels);
-		printf("\t attr_Id=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->attr_Id.data[0]);
-		printf("\t EPriceLevel=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].EPriceLevel);
-		printf("\t start=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].RelativeTimeInterval.start);
-		printf("\t duration=%d\n",	resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SalesTariff->SalesTariffEntry[0].RelativeTimeInterval.duration);
-
-
-	}
-
-
-	/*********************************
-	 * Setup data for powerDelivery *
-	 *********************************/
-
-	printf("\n\nEV side: prepare EVSE powerDelivery\n");
-
-	powerDelivery.ReadyToChargeState = 1;
-	powerDelivery.isused.ChargingProfile= 0;
-	powerDelivery.isused.DC_EVPowerDeliveryParameter=0; /* only used for DC charging */
-	resultPowerDelivery.AC_EVSEStatus = &evseStatus; /* we expect an evse status */
-
-	prepare_powerDelivery(&service,&v2gHeader,&powerDelivery,&resultPowerDelivery);
-
-	printf("EV side: call EVSE powerDelivery \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the powerDelivery response message */
-	if(resMsg==POWERDELIVERYRES)
-	{
-
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		printf("\tResponseCode=%d\n",resultPowerDelivery.ResponseCode);
-		printACEVSEStatus(&evseStatus);
-	}
-
-
-
-
-
-
-	/*********************************
-	 * Setup data for chargingStatus *
-	 *********************************/
-
-	printf("\n\nEV side: prepare EVSE chargingStatus\n");
-
-	/***************************
-	 * Prepare chargingStatus  *
-	 ***************************/
-
-	if(prepare_chargingStatus(&service,&v2gHeader,&resultChargingStatus))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE chargingStatus \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the chargingStatus response message */
-	if(resMsg==CHARGINGSTATUSRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultChargingStatus.ResponseCode);
-		printACEVSEStatus(&resultChargingStatus.AC_EVSEStatus);
-		printf("\tReceiptRequired=%d\n",resultChargingStatus.ReceiptRequired);
-		printf("\tEVSEID=%d\n",resultChargingStatus.EVSEID.data[0]);
-		printf("\tEVSEMaxCurrent=%d\n",resultChargingStatus.EVSEMaxCurrent.Value);
-		printf("\tisused.MeterInfo=%d\n",		resultChargingStatus.isused.MeterInfo);
-		printf("\t\tMeterInfo.MeterID=%d\n",		resultChargingStatus.MeterInfo.MeterID.data[0]);
-		printf("\t\tMeterInfo.MeterReading.Value=%d\n",		resultChargingStatus.MeterInfo.MeterReading.Value);
-		printf("\t\tMeterInfo.MeterStatus=%d\n",		resultChargingStatus.MeterInfo.MeterStatus);
-		printf("\t\tMeterInfo.TMeter=%lld\n",		resultChargingStatus.MeterInfo.TMeter);
-	}
-
-
-
-
-
-
-	/***********************************
-	 * Setup data for meteringReceipt *
-	 ***********************************/
-
-
-	meteringReceipt.SessionID = v2gHeader.SessionID;
-	meteringReceipt.SAScheduleTupleID = 12;
-	meteringReceipt.isused.SAScheduleTupleID=1;
-	meteringReceipt.MeterInfo.MeterStatus = 2;
-	meteringReceipt.MeterInfo.isused.MeterStatus = 1;
-	meteringReceipt.MeterInfo.MeterID.arraylen.data=1;
-	meteringReceipt.MeterInfo.MeterID.data[0]=3;
-
-	meteringReceipt.MeterInfo.MeterReading.Multiplier = 0;
-	meteringReceipt.MeterInfo.MeterReading.Unit = A_unitSymbolType;
-	meteringReceipt.MeterInfo.MeterReading.Value = 100;
-	meteringReceipt.MeterInfo.isused.MeterReading = 1;
-	meteringReceipt.MeterInfo.isused.SigMeterReading = 0;
-
-	meteringReceipt.MeterInfo.TMeter =123456789;
-	meteringReceipt.MeterInfo.isused.TMeter = 1;
-
-	meteringReceipt.isused.attr_Id=0; /* message is not signed */
-
-	printf("\n\nEV side: prepare EVSE meteringReceipt\n");
-
-	/****************************
-	 * Prepare meteringReceipt  *
-	 ****************************/
-
-	if(prepare_meteringReceipt(&service,&v2gHeader,&meteringReceipt,&resultMeteringReceipt))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE meteringReceipt \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the meteringReceipt response message */
-	if(resMsg==METERINGRECEIPTRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultMeteringReceipt.ResponseCode);
-		printACEVSEStatus(&resultMeteringReceipt.AC_EVSEStatus);
-	}
-
-
-	/***********************************
-	 * Setup data for stopSession *
-	 ***********************************/
-
-	printf("\n\nEV side: prepare EVSE stopSession\n");
-
-	/************************
-	 * Prepare stopSession  *
-	 ************************/
-
-	if(prepare_sessionStop(&service,&v2gHeader,&resultSessionStop))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE stopSession \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the stopSession response message */
-	if(resMsg==SESSIONSTOPRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultSessionStop.ResponseCode);
-	}
-
-	return 0;
-}
-
-static int dc_charging()
-{
-
-
-
-	static uint8_t byte_array[MAX_BYTE_SIZE]; /* define MAX_BYTE_SIZE before*/
-	static uint32_t string_array[MAX_STRING_SIZE]; /* define MAX_STRING_SIZE before*/
-
-	/* define in and out byte stream */
-	uint8_t inStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
-	uint8_t outStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
-
-
-
-	/* define offset variable for transport header data */
-	uint16_t transportHeaderOffset;
-
-
-	/* service data structure for DC*/
-	struct EXIService service;
-	struct MessageHeaderType v2gHeader;
-	struct SessionSetupReqType sessionSetup;
-	struct SessionSetupResType resultSessionSetup;
-	struct ServiceDiscoveryReqType serviceDiscovery;
-	struct ServiceDiscoveryResType resultServiceDiscovery;
-	struct ServicePaymentSelectionReqType servicePayment;
-	struct ServicePaymentSelectionResType resultServicePayment;
-	struct ContractAuthenticationReqType contractAuthentication;
-	struct ContractAuthenticationResType resultContractAuthentication;
-	struct ChargeParameterDiscoveryReqType powerDiscovery;
-	struct ChargeParameterDiscoveryResType resultPowerDiscovery;
-	struct CableCheckReqType cableCheck;
-	struct CableCheckResType resultCableCheck;
-	struct PowerDeliveryReqType powerDelivery;
-	struct PowerDeliveryResType resultPowerDelivery;
-	struct PreChargeReqType preCharge;
-	struct PreChargeResType resultPreCharge;
-	struct CurrentDemandReqType currentDemand;
-	struct CurrentDemandResType resultCurrentDemand;
-	struct WeldingDetectionReqType weldingDetection;
-	struct WeldingDetectionResType resultWeldingDetection;
-	struct SessionStopResType resultSessionStop;
-
-	struct DC_EVStatusType EVStatus;
-	struct DC_EVSEStatusType evseStatus;
-	struct DC_EVChargeParameterType EVChargeParameter;
-	struct DC_EVSEChargeParameterType evseChargeParameter;
-	struct DC_EVPowerDeliveryParameterType EVPowerDelivery;
-
-	enum responseMessages resMsg;
-
-	struct PhysicalValueType float_type;
-
-	uint32_t outPayloadLength;
-
-
-	size_t i, j;
-
-
-	/* BINARY memory setup */
-	exi_bytes_t bytes = { MAX_BYTE_SIZE, byte_array, 0 };
-
-	/* STRING memory setup */
-	exi_string_ucs_t string = { MAX_STRING_SIZE, string_array, 0 };
-
-	/* setup offset for DoIP header (otherwise set
-	 * transportHeaderOffset=0 if no transfer protocol is used)*/
-	transportHeaderOffset = V2GTP_HEADER_LENGTH;
-
-
-
-	/*******************
-	 * Init V2G Client *
-	 *******************/
-
-	init_v2gServiceClient(&service,bytes,string,inStream,MAX_STREAM_SIZE, outStream, MAX_STREAM_SIZE, &outPayloadLength, transportHeaderOffset);
-
-
-	/*******************************
-	 * Setup data for sessionSetup *
-	 *******************************/
-
-	/* setup header information */
-	v2gHeader.SessionID.data[0] = 0; /* sessionID is always '0' at the beginning (the response message contains the valid sessionID)*/
-	v2gHeader.SessionID.data[1] = 0;
-	v2gHeader.SessionID.data[2] = 0;
-	v2gHeader.SessionID.data[3] = 0;
-	v2gHeader.SessionID.data[4] = 0;
-	v2gHeader.SessionID.data[5] = 0;
-	v2gHeader.SessionID.data[6] = 0;
-	v2gHeader.SessionID.data[7] = 0;
-	v2gHeader.SessionID.arraylen.data = 8; /* length of the byte session array is always 8*/
-
-	v2gHeader.isused.Notification=0; /* no notification */
-	v2gHeader.isused.Signature=0; /* no security */
-
-	/* setup sessionSetup parameter */
-	sessionSetup.EVCCID.data[0]=10;
-	sessionSetup.EVCCID.arraylen.data=1;
-
-	printf("EV side: prepare EVSE sessionSetup\n");
-
-	/************************
-	 * Prepare sessionSetup *
-	 ************************/
-
-	prepare_sessionSetup(&service,&v2gHeader, &sessionSetup,&resultSessionSetup);
-
-	printf("EV side: call EVSE sessionSetup\n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the sessionSetup response message */
-	if(resMsg==SESSIONSETUPRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup */
-		printf("EV: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\tResponseCode=%d\n",resultSessionSetup.ResponseCode);
-		printf("\tEVSEID=%d\n",	resultSessionSetup.EVSEID.data[0]);
-		printf("\tDateTimeNow=%lld\n",resultSessionSetup.DateTimeNow);
-
-	}
-
-
-	/*******************************************
-	 * Setup data for serviceDiscovery *
-	 *******************************************/
-
-	serviceDiscovery.isused.ServiceCategory=1;
-	serviceDiscovery.ServiceCategory = 	EVCharging_serviceCategoryType;
-	serviceDiscovery.isused.ServiceScope=0;
-
-
-	printf("\n\nEV side: prepare EVSE serviceDiscovery\n");
-
-	/****************************
-	 * Prepare serviceDiscovery *
-	 ****************************/
-
-	prepare_serviceDiscovery(&service,&v2gHeader, &serviceDiscovery,&resultServiceDiscovery);
-
-	printf("EV side: call EVSE serviceDiscovery \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the serviceDiscovery response message */
-	if(resMsg==SERVICEDISCOVERYRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup */
-		printf("\nEV side: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\t ResponseCode=%d\n",resultServiceDiscovery.ResponseCode);
-		printf("\t ChargeServiceID=%d\n",	resultServiceDiscovery.ChargeService.ServiceTag.ServiceID);
-		printf("\t ServiceName=");
-		printASCIIString(resultServiceDiscovery.ChargeService.ServiceTag.ServiceName.data,(uint32_t)resultServiceDiscovery.ChargeService.ServiceTag.ServiceName.arraylen.data );
-		printf("\t PaymentOption=%d\n",	resultServiceDiscovery.PaymentOptions.PaymentOption[0]);
-		printf("\t EnergyTransferType=%d\n",	resultServiceDiscovery.ChargeService.EnergyTransferType);
-	}
-
-
-	/*******************************************
-	 * Setup data for ServicePaymentSelection *
-	 *******************************************/
-
-	servicePayment.SelectedPaymentOption = ExternalPayment_paymentOptionType;
-	servicePayment.SelectedServiceList.SelectedService[0].ServiceID=resultServiceDiscovery.ChargeService.ServiceTag.ServiceID; /* charge server ID */
-	servicePayment.SelectedServiceList.SelectedService[0].isused.ParameterSetID=0; /* is not used */
-	servicePayment.SelectedServiceList.arraylen.SelectedService=1; /* only one service was selected */
-
-	printf("\n\nEV side: prepare EVSE servicePaymentSelection\n");
-
-	/**************************************
-	 * Prepare ServicePaymentSelection *
-	 **************************************/
-
-	if(prepare_servicePaymentSelection(&service,&v2gHeader, &servicePayment,&resultServicePayment))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-	printf("EV side: call EVSE ServicePaymentSelection \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the servicePaymentSelection response message */
-	if(resMsg==SERVICEPAYMENTSELECTIONRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup */
-		printf("EV: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\t ResponseCode=%d\n",resultServicePayment.ResponseCode);
-	}
-
-
-
-	/*******************************************
-	 * Setup data for ContractAuthentification *
-	 *******************************************/
-
-	contractAuthentication.isused.GenChallenge=0; /* no challenge needed here*/
-	contractAuthentication.isused.attr_Id=0; /* no signature needed here */
-
-
-	printf("\n\nEV side: prepare EVSE contractAuthentification\n");
-
-	/**************************************
-	 * Prepare ContractAuthentification   *
-	 **************************************/
-
-	if(prepare_contractAuthentication(&service,&v2gHeader, &contractAuthentication,&resultContractAuthentication))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-	printf("EV side: call EVSE ContractAuthentification \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the servicePaymentSelection response message */
-	if(resMsg==CONTRACTAUTHENTICATIONRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup */
-		printf("EV: received response message from EVSE\n");
-		printf("\tHeader SessionID=");
-		printBinaryArray(v2gHeader.SessionID.data,v2gHeader.SessionID.arraylen.data );
-		printf("\t ResponseCode=%d\n",resultContractAuthentication.ResponseCode);
-		if(resultContractAuthentication.EVSEProcessing==Finished_EVSEProcessingType)
-			printf("\t EVSEProcessing=Finished\n");
-
-
-	}
-
-
-	/*******************************************
-	 * Setup data for chargeParameterDiscovery *
-	 *******************************************/
-
-	/* setup EVStatus */
-
-	EVStatus.EVRESSSOC = 89;
-	EVStatus.EVReady = 1;
-	EVStatus.EVCabinConditioning = 1;
-	EVStatus.EVRESSConditioning = 1;
-	EVStatus.isused.EVCabinConditioning=1;
-	EVStatus.isused.EVRESSConditioning=1;
-	EVStatus.EVErrorCode = NO_ERROR_DC_EVErrorCodeType;
-
-	EVChargeParameter.DC_EVStatus = EVStatus;
-
-
-	float_type.Multiplier = 0;
-	float_type.Unit = A_unitSymbolType;
-	float_type.isused.Unit=1;
-	float_type.Value = 60;
-
-	EVChargeParameter.EVMaximumCurrentLimit = float_type;
-
-	float_type.Unit = W_unitSymbolType;
-	float_type.Value = 20000;
-
-	EVChargeParameter.EVMaximumPowerLimit = float_type;
-	EVChargeParameter.isused.EVMaximumPowerLimit = 1;
-
-	float_type.Unit = V_unitSymbolType;
-	float_type.Value = 420;
-
-	EVChargeParameter.EVMaximumVoltageLimit= float_type;
-
-	float_type.Unit = W_s_unitSymbolType;
-	float_type.Value = 15000;
-
-	EVChargeParameter.EVEnergyCapacity= float_type;
-	EVChargeParameter.isused.EVEnergyCapacity = 1;
-
-	float_type.Unit = W_s_unitSymbolType;
-	float_type.Value = 5000;
-
-	EVChargeParameter.EVEnergyRequest= float_type;
-	EVChargeParameter.isused.EVEnergyRequest = 1;
-
-	EVChargeParameter.FullSOC=99;
-	EVChargeParameter.isused.FullSOC = 1;
-
-	EVChargeParameter.BulkSOC=80;
-	EVChargeParameter.isused.BulkSOC = 1;
-
-	powerDiscovery.EVRequestedEnergyTransferType = DC_combo_core_EVRequestedEnergyTransferType;
-
-	powerDiscovery.DC_EVChargeParameter = &EVChargeParameter;
-	powerDiscovery.isused.DC_EVChargeParameter = 1; /* we use here DC based charging parameters */
-	powerDiscovery.isused.AC_EVChargeParameter = 0;
-
-	resultPowerDiscovery.DC_EVSEChargeParameter = &evseChargeParameter; /* we expect DC-based parameters from the evse*/
-
-	printf("\n\nEV side: prepare EVSE chargeParameterDiscovery\n");
-
-	/************************************
-	 * Prepare chargeParameterDiscovery *
-	 ************************************/
-
-	if(prepare_chargeParameterDiscovery(&service,&v2gHeader, &powerDiscovery,&resultPowerDiscovery))
-	{
-		printErrorMessage(&service);
-		return 0;
-	}
-
-	printf("EV side: call EVSE chargeParameterDiscovery \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the chargeParameterDiscovery response message */
-	if(resMsg==CHARGEPARAMETERDISCOVERYRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("\nEV side: received response message from EVSE\n");
-		printf("\t\t Header SessionID=%d\n",v2gHeader.SessionID.data[0]);
-		printf("\tResponseCode=%d\n",resultPowerDiscovery.ResponseCode);
-		if(resultPowerDiscovery.EVSEProcessing==Finished_EVSEProcessingType)
-			printf("\tEVSEProcessing=Finished\n");
-		printDCEVSEStatus(&(resultPowerDiscovery.DC_EVSEChargeParameter->DC_EVSEStatus));
-		printf("\tEVSEMaximumCurrentLimit=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEMaximumCurrentLimit.Value);
-		printf("\tEVSEMaximumPowerLimit=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEMaximumPowerLimit.Value);
-		printf("\tEVSEMaximumVoltageLimit=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEMaximumVoltageLimit.Value);
-		printf("\tEVSEMinimumCurrentLimit=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEMinimumCurrentLimit.Value);
-
-		printf("\tEVSEMinimumVoltageLimit=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEMinimumVoltageLimit.Value);
-		printf("\tEVSECurrentRegulationTolerance=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSECurrentRegulationTolerance.Value);
-		printf("\tEVSEPeakCurrentRipple=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEPeakCurrentRipple.Value);
-		printf("\tEVSEEnergyToBeDelivered=%d\n",resultPowerDiscovery.DC_EVSEChargeParameter->EVSEEnergyToBeDelivered.Value);
-
-		/* show PMax schedule, if there one provided  */
-			printf("\tSAScheduleList: \n");
-
-			for(i=0; i< resultPowerDiscovery.SAScheduleList.arraylen.SAScheduleTuple;i++)
-			{
-				printf("\t\t Tuple#%d: \n",(i+1));
-				printf("\t\t SAScheduleTupleID=%d: \n", resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].SAScheduleTupleID);
-				printf("\t\t PMaxScheduleID=%d: \n",resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].PMaxSchedule.PMaxScheduleID);
-
-				for(j=0; j< resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].PMaxSchedule.arraylen.PMaxScheduleEntry;j++)
-				{
-					printf("\t\t\t Entry#%d: \n",(j+1));
-					printf("\t\t\t\t PMax=%d \n",resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].PMaxSchedule.PMaxScheduleEntry[j].PMax);
-					printf("\t\t\t\t Start=%d \n",resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].PMaxSchedule.PMaxScheduleEntry[j].RelativeTimeInterval.start);
-					if(resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].PMaxSchedule.PMaxScheduleEntry[j].RelativeTimeInterval.isused.duration)
-						printf("\t\t\t\t Duration=%d \n",resultPowerDiscovery.SAScheduleList.SAScheduleTuple[i].PMaxSchedule.PMaxScheduleEntry[j].RelativeTimeInterval.duration);
-				}
-			}
-
-	}
-
-
-
-
-	/*****************************
-	 * Setup data for cableCheck *
-	 *****************************/
-
-	/* setup EVStatus */
-	cableCheck.DC_EVStatus =EVStatus;
-
-
-	printf("\n\nEV side: prepare EVSE cableCheck\n");
-
-	/**********************
-	 * Prepare cableCheck *
-	 **********************/
-
-	if(prepare_cableCheck(&service,&v2gHeader,&cableCheck,&resultCableCheck))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE cableCheck \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the cableCheck response message */
-	if(resMsg==CABLECHECKRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		printf("\t\t Header SessionID=%d\n",v2gHeader.SessionID.data[0]);
-		printf("\tResponseCode=%d\n",resultCableCheck.ResponseCode);
-		if(resultCableCheck.EVSEProcessing==Ongoing_EVSEProcessingType)
-			printf("\tEVSEProcessing=Ongoing\n");
-
-		printDCEVSEStatus(&(resultCableCheck.DC_EVSEStatus));
-	}
-
-
-	/*****************************
-	 * Setup data for preCharge  *
-	 *****************************/
-
-	/* setup EVStatus */
-	preCharge.DC_EVStatus =EVStatus;
-
-	float_type.Unit = V_unitSymbolType;
-	float_type.Value = 100;
-	preCharge.EVTargetCurrent = float_type;
-
-	float_type.Unit = V_unitSymbolType;
-	float_type.Value = 200;
-	preCharge.EVTargetVoltage = float_type;
-
-	printf("\n\nEV side: prepare EVSE preCharge\n");
-
-	/**********************
-	 * Prepare preCharge  *
-	 **********************/
-
-	if(prepare_preCharge(&service,&v2gHeader,&preCharge,&resultPreCharge))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE preCharge \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the preCharge response message */
-	if(resMsg==PRECHARGERES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultPreCharge.ResponseCode);
-		printDCEVSEStatus(&resultPreCharge.DC_EVSEStatus);
-		printf("\tEVSEPresentVoltage=%d\n",resultPreCharge.EVSEPresentVoltage.Value);
-	}
-
-
-
-	/*********************************
-	 * Setup data for powerDelivery *
-	 *********************************/
-
-	powerDelivery.ReadyToChargeState = 1;
-
-	EVPowerDelivery.DC_EVStatus = EVStatus;
-	EVPowerDelivery.BulkChargingComplete = 1;
-	EVPowerDelivery.isused.BulkChargingComplete = 1;
-	EVPowerDelivery.ChargingComplete = 0;
-
-	powerDelivery.DC_EVPowerDeliveryParameter = &EVPowerDelivery;
-	powerDelivery.isused.DC_EVPowerDeliveryParameter = 1; /* DC parameters are send */
-
-
-	/* we are using a charging profile */
-	powerDelivery.isused.ChargingProfile=1;
-	powerDelivery.ChargingProfile.SAScheduleTupleID = resultPowerDiscovery.SAScheduleList.SAScheduleTuple[0].SAScheduleTupleID;
-
-	/* set up 3 entries */
-	powerDelivery.ChargingProfile.ProfileEntry[0].ChargingProfileEntryMaxPower=0;
-	powerDelivery.ChargingProfile.ProfileEntry[0].ChargingProfileEntryStart=0;
-	powerDelivery.ChargingProfile.ProfileEntry[1].ChargingProfileEntryMaxPower=20000;
-	powerDelivery.ChargingProfile.ProfileEntry[1].ChargingProfileEntryStart=300; /* 5min */
-	powerDelivery.ChargingProfile.ProfileEntry[2].ChargingProfileEntryMaxPower=0;
-	powerDelivery.ChargingProfile.ProfileEntry[2].ChargingProfileEntryStart=1200; /* 20min */
-	powerDelivery.ChargingProfile.arraylen.ProfileEntry=3;
-
-
-
-	resultPowerDelivery.DC_EVSEStatus = &evseStatus; /* we expect the DC-based EVSE status */
-
-	printf("\n\nEV side: prepare EVSE powerDelivery\n");
-
-
-	/**************************
-	 * Prepare powerDelivery  *
-	 **************************/
-
-	if(prepare_powerDelivery(&service,&v2gHeader,&powerDelivery,&resultPowerDelivery))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE powerDelivery \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the powerDelivery response message */
-	if(resMsg==POWERDELIVERYRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("\nEV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultPreCharge.ResponseCode);
-		printDCEVSEStatus(&resultPreCharge.DC_EVSEStatus);
-	}
-
-
-
-
-
-	/*********************************
-	 * Setup data for currentDemand *
-	 *********************************/
-
-	currentDemand.DC_EVStatus = EVStatus;
-
-	float_type.Unit = A_unitSymbolType;
-	float_type.Value = 4;
-
-	currentDemand.EVTargetCurrent = float_type;
-
-	float_type.Unit = V_unitSymbolType;
-	float_type.Value = 420;
-
-	currentDemand.EVMaximumVoltageLimit = float_type;
-	currentDemand.isused.EVMaximumVoltageLimit = 1;
-
-	float_type.Unit = W_unitSymbolType;
-	float_type.Value = 20000;
-
-	currentDemand.EVMaximumPowerLimit = float_type;
-	currentDemand.isused.EVMaximumPowerLimit = 1;
-
-	float_type.Unit = A_unitSymbolType;
-	float_type.Value = 60;
-
-	currentDemand.EVMaximumCurrentLimit = float_type;
-	currentDemand.isused.EVMaximumCurrentLimit = 1;
-
-	currentDemand.BulkChargingComplete = 0;
-	currentDemand.isused.BulkChargingComplete = 1;
-
-	currentDemand.ChargingComplete = 0;
-
-	float_type.Unit = s_unitSymbolType;
-	float_type.Value = 300; /* 5 min*/
-
-	currentDemand.RemainingTimeToFullSoC = float_type;
-	currentDemand.isused.RemainingTimeToFullSoC = 1;
-
-	float_type.Unit = s_unitSymbolType;
-	float_type.Value = 120; /* 3 min */
-
-	currentDemand.RemainingTimeToBulkSoC = float_type;
-	currentDemand.isused.RemainingTimeToBulkSoC = 1;
-
-
-	float_type.Unit = V_unitSymbolType;
-	float_type.Value = 360;
-
-	currentDemand.EVTargetVoltage = float_type;
-
-
-	printf("\n\nEV side: prepare EVSE currentDemand\n");
-
-	/**************************
-	 * Prepare currentDemand  *
-	 **************************/
-
-	if(prepare_currentDemand(&service,&v2gHeader,&currentDemand,&resultCurrentDemand))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE currentDemand \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the sessionSetup response message */
-	if(resMsg==CURRENTDEMANDRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("\nEV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultCurrentDemand.ResponseCode);
-		printDCEVSEStatus(&resultCurrentDemand.DC_EVSEStatus);
-		printf("\t EVSEPresentVoltage=%d\n",resultCurrentDemand.EVSEPresentVoltage.Value);
-		printf("\t EVSEPresentCurrent=%d\n",resultCurrentDemand.EVSEPresentCurrent.Value);
-		printf("\t EVSECurrentLimitAchieved=%d\n",resultCurrentDemand.EVSECurrentLimitAchieved);
-		printf("\t EVSEVoltageLimitAchieved=%d\n",resultCurrentDemand.EVSEVoltageLimitAchieved);
-
-		printf("\t EVSEPowerLimitAchieved=%d\n",resultCurrentDemand.EVSEPowerLimitAchieved);
-		printf("\t EVSEMaximumVoltageLimit=%d\n",resultCurrentDemand.EVSEMaximumVoltageLimit.Value);
-		printf("\t EVSEMaximumCurrentLimit=%d\n",resultCurrentDemand.EVSEMaximumCurrentLimit.Value);
-		printf("\t EVSEMaximumPowerLimit=%d\n",resultCurrentDemand.EVSEMaximumPowerLimit.Value);
-	}
-
-
-
-
-
-
-	/***********************************
-	 * Setup data for weldingDetection *
-	 ***********************************/
-
-	weldingDetection.DC_EVStatus =EVStatus;
-
-
-
-	printf("\n\nEV side: prepare EVSE weldingDetection\n");
-
-	/**************************
-	 * Prepare weldingDetection  *
-	 **************************/
-
-	if(prepare_weldingDetection(&service,&v2gHeader,&weldingDetection,&resultWeldingDetection))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE weldingDetection \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the sessionSetup response message */
-	if(resMsg==WELDINGDETECTIONRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultWeldingDetection.ResponseCode);
-		printDCEVSEStatus(&resultWeldingDetection.DC_EVSEStatus);
-		printf("\tEVSEPresentVoltage=%d\n",resultWeldingDetection.EVSEPresentVoltage.Value);
-	}
-
-
-
-
-
-	/***********************************
-	 * Setup data for stopSession *
-	 ***********************************/
-
-	printf("\n\nEV side: prepare EVSE stopSession\n");
-
-	/************************
-	 * Prepare stopSession  *
-	 ************************/
-
-	if(prepare_sessionStop(&service,&v2gHeader,&resultSessionStop))
-	{
-		printErrorMessage(&service);
-		return 0; /* stop here */
-	}
-
-	printf("EV side: call EVSE stopSession \n");
-
-	/* Use here your sending / receiving mechanism to / from the EVSE. The following serviceDataTransmitter method
-	 * is only an exemplary implementation which also shows how to add the V2GTP header information to
-	 * the output stream.
-	 * */
-
-	serviceDataTransmitter(outStream, outPayloadLength, inStream);
-
-	/* this methods deserialize the response EXI stream and determines the kind of
-	 * the response message */
-	if(determineResponseMesssage(&service, &resMsg))
-	{
-		printErrorMessage(&service);
-	}
-
-	/* check, if this is the sessionSetup response message */
-	if(resMsg==SESSIONSTOPRES)
-	{
-		/* show result of the answer message of EVSE sessionSetup*/
-		printf("EV side: received response message from EVSE\n");
-		/* show result of the answer message of EVSE powerDiscovery*/
-		printf("\tResponseCode=%d\n",resultSessionStop.ResponseCode);
-	}
-
-	return 0;
-
-}
-
-
-
-int main_service()
-{
-
-
-	printf("+++ Start application handshake protocol example +++\n\n");
-
-	appHandshake();
-
-	printf("+++ Terminate application handshake protocol example +++\n\n");
-
-	printf("\n\nPlease press enter for AC charging!\n");
-	fflush(stdout);
-	getchar();
-	printf("+++ Start V2G client / service example for AC charging +++\n\n");
-
-	ac_charging();
-
-	printf("\n+++Terminate V2G Client / Service example for AC charging +++\n");
-	printf("Please press enter for DC charging!\n");
-	fflush(stdout);
-	getchar();
-
-	printf("+++ Start V2G client / service example for DC charging +++\n\n");
-
-	dc_charging();
-
-	printf("\n+++Terminate V2G client / service example for DC charging +++");
-
-	return 0;
-}
-
-static void printACEVSEStatus(struct AC_EVSEStatusType* status)
-{
-	printf("\tEVSEStatus:\n");
-	printf("\t\tPowerSwitchClosed=%d\n",status->PowerSwitchClosed);
-	printf("\t\tRCD=%d\n",status->RCD);
-	printf("\t\tEVSENotification=%d\n",status->EVSENotification);
-	printf("\t\tNotificationMaxDelay=%d\n",status->NotificationMaxDelay);
-}
-
-static void printDCEVSEStatus(struct DC_EVSEStatusType* status)
-{
-	if(status->isused.EVSEIsolationStatus)
-		printf("\tEVSEStatus:\n\t\tEVSEIsolationStatus=%d\n",status->EVSEIsolationStatus);
-
-	printf("\t\tEVSEStatusCode=%d\n",status->EVSEStatusCode);
-
-	if(status->EVSENotification==None_EVSENotificationType)
-		printf("\t\tEVSENotification=None_EVSENotificationType\n");
-
-	printf("\t\tNotificationMaxDelay=%d\n",status->NotificationMaxDelay);
-
-}
-
-static void printErrorMessage(struct EXIService* service)
-{
-	if(service->errorCode==EXI_NON_VALID_MESSAGE)
-	{
-		printf("EV did not send a valid V2G message!\n");
-	}
-	else if(service->errorCode==EXI_SERIALIZATION_FAILED)
-	{
-		printf("Error: Could not serialize the response message\n");
-	}
-	else if(service->errorCode==EXI_DESERIALIZATION_FAILED)
-	{
-		printf("Error: Could not deserialize the response message\n");
-	}
-	else if(service->errorCode==EXI_VALUE_RANGE_FAILED)
-	{
-		printf("Error: Could not deserialize the response message because of VALUE_RANGE\n");
-	}
-	else if(service->errorCode==EXI_UNKNOWN_ERROR)
-	{
-		printf("Error: Could not deserialize the response message because of VALUE_RANGE\n");
-	}
-}
-
-static void printASCIIString(uint32_t* string, uint32_t len) {
-	unsigned int i;
-	for(i=0; i<len; i++) {
-		printf("%c",(char)string[i]);
-	}
-	printf("\n");
-}
-
-static void printBinaryArray(uint8_t* byte, uint32_t len) {
-	unsigned int i;
-	for(i=0; i<len; i++) {
-		printf("%d ",byte[i]);
-	}
-	printf("\n");
-}
-
-static int writeStringToEXIString(char* string, uint32_t* exiString)
-{
-
-	int pos=0;
-	while(string[pos]!='\0')
-	{
-		exiString[pos] = string[pos];
-		pos++;
-	}
-
-	return pos;
-}
-

+ 0 - 76
src/test/serviceClientDataTransmitter.c

@@ -1,76 +0,0 @@
-/*
- * Copyright (C) 2007-2012 Siemens AG
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*******************************************************************
- *
- * @author Sebastian.Kaebisch.EXT@siemens.com
- * @@version 0.7
- * @contact Joerg.Heuer@siemens.com
- *
- ********************************************************************/
-
-#include "v2g_serviceClientDataTransmitter.h"
-#include "evse_server.h"
-#include "v2gtp.h"
-
-
-
-void binaryToBits(uint8_t x)
-{
-	uint8_t cnt, mask = 1 << 7;
-
-	for(cnt=1;cnt<=8;++cnt)
-	{
-		printf("%c",((x & mask) == 0) ? '0' : '1');
-		x <<= 1;
-	}
-}
-
-/*
- * Send EXI stream (outStream) to EVSE and receive a response stream (inStream)*/
-int serviceDataTransmitter(uint8_t* outStream, uint32_t outStreamLength, uint8_t* inStream)
-{
-	/* send output stream to the underlying network to the EVSE and wait for response
-	 * --> here provide data to the V2G server directly*/
-
-	uint32_t inStreamLength = 0;
-	uint32_t payloadLength = 0;
-
-	printf("\nEXI request message size=%d bytes\n",outStreamLength);
-
-
-
-	/* setup v2gtp header information; outStreamLength==payloadLength*/
-	write_v2gtpHeader(outStream,&outStreamLength,V2GTP_EXI_TYPE);
-
-
-/*	uint8_t* outStream2 = {1,254,128,1,0,0,0,33,128,154,2,2,192,0,0,0,0,0,0,16,209,64,22,64,200,8,1,146,64,12,3,32,40,128,50,50,8,201,208,4,0};*/
-/*	uint8_t outStream2[] = {0x01, 0xFE, 0x80, 0x01, 0x00, 0x00, 0x00, 0x21, 0x80, 0x9A, 0x02, 0x02, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0xD1, 0x40, 0x16, 0x40, 0xC8, 0x08, 0x01, 0x92, 0x40, 0x0C, 0x03, 0x20, 0x28, 0x80, 0x32, 0x32, 0x08, 0xC9, 0xD0, 0x04, 0x00};
-	outStreamLength = 41;
-*/
-
-
-	/* send data to EVSE server (add v2g offset)*/
-	testV2GService(outStream, outStreamLength, inStream, &inStreamLength);
-
-	read_v2gtpHeader(inStream,inStreamLength, &payloadLength);
-
-	printf("\nEXI response message size=%d bytes\n",payloadLength);
-
-
-	return 0;
-}

برخی فایل ها در این مقایسه diff نمایش داده نمی شوند زیرا تعداد فایل ها بسیار زیاد است