From ab805782e6f56c46b0a254abf536ed15b11d9396 Mon Sep 17 00:00:00 2001 From: Dewald Bodenstein Date: Wed, 7 Feb 2024 16:19:37 +0200 Subject: [PATCH 1/4] Upgrade project to 2021.3.22f1 --- .vsconfig | 6 + Packages/manifest.json | 13 +- Packages/packages-lock.json | 338 +++++++++ ProjectSettings/MemorySettings.asset | 35 + ProjectSettings/PackageManagerSettings.asset | 36 + ProjectSettings/ProjectSettings.asset | 544 +++++++++----- ProjectSettings/ProjectVersion.txt | 4 +- ProjectSettings/VersionControlSettings.asset | 8 + ProjectSettings/boot.config | 0 UserSettings/EditorUserSettings.asset | 25 + UserSettings/Layouts/default-2021.dwlt | 746 +++++++++++++++++++ 11 files changed, 1580 insertions(+), 175 deletions(-) create mode 100644 .vsconfig create mode 100644 Packages/packages-lock.json create mode 100644 ProjectSettings/MemorySettings.asset create mode 100644 ProjectSettings/PackageManagerSettings.asset create mode 100644 ProjectSettings/VersionControlSettings.asset create mode 100644 ProjectSettings/boot.config create mode 100644 UserSettings/EditorUserSettings.asset create mode 100644 UserSettings/Layouts/default-2021.dwlt diff --git a/.vsconfig b/.vsconfig new file mode 100644 index 00000000..d70cd98b --- /dev/null +++ b/.vsconfig @@ -0,0 +1,6 @@ +{ + "version": "1.0", + "components": [ + "Microsoft.VisualStudio.Workload.ManagedGame" + ] +} diff --git a/Packages/manifest.json b/Packages/manifest.json index 39e66d1f..ffb3838a 100644 --- a/Packages/manifest.json +++ b/Packages/manifest.json @@ -1,11 +1,12 @@ { "dependencies": { - "com.unity.collab-proxy": "1.2.16", - "com.unity.ide.rider": "1.1.4", - "com.unity.ide.vscode": "1.1.4", - "com.unity.test-framework": "1.1.9", - "com.unity.textmeshpro": "2.0.1", - "com.unity.timeline": "1.2.10", + "com.unity.collab-proxy": "2.0.1", + "com.unity.ide.rider": "3.0.18", + "com.unity.ide.visualstudio": "2.0.17", + "com.unity.ide.vscode": "1.2.5", + "com.unity.test-framework": "1.1.31", + "com.unity.textmeshpro": "3.0.6", + "com.unity.timeline": "1.6.4", "com.unity.ugui": "1.0.0", "com.unity.modules.ai": "1.0.0", "com.unity.modules.androidjni": "1.0.0", diff --git a/Packages/packages-lock.json b/Packages/packages-lock.json new file mode 100644 index 00000000..d1ef6780 --- /dev/null +++ b/Packages/packages-lock.json @@ -0,0 +1,338 @@ +{ + "dependencies": { + "com.unity.collab-proxy": { + "version": "2.0.1", + "depth": 0, + "source": "registry", + "dependencies": {}, + "url": "https://packages.unity.com" + }, + "com.unity.ext.nunit": { + "version": "1.0.6", + "depth": 1, + "source": "registry", + "dependencies": {}, + "url": "https://packages.unity.com" + }, + "com.unity.ide.rider": { + "version": "3.0.18", + "depth": 0, + "source": "registry", + "dependencies": { + "com.unity.ext.nunit": "1.0.6" + }, + "url": "https://packages.unity.com" + }, + "com.unity.ide.visualstudio": { + "version": "2.0.17", + "depth": 0, + "source": "registry", + "dependencies": { + "com.unity.test-framework": "1.1.9" + }, + "url": "https://packages.unity.com" + }, + "com.unity.ide.vscode": { + "version": "1.2.5", + "depth": 0, + "source": "registry", + "dependencies": {}, + "url": "https://packages.unity.com" + }, + "com.unity.test-framework": { + "version": "1.1.31", + "depth": 0, + "source": "registry", + "dependencies": { + "com.unity.ext.nunit": "1.0.6", + "com.unity.modules.imgui": "1.0.0", + "com.unity.modules.jsonserialize": "1.0.0" + }, + "url": "https://packages.unity.com" + }, + "com.unity.textmeshpro": { + "version": "3.0.6", + "depth": 0, + "source": "registry", + "dependencies": { + "com.unity.ugui": "1.0.0" + }, + "url": "https://packages.unity.com" + }, + "com.unity.timeline": { + "version": "1.6.4", + "depth": 0, + "source": "registry", + "dependencies": { + "com.unity.modules.director": "1.0.0", + "com.unity.modules.animation": "1.0.0", + "com.unity.modules.audio": "1.0.0", + "com.unity.modules.particlesystem": "1.0.0" + }, + "url": "https://packages.unity.com" + }, + "com.unity.ugui": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.ui": "1.0.0", + "com.unity.modules.imgui": "1.0.0" + } + }, + "com.unity.modules.ai": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.androidjni": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.animation": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.assetbundle": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.audio": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.cloth": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.physics": "1.0.0" + } + }, + "com.unity.modules.director": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.audio": "1.0.0", + "com.unity.modules.animation": "1.0.0" + } + }, + "com.unity.modules.imageconversion": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.imgui": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.jsonserialize": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.particlesystem": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.physics": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.physics2d": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.screencapture": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.imageconversion": "1.0.0" + } + }, + "com.unity.modules.subsystems": { + "version": "1.0.0", + "depth": 1, + "source": "builtin", + "dependencies": { + "com.unity.modules.jsonserialize": "1.0.0" + } + }, + "com.unity.modules.terrain": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.terrainphysics": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.physics": "1.0.0", + "com.unity.modules.terrain": "1.0.0" + } + }, + "com.unity.modules.tilemap": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.physics2d": "1.0.0" + } + }, + "com.unity.modules.ui": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.uielements": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.ui": "1.0.0", + "com.unity.modules.imgui": "1.0.0", + "com.unity.modules.jsonserialize": "1.0.0", + "com.unity.modules.uielementsnative": "1.0.0" + } + }, + "com.unity.modules.uielementsnative": { + "version": "1.0.0", + "depth": 1, + "source": "builtin", + "dependencies": { + "com.unity.modules.ui": "1.0.0", + "com.unity.modules.imgui": "1.0.0", + "com.unity.modules.jsonserialize": "1.0.0" + } + }, + "com.unity.modules.umbra": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.unityanalytics": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.unitywebrequest": "1.0.0", + "com.unity.modules.jsonserialize": "1.0.0" + } + }, + "com.unity.modules.unitywebrequest": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.unitywebrequestassetbundle": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.assetbundle": "1.0.0", + "com.unity.modules.unitywebrequest": "1.0.0" + } + }, + "com.unity.modules.unitywebrequestaudio": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.unitywebrequest": "1.0.0", + "com.unity.modules.audio": "1.0.0" + } + }, + "com.unity.modules.unitywebrequesttexture": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.unitywebrequest": "1.0.0", + "com.unity.modules.imageconversion": "1.0.0" + } + }, + "com.unity.modules.unitywebrequestwww": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.unitywebrequest": "1.0.0", + "com.unity.modules.unitywebrequestassetbundle": "1.0.0", + "com.unity.modules.unitywebrequestaudio": "1.0.0", + "com.unity.modules.audio": "1.0.0", + "com.unity.modules.assetbundle": "1.0.0", + "com.unity.modules.imageconversion": "1.0.0" + } + }, + "com.unity.modules.vehicles": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.physics": "1.0.0" + } + }, + "com.unity.modules.video": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.audio": "1.0.0", + "com.unity.modules.ui": "1.0.0", + "com.unity.modules.unitywebrequest": "1.0.0" + } + }, + "com.unity.modules.vr": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.jsonserialize": "1.0.0", + "com.unity.modules.physics": "1.0.0", + "com.unity.modules.xr": "1.0.0" + } + }, + "com.unity.modules.wind": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": {} + }, + "com.unity.modules.xr": { + "version": "1.0.0", + "depth": 0, + "source": "builtin", + "dependencies": { + "com.unity.modules.physics": "1.0.0", + "com.unity.modules.jsonserialize": "1.0.0", + "com.unity.modules.subsystems": "1.0.0" + } + } + } +} diff --git a/ProjectSettings/MemorySettings.asset b/ProjectSettings/MemorySettings.asset new file mode 100644 index 00000000..5b5facec --- /dev/null +++ b/ProjectSettings/MemorySettings.asset @@ -0,0 +1,35 @@ +%YAML 1.1 +%TAG !u! tag:unity3d.com,2011: +--- !u!387306366 &1 +MemorySettings: + m_ObjectHideFlags: 0 + m_EditorMemorySettings: + m_MainAllocatorBlockSize: -1 + m_ThreadAllocatorBlockSize: -1 + m_MainGfxBlockSize: -1 + m_ThreadGfxBlockSize: -1 + m_CacheBlockSize: -1 + m_TypetreeBlockSize: -1 + m_ProfilerBlockSize: -1 + m_ProfilerEditorBlockSize: -1 + m_BucketAllocatorGranularity: -1 + m_BucketAllocatorBucketsCount: -1 + m_BucketAllocatorBlockSize: -1 + m_BucketAllocatorBlockCount: -1 + m_ProfilerBucketAllocatorGranularity: -1 + m_ProfilerBucketAllocatorBucketsCount: -1 + m_ProfilerBucketAllocatorBlockSize: -1 + m_ProfilerBucketAllocatorBlockCount: -1 + m_TempAllocatorSizeMain: -1 + m_JobTempAllocatorBlockSize: -1 + m_BackgroundJobTempAllocatorBlockSize: -1 + m_JobTempAllocatorReducedBlockSize: -1 + m_TempAllocatorSizeGIBakingWorker: -1 + m_TempAllocatorSizeNavMeshWorker: -1 + m_TempAllocatorSizeAudioWorker: -1 + m_TempAllocatorSizeCloudWorker: -1 + m_TempAllocatorSizeGfx: -1 + m_TempAllocatorSizeJobWorker: -1 + m_TempAllocatorSizeBackgroundWorker: -1 + m_TempAllocatorSizePreloadManager: -1 + m_PlatformMemorySettings: {} diff --git a/ProjectSettings/PackageManagerSettings.asset b/ProjectSettings/PackageManagerSettings.asset new file mode 100644 index 00000000..137ce765 --- /dev/null +++ b/ProjectSettings/PackageManagerSettings.asset @@ -0,0 +1,36 @@ +%YAML 1.1 +%TAG !u! tag:unity3d.com,2011: +--- !u!114 &1 +MonoBehaviour: + m_ObjectHideFlags: 61 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 13964, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_EnablePreReleasePackages: 0 + m_EnablePackageDependencies: 0 + m_AdvancedSettingsExpanded: 1 + m_ScopedRegistriesSettingsExpanded: 1 + m_SeeAllPackageVersions: 0 + oneTimeWarningShown: 0 + m_Registries: + - m_Id: main + m_Name: + m_Url: https://packages.unity.com + m_Scopes: [] + m_IsDefault: 1 + m_Capabilities: 7 + m_ConfigSource: 0 + m_UserSelectedRegistryName: + m_UserAddingNewScopedRegistry: 0 + m_RegistryInfoDraft: + m_Modified: 0 + m_ErrorMessage: + m_UserModificationsInstanceId: -856 + m_OriginalInstanceId: -858 + m_LoadAssets: 0 diff --git a/ProjectSettings/ProjectSettings.asset b/ProjectSettings/ProjectSettings.asset index 524c6642..ac0d6ada 100644 --- a/ProjectSettings/ProjectSettings.asset +++ b/ProjectSettings/ProjectSettings.asset @@ -3,9 +3,11 @@ --- !u!129 &1 PlayerSettings: m_ObjectHideFlags: 0 - serializedVersion: 11 + serializedVersion: 24 productGUID: dd117d38d745844fc8480950f2558604 AndroidProfiler: 0 + AndroidFilterTouchesWhenObscured: 0 + AndroidEnableSustainedPerformanceMode: 0 defaultScreenOrientation: 4 targetDevice: 2 useOnDemandResources: 0 @@ -14,7 +16,7 @@ PlayerSettings: productName: tangramunity defaultCursor: {fileID: 0} cursorHotspot: {x: 0, y: 0} - m_SplashScreenBackgroundColor: {r: 0.13333334, g: 0.17254902, b: 0.21176471, a: 1} + m_SplashScreenBackgroundColor: {r: 0.12156863, g: 0.12156863, b: 0.1254902, a: 1} m_ShowUnitySplashScreen: 1 m_ShowUnitySplashLogo: 1 m_SplashScreenOverlayOpacity: 1 @@ -38,8 +40,6 @@ PlayerSettings: width: 1 height: 1 m_SplashScreenLogos: [] - m_SplashScreenBackgroundLandscape: {fileID: 0} - m_SplashScreenBackgroundPortrait: {fileID: 0} m_VirtualRealitySplashScreen: {fileID: 0} m_HolographicTrackingLossScreen: {fileID: 0} defaultScreenWidth: 1024 @@ -49,13 +49,12 @@ PlayerSettings: m_StereoRenderingPath: 0 m_ActiveColorSpace: 0 m_MTRendering: 1 - m_MobileMTRendering: 0 + mipStripping: 0 + numberOfMipsStripped: 0 m_StackTraceTypes: 010000000100000001000000010000000100000001000000 iosShowActivityIndicatorOnLoading: -1 androidShowActivityIndicatorOnLoading: -1 - tizenShowActivityIndicatorOnLoading: -1 - iosAppInBackgroundBehavior: 0 - displayResolutionDialog: 1 + iosUseCustomAppBackgroundBehavior: 0 iosAllowHTTPDownload: 1 allowedAutorotateToPortrait: 1 allowedAutorotateToPortraitUpsideDown: 1 @@ -63,22 +62,36 @@ PlayerSettings: allowedAutorotateToLandscapeLeft: 1 useOSAutorotation: 1 use32BitDisplayBuffer: 1 + preserveFramebufferAlpha: 0 disableDepthAndStencilBuffers: 0 - defaultIsFullScreen: 1 + androidStartInFullscreen: 1 + androidRenderOutsideSafeArea: 1 + androidUseSwappy: 0 + androidBlitType: 0 + androidResizableWindow: 0 + androidDefaultWindowWidth: 1920 + androidDefaultWindowHeight: 1080 + androidMinimumWindowWidth: 400 + androidMinimumWindowHeight: 300 + androidFullscreenMode: 1 defaultIsNativeResolution: 1 + macRetinaSupport: 1 runInBackground: 0 captureSingleScreen: 0 muteOtherAudioSources: 0 Prepare IOS For Recording: 0 + Force IOS Speakers When Recording: 0 + deferSystemGesturesMode: 0 + hideHomeButton: 0 submitAnalytics: 1 usePlayerLog: 1 bakeCollisionMeshes: 0 forceSingleInstance: 0 + useFlipModelSwapchain: 1 resizableWindow: 0 useMacAppStoreValidation: 0 macAppStoreCategory: public.app-category.games gpuSkinning: 0 - graphicsJobs: 0 xboxPIXTextureCapture: 0 xboxEnableAvatar: 0 xboxEnableKinect: 0 @@ -86,33 +99,35 @@ PlayerSettings: xboxEnableFitness: 0 visibleInBackground: 0 allowFullscreenSwitch: 1 - graphicsJobMode: 0 - macFullscreenMode: 2 - d3d9FullscreenMode: 1 - d3d11FullscreenMode: 1 + fullscreenMode: 1 xboxSpeechDB: 0 xboxEnableHeadOrientation: 0 xboxEnableGuest: 0 xboxEnablePIXSampling: 0 - n3dsDisableStereoscopicView: 0 - n3dsEnableSharedListOpt: 1 - n3dsEnableVSync: 0 - ignoreAlphaClear: 0 + metalFramebufferOnly: 0 xboxOneResolution: 0 + xboxOneSResolution: 0 + xboxOneXResolution: 3 xboxOneMonoLoggingLevel: 0 xboxOneLoggingLevel: 1 - videoMemoryForVertexBuffers: 0 - psp2PowerMode: 0 - psp2AcquireBGM: 1 - wiiUTVResolution: 0 - wiiUGamePadMSAA: 1 - wiiUSupportsNunchuk: 0 - wiiUSupportsClassicController: 0 - wiiUSupportsBalanceBoard: 0 - wiiUSupportsMotionPlus: 0 - wiiUSupportsProController: 0 - wiiUAllowScreenCapture: 1 - wiiUControllerCount: 0 + xboxOneDisableEsram: 0 + xboxOneEnableTypeOptimization: 0 + xboxOnePresentImmediateThreshold: 0 + switchQueueCommandMemory: 1048576 + switchQueueControlMemory: 16384 + switchQueueComputeMemory: 262144 + switchNVNShaderPoolsGranularity: 33554432 + switchNVNDefaultPoolsGranularity: 16777216 + switchNVNOtherPoolsGranularity: 16777216 + switchNVNMaxPublicTextureIDCount: 0 + switchNVNMaxPublicSamplerIDCount: 0 + stadiaPresentMode: 0 + stadiaTargetFramerate: 0 + vulkanNumSwapchainBuffers: 3 + vulkanEnableSetSRGBWrite: 0 + vulkanEnablePreTransform: 0 + vulkanEnableLateAcquireNextImage: 0 + vulkanEnableCommandBufferRecycling: 1 m_SupportedAspectRatios: 4:3: 1 5:4: 1 @@ -122,30 +137,36 @@ PlayerSettings: bundleVersion: 1.0 preloadedAssets: [] metroInputSource: 0 + wsaTransparentSwapchain: 0 m_HolographicPauseOnTrackingLoss: 1 xboxOneDisableKinectGpuReservation: 0 xboxOneEnable7thCore: 0 vrSettings: - cardboard: - depthFormat: 0 - enableTransitionView: 0 - daydream: - depthFormat: 0 - useSustainedPerformanceMode: 0 - hololens: - depthFormat: 1 - protectGraphicsMemory: 0 + enable360StereoCapture: 0 + isWsaHolographicRemotingEnabled: 0 + enableFrameTimingStats: 0 + enableOpenGLProfilerGPURecorders: 1 useHDRDisplay: 0 + D3DHDRBitDepth: 0 + m_ColorGamuts: 00000000 + targetPixelDensity: 30 + resolutionScalingMode: 0 + resetResolutionOnWindowResize: 0 + androidSupportedAspectRatio: 1 + androidMaxAspectRatio: 2.1 applicationIdentifier: Android: com.mapzen.tangramunity Standalone: unity.DefaultCompany.mapzen Tizen: com.Company.ProductName - iOS: com.Company.ProductName + iPhone: com.Company.ProductName tvOS: com.Company.ProductName buildNumber: - iOS: 0 + Standalone: 0 + iPhone: 0 + tvOS: 0 + overrideDefaultApplicationIdentifier: 1 AndroidBundleVersionCode: 1 - AndroidMinSdkVersion: 16 + AndroidMinSdkVersion: 22 AndroidTargetSdkVersion: 0 AndroidPreferredInstallLocation: 1 aotOptions: @@ -158,35 +179,28 @@ PlayerSettings: APKExpansionFiles: 0 keepLoadedShadersAlive: 0 StripUnusedMeshComponents: 0 - VertexChannelCompressionMask: - serializedVersion: 2 - m_Bits: 238 + VertexChannelCompressionMask: 214 iPhoneSdkVersion: 988 - iOSTargetOSVersionString: + iOSTargetOSVersionString: 12.0 tvOSSdkVersion: 0 tvOSRequireExtendedGameController: 0 - tvOSTargetOSVersionString: + tvOSTargetOSVersionString: 12.0 uIPrerenderedIcon: 0 uIRequiresPersistentWiFi: 0 uIRequiresFullScreen: 1 uIStatusBarHidden: 1 uIExitOnSuspend: 0 uIStatusBarStyle: 0 - iPhoneSplashScreen: {fileID: 0} - iPhoneHighResSplashScreen: {fileID: 0} - iPhoneTallHighResSplashScreen: {fileID: 0} - iPhone47inSplashScreen: {fileID: 0} - iPhone55inPortraitSplashScreen: {fileID: 0} - iPhone55inLandscapeSplashScreen: {fileID: 0} - iPadPortraitSplashScreen: {fileID: 0} - iPadHighResPortraitSplashScreen: {fileID: 0} - iPadLandscapeSplashScreen: {fileID: 0} - iPadHighResLandscapeSplashScreen: {fileID: 0} appleTVSplashScreen: {fileID: 0} + appleTVSplashScreen2x: {fileID: 0} tvOSSmallIconLayers: [] + tvOSSmallIconLayers2x: [] tvOSLargeIconLayers: [] + tvOSLargeIconLayers2x: [] tvOSTopShelfImageLayers: [] + tvOSTopShelfImageLayers2x: [] tvOSTopShelfImageWideLayers: [] + tvOSTopShelfImageWideLayers2x: [] iOSLaunchScreenType: 0 iOSLaunchScreenPortrait: {fileID: 0} iOSLaunchScreenLandscape: {fileID: 0} @@ -204,58 +218,232 @@ PlayerSettings: iOSLaunchScreeniPadFillPct: 100 iOSLaunchScreeniPadSize: 100 iOSLaunchScreeniPadCustomXibPath: + iOSLaunchScreenCustomStoryboardPath: + iOSLaunchScreeniPadCustomStoryboardPath: iOSDeviceRequirements: [] iOSURLSchemes: [] + macOSURLSchemes: [] iOSBackgroundModes: 0 iOSMetalForceHardShadows: 0 metalEditorSupport: 0 metalAPIValidation: 1 iOSRenderExtraFrameOnPause: 1 + iosCopyPluginsCodeInsteadOfSymlink: 0 appleDeveloperTeamID: iOSManualSigningProvisioningProfileID: tvOSManualSigningProvisioningProfileID: + iOSManualSigningProvisioningProfileType: 0 + tvOSManualSigningProvisioningProfileType: 0 appleEnableAutomaticSigning: 0 - AndroidTargetDevice: 0 + iOSRequireARKit: 0 + iOSAutomaticallyDetectAndAddCapabilities: 1 + appleEnableProMotion: 0 + shaderPrecisionModel: 0 + clonedFromGUID: 00000000000000000000000000000000 + templatePackageId: + templateDefaultScene: + useCustomMainManifest: 0 + useCustomLauncherManifest: 0 + useCustomMainGradleTemplate: 0 + useCustomLauncherGradleManifest: 0 + useCustomBaseGradleTemplate: 0 + useCustomGradlePropertiesTemplate: 0 + useCustomProguardFile: 0 + AndroidTargetArchitectures: 1 + AndroidTargetDevices: 0 AndroidSplashScreenScale: 0 androidSplashScreen: {fileID: 0} - AndroidKeystoreName: + AndroidKeystoreName: '{inproject}: ' AndroidKeyaliasName: + AndroidBuildApkPerCpuArchitecture: 0 AndroidTVCompatibility: 1 AndroidIsGame: 1 + AndroidEnableTango: 0 androidEnableBanner: 1 + androidUseLowAccuracyLocation: 0 + androidUseCustomKeystore: 0 m_AndroidBanners: - width: 320 height: 180 banner: {fileID: 0} androidGamepadSupportLevel: 0 - resolutionDialogBanner: {fileID: 0} + chromeosInputEmulation: 1 + AndroidMinifyWithR8: 0 + AndroidMinifyRelease: 0 + AndroidMinifyDebug: 0 + AndroidValidateAppBundleSize: 1 + AndroidAppBundleSizeToValidate: 150 m_BuildTargetIcons: [] + m_BuildTargetPlatformIcons: + - m_BuildTarget: Android + m_Icons: + - m_Textures: [] + m_Width: 432 + m_Height: 432 + m_Kind: 2 + m_SubKind: + - m_Textures: [] + m_Width: 324 + m_Height: 324 + m_Kind: 2 + m_SubKind: + - m_Textures: [] + m_Width: 216 + m_Height: 216 + m_Kind: 2 + m_SubKind: + - m_Textures: [] + m_Width: 162 + m_Height: 162 + m_Kind: 2 + m_SubKind: + - m_Textures: [] + m_Width: 108 + m_Height: 108 + m_Kind: 2 + m_SubKind: + - m_Textures: [] + m_Width: 81 + m_Height: 81 + m_Kind: 2 + m_SubKind: + - m_Textures: [] + m_Width: 192 + m_Height: 192 + m_Kind: 1 + m_SubKind: + - m_Textures: [] + m_Width: 144 + m_Height: 144 + m_Kind: 1 + m_SubKind: + - m_Textures: [] + m_Width: 96 + m_Height: 96 + m_Kind: 1 + m_SubKind: + - m_Textures: [] + m_Width: 72 + m_Height: 72 + m_Kind: 1 + m_SubKind: + - m_Textures: [] + m_Width: 48 + m_Height: 48 + m_Kind: 1 + m_SubKind: + - m_Textures: [] + m_Width: 36 + m_Height: 36 + m_Kind: 1 + m_SubKind: + - m_Textures: [] + m_Width: 192 + m_Height: 192 + m_Kind: 0 + m_SubKind: + - m_Textures: [] + m_Width: 144 + m_Height: 144 + m_Kind: 0 + m_SubKind: + - m_Textures: [] + m_Width: 96 + m_Height: 96 + m_Kind: 0 + m_SubKind: + - m_Textures: [] + m_Width: 72 + m_Height: 72 + m_Kind: 0 + m_SubKind: + - m_Textures: [] + m_Width: 48 + m_Height: 48 + m_Kind: 0 + m_SubKind: + - m_Textures: [] + m_Width: 36 + m_Height: 36 + m_Kind: 0 + m_SubKind: m_BuildTargetBatching: [] - m_BuildTargetGraphicsAPIs: [] + m_BuildTargetShaderSettings: [] + m_BuildTargetGraphicsJobs: + - m_BuildTarget: WindowsStandaloneSupport + m_GraphicsJobs: 0 + - m_BuildTarget: MacStandaloneSupport + m_GraphicsJobs: 0 + - m_BuildTarget: LinuxStandaloneSupport + m_GraphicsJobs: 0 + - m_BuildTarget: AndroidPlayer + m_GraphicsJobs: 0 + - m_BuildTarget: iOSSupport + m_GraphicsJobs: 0 + - m_BuildTarget: PS4Player + m_GraphicsJobs: 0 + - m_BuildTarget: PS5Player + m_GraphicsJobs: 0 + - m_BuildTarget: XboxOnePlayer + m_GraphicsJobs: 0 + - m_BuildTarget: GameCoreXboxOneSupport + m_GraphicsJobs: 0 + - m_BuildTarget: GameCoreScarlettSupport + m_GraphicsJobs: 0 + - m_BuildTarget: Switch + m_GraphicsJobs: 0 + - m_BuildTarget: WebGLSupport + m_GraphicsJobs: 0 + - m_BuildTarget: MetroSupport + m_GraphicsJobs: 0 + - m_BuildTarget: AppleTVSupport + m_GraphicsJobs: 0 + - m_BuildTarget: BJMSupport + m_GraphicsJobs: 0 + - m_BuildTarget: LuminSupport + m_GraphicsJobs: 0 + - m_BuildTarget: CloudRendering + m_GraphicsJobs: 0 + - m_BuildTarget: EmbeddedLinux + m_GraphicsJobs: 0 + m_BuildTargetGraphicsJobMode: + - m_BuildTarget: PS4Player + m_GraphicsJobMode: 0 + - m_BuildTarget: XboxOnePlayer + m_GraphicsJobMode: 0 + m_BuildTargetGraphicsAPIs: + - m_BuildTarget: iOSSupport + m_APIs: 10000000 + m_Automatic: 1 + - m_BuildTarget: AndroidPlayer + m_APIs: 0b00000008000000 + m_Automatic: 0 m_BuildTargetVRSettings: [] + m_DefaultShaderChunkSizeInMB: 16 + m_DefaultShaderChunkCount: 0 openGLRequireES31: 0 openGLRequireES31AEP: 0 - webPlayerTemplate: APPLICATION:Default + openGLRequireES32: 0 m_TemplateCustomTags: {} - wiiUTitleID: 0005000011000000 - wiiUGroupID: 00010000 - wiiUCommonSaveSize: 4096 - wiiUAccountSaveSize: 2048 - wiiUOlvAccessKey: 0 - wiiUTinCode: 0 - wiiUJoinGameId: 0 - wiiUJoinGameModeMask: 0000000000000000 - wiiUCommonBossSize: 0 - wiiUAccountBossSize: 0 - wiiUAddOnUniqueIDs: [] - wiiUMainThreadStackSize: 3072 - wiiULoaderThreadStackSize: 1024 - wiiUSystemHeapSize: 128 - wiiUTVStartupScreen: {fileID: 0} - wiiUGamePadStartupScreen: {fileID: 0} - wiiUDrcBufferDisabled: 0 - wiiUProfilerLibPath: + mobileMTRendering: + iPhone: 1 + tvOS: 1 + m_BuildTargetGroupLightmapEncodingQuality: + - m_BuildTarget: Standalone + m_EncodingQuality: 1 + - m_BuildTarget: XboxOne + m_EncodingQuality: 1 + - m_BuildTarget: PS4 + m_EncodingQuality: 1 + - m_BuildTarget: GameCoreScarlett + m_EncodingQuality: 1 + - m_BuildTarget: GameCoreXboxOne + m_EncodingQuality: 1 + m_BuildTargetGroupLightmapSettings: [] + m_BuildTargetNormalMapEncoding: [] + m_BuildTargetDefaultTextureCompressionFormat: [] playModeTestRunnerEnabled: 0 + runPlayModeTestAsEditModeTest: 0 actionOnDotNetUnhandledException: 1 enableInternalProfiler: 0 logObjCUncaughtExceptions: 1 @@ -263,11 +451,16 @@ PlayerSettings: cameraUsageDescription: locationUsageDescription: microphoneUsageDescription: + bluetoothUsageDescription: + switchNMETAOverride: switchNetLibKey: switchSocketMemoryPoolSize: 6144 switchSocketAllocatorPoolSize: 128 switchSocketConcurrencyLimit: 14 + switchScreenResolutionBehavior: 2 switchUseCPUProfiler: 0 + switchUseGOLDLinker: 0 + switchLTOSetting: 0 switchApplicationID: 0x0005000C10000001 switchNSODependencies: switchTitleNames_0: @@ -285,6 +478,7 @@ PlayerSettings: switchTitleNames_12: switchTitleNames_13: switchTitleNames_14: + switchTitleNames_15: switchPublisherNames_0: switchPublisherNames_1: switchPublisherNames_2: @@ -300,6 +494,7 @@ PlayerSettings: switchPublisherNames_12: switchPublisherNames_13: switchPublisherNames_14: + switchPublisherNames_15: switchIcons_0: {fileID: 0} switchIcons_1: {fileID: 0} switchIcons_2: {fileID: 0} @@ -315,6 +510,7 @@ PlayerSettings: switchIcons_12: {fileID: 0} switchIcons_13: {fileID: 0} switchIcons_14: {fileID: 0} + switchIcons_15: {fileID: 0} switchSmallIcons_0: {fileID: 0} switchSmallIcons_1: {fileID: 0} switchSmallIcons_2: {fileID: 0} @@ -330,6 +526,7 @@ PlayerSettings: switchSmallIcons_12: {fileID: 0} switchSmallIcons_13: {fileID: 0} switchSmallIcons_14: {fileID: 0} + switchSmallIcons_15: {fileID: 0} switchManualHTML: switchAccessibleURLs: switchLegalInformation: @@ -339,13 +536,12 @@ PlayerSettings: switchReleaseVersion: 0 switchDisplayVersion: 1.0.0 switchStartupUserAccount: 0 - switchTouchScreenUsage: 0 switchSupportedLanguagesMask: 0 switchLogoType: 0 switchApplicationErrorCodeCategory: switchUserAccountSaveDataSize: 0 switchUserAccountSaveDataJournalSize: 0 - switchAttribute: 0 + switchApplicationAttribute: 0 switchCardSpecSize: 4 switchCardSpecClock: 25 switchRatingsMask: 0 @@ -361,6 +557,7 @@ PlayerSettings: switchRatingsInt_9: 0 switchRatingsInt_10: 0 switchRatingsInt_11: 0 + switchRatingsInt_12: 0 switchLocalCommunicationIds_0: 0x0005000C10000001 switchLocalCommunicationIds_1: switchLocalCommunicationIds_2: @@ -371,7 +568,33 @@ PlayerSettings: switchLocalCommunicationIds_7: switchParentalControl: 0 switchAllowsScreenshot: 1 + switchAllowsVideoCapturing: 1 + switchAllowsRuntimeAddOnContentInstall: 0 switchDataLossConfirmation: 0 + switchUserAccountLockEnabled: 0 + switchSystemResourceMemory: 16777216 + switchSupportedNpadStyles: 22 + switchNativeFsCacheSize: 32 + switchIsHoldTypeHorizontal: 0 + switchSupportedNpadCount: 8 + switchEnableTouchScreen: 1 + switchSocketConfigEnabled: 0 + switchTcpInitialSendBufferSize: 32 + switchTcpInitialReceiveBufferSize: 64 + switchTcpAutoSendBufferSizeMax: 256 + switchTcpAutoReceiveBufferSizeMax: 256 + switchUdpSendBufferSize: 9 + switchUdpReceiveBufferSize: 42 + switchSocketBufferEfficiency: 4 + switchSocketInitializeEnabled: 1 + switchNetworkInterfaceManagerInitializeEnabled: 1 + switchPlayerConnectionEnabled: 1 + switchUseNewStyleFilepaths: 0 + switchUseLegacyFmodPriorities: 1 + switchUseMicroSleepForYield: 1 + switchEnableRamDiskSupport: 0 + switchMicroSleepForYieldTime: 25 + switchRamDiskSpaceSize: 12 ps4NPAgeRating: 12 ps4NPTitleSecret: ps4NPTrophyPackPath: @@ -390,12 +613,15 @@ PlayerSettings: ps4PronunciationSIGPath: ps4BackgroundImagePath: ps4StartupImagePath: + ps4StartupImagesFolder: + ps4IconImagesFolder: ps4SaveDataImagePath: ps4SdkOverride: ps4BGMPath: ps4ShareFilePath: ps4ShareOverlayImagePath: ps4PrivacyGuardImagePath: + ps4ExtraSceSysFile: ps4NPtitleDatPath: ps4RemotePlayKeyAssignment: -1 ps4RemotePlayKeyMappingDir: @@ -408,17 +634,20 @@ PlayerSettings: ps4DownloadDataSize: 0 ps4GarlicHeapSize: 2048 ps4ProGarlicHeapSize: 2560 + playerPrefsMaxSize: 32768 ps4Passcode: 5PN2qmWqBlQ9wQj99nsQzldVI5ZuGXbE - ps4UseDebugIl2cppLibs: 0 ps4pnSessions: 1 ps4pnPresence: 1 ps4pnFriends: 1 ps4pnGameCustomData: 1 playerPrefsSupport: 0 + enableApplicationExit: 0 + resetTempFolder: 1 restrictedAudioUsageRights: 0 ps4UseResolutionFallback: 0 ps4ReprojectionSupport: 0 ps4UseAudio3dBackend: 0 + ps4UseLowGarlicFragmentationMode: 1 ps4SocialScreenEnabled: 0 ps4ScriptOptimizationLevel: 3 ps4Audio3dVirtualSpeakerCount: 14 @@ -435,59 +664,16 @@ PlayerSettings: ps4disableAutoHideSplash: 0 ps4videoRecordingFeaturesUsed: 0 ps4contentSearchFeaturesUsed: 0 + ps4CompatibilityPS5: 0 + ps4AllowPS5Detection: 0 + ps4GPU800MHz: 1 ps4attribEyeToEyeDistanceSettingVR: 0 ps4IncludedModules: [] + ps4attribVROutputEnabled: 0 monoEnv: - psp2Splashimage: {fileID: 0} - psp2NPTrophyPackPath: - psp2NPSupportGBMorGJP: 0 - psp2NPAgeRating: 12 - psp2NPTitleDatPath: - psp2NPCommsID: - psp2NPCommunicationsID: - psp2NPCommsPassphrase: - psp2NPCommsSig: - psp2ParamSfxPath: - psp2ManualPath: - psp2LiveAreaGatePath: - psp2LiveAreaBackroundPath: - psp2LiveAreaPath: - psp2LiveAreaTrialPath: - psp2PatchChangeInfoPath: - psp2PatchOriginalPackage: - psp2PackagePassword: WRK5RhRXdCdG5nG5azdNMK66MuCV6GXi - psp2KeystoneFile: - psp2MemoryExpansionMode: 0 - psp2DRMType: 0 - psp2StorageType: 0 - psp2MediaCapacity: 0 - psp2DLCConfigPath: - psp2ThumbnailPath: - psp2BackgroundPath: - psp2SoundPath: - psp2TrophyCommId: - psp2TrophyPackagePath: - psp2PackagedResourcesPath: - psp2SaveDataQuota: 10240 - psp2ParentalLevel: 1 - psp2ShortTitle: Not Set - psp2ContentID: IV0000-ABCD12345_00-0123456789ABCDEF - psp2Category: 0 - psp2MasterVersion: 01.00 - psp2AppVersion: 01.00 - psp2TVBootMode: 0 - psp2EnterButtonAssignment: 2 - psp2TVDisableEmu: 0 - psp2AllowTwitterDialog: 1 - psp2Upgradable: 0 - psp2HealthWarning: 0 - psp2UseLibLocation: 0 - psp2InfoBarOnStartup: 0 - psp2InfoBarColor: 0 - psp2UseDebugIl2cppLibs: 0 - psmSplashimage: {fileID: 0} splashScreenBackgroundSourceLandscape: {fileID: 0} splashScreenBackgroundSourcePortrait: {fileID: 0} + blurSplashScreenBackground: 1 spritePackerPolicy: webGLMemorySize: 256 webGLExceptionSupport: 1 @@ -499,13 +685,42 @@ PlayerSettings: webGLTemplate: APPLICATION:Default webGLAnalyzeBuildSize: 0 webGLUseEmbeddedResources: 0 - webGLUseWasm: 0 webGLCompressionFormat: 1 + webGLWasmArithmeticExceptions: 0 + webGLLinkerTarget: 1 + webGLThreadsSupport: 0 + webGLDecompressionFallback: 0 + webGLPowerPreference: 2 scriptingDefineSymbols: {} + additionalCompilerArguments: {} platformArchitecture: {} scriptingBackend: {} + il2cppCompilerConfiguration: {} + managedStrippingLevel: + EmbeddedLinux: 1 + GameCoreScarlett: 1 + GameCoreXboxOne: 1 + Lumin: 1 + Nintendo Switch: 1 + PS4: 1 + PS5: 1 + Stadia: 1 + WebGL: 1 + Windows Store Apps: 1 + XboxOne: 1 + iPhone: 1 + tvOS: 1 incrementalIl2cppBuild: {} + suppressCommonWarnings: 1 + allowUnsafeCode: 0 + useDeterministicCompilation: 1 + enableRoslynAnalyzers: 1 + selectedPlatform: 0 additionalIl2CppArgs: + scriptingRuntimeVersion: 1 + gcIncremental: 1 + assemblyVersionValidation: 1 + gcWBarrierValidation: 0 apiCompatibilityLevelPerPlatform: {} m_RenderingPath: 1 m_MobileRenderingPath: 1 @@ -519,11 +734,12 @@ PlayerSettings: metroApplicationDescription: mapzen wsaImages: {} metroTileShortName: - metroCommandLineArgsFile: metroTileShowName: 0 metroMediumTileShowName: 0 metroLargeTileShowName: 0 metroWideTileShowName: 0 + metroSupportStreamingInstall: 0 + metroLastRequiredScene: 0 metroDefaultTileSize: 1 metroTileForegroundText: 2 metroTileBackgroundColor: {r: 0.13333334, g: 0.17254902, b: 0.21568628, a: 0} @@ -531,35 +747,11 @@ PlayerSettings: a: 1} metroSplashScreenUseBackgroundColor: 0 platformCapabilities: {} + metroTargetDeviceFamilies: {} metroFTAName: metroFTAFileTypes: [] metroProtocolName: - metroCompilationOverrides: 1 - tizenProductDescription: - tizenProductURL: - tizenSigningProfileName: - tizenGPSPermissions: 0 - tizenMicrophonePermissions: 0 - tizenDeploymentTarget: - tizenDeploymentTargetType: -1 - tizenMinOSVersion: 1 - n3dsUseExtSaveData: 0 - n3dsCompressStaticMem: 1 - n3dsExtSaveDataNumber: 0x12345 - n3dsStackSize: 131072 - n3dsTargetPlatform: 2 - n3dsRegion: 7 - n3dsMediaSize: 0 - n3dsLogoStyle: 3 - n3dsTitle: GameName - n3dsProductCode: - n3dsApplicationId: 0xFF3FF - stvDeviceAddress: - stvProductDescription: - stvProductAuthor: - stvProductAuthorEmail: - stvProductLink: - stvProductCategory: 0 + vcxProjDefaultLanguage: XboxOneProductId: XboxOneUpdateKey: XboxOneSandboxId: @@ -569,6 +761,7 @@ PlayerSettings: XboxOneGameOsOverridePath: XboxOnePackagingOverridePath: XboxOneAppManifestOverridePath: + XboxOneVersion: 1.0.0.0 XboxOnePackageEncryption: 0 XboxOnePackageUpdateGranularity: 2 XboxOneDescription: @@ -577,26 +770,43 @@ PlayerSettings: XboxOneCapability: [] XboxOneGameRating: {} XboxOneIsContentPackage: 0 + XboxOneEnhancedXboxCompatibilityMode: 0 XboxOneEnableGPUVariability: 0 XboxOneSockets: {} XboxOneSplashScreen: {fileID: 0} XboxOneAllowedProductIds: [] XboxOnePersistentLocalStorageSize: 0 - xboxOneScriptCompiler: 0 - vrEditorSettings: - daydream: - daydreamIconForeground: {fileID: 0} - daydreamIconBackground: {fileID: 0} + XboxOneXTitleMemory: 8 + XboxOneOverrideIdentityName: + XboxOneOverrideIdentityPublisher: + vrEditorSettings: {} cloudServicesEnabled: Build: 0 Collab: 0 ErrorHub: 0 Hub: 0 UNet: 1 - facebookSdkVersion: 7.9.1 - apiCompatibilityLevel: 2 + luminIcon: + m_Name: + m_ModelFolderPath: + m_PortalFolderPath: + luminCert: + m_CertPath: + m_SignPackage: 1 + luminIsChannelApp: 0 + luminVersion: + m_VersionCode: 1 + m_VersionName: + apiCompatibilityLevel: 6 + activeInputHandler: 0 + windowsGamepadBackendHint: 0 cloudProjectId: ffc4f172-52c7-47d7-b4e6-0179e0a5c24d + framebufferDepthMemorylessMode: 0 + qualitySettingsNames: [] projectName: mapzen organizationId: karim-naaji-gmail-com cloudEnabled: 0 - enableNewInputSystem: 0 + legacyClampBlendShapeWeights: 1 + playerDataPath: + forceSRGBBlit: 1 + virtualTexturingSupportEnabled: 0 diff --git a/ProjectSettings/ProjectVersion.txt b/ProjectSettings/ProjectVersion.txt index 798259ba..f8251a7a 100644 --- a/ProjectSettings/ProjectVersion.txt +++ b/ProjectSettings/ProjectVersion.txt @@ -1,2 +1,2 @@ -m_EditorVersion: 2019.3.0f6 -m_EditorVersionWithRevision: 2019.3.0f6 (27ab2135bccf) +m_EditorVersion: 2021.3.22f1 +m_EditorVersionWithRevision: 2021.3.22f1 (b6c551784ba3) diff --git a/ProjectSettings/VersionControlSettings.asset b/ProjectSettings/VersionControlSettings.asset new file mode 100644 index 00000000..dca28814 --- /dev/null +++ b/ProjectSettings/VersionControlSettings.asset @@ -0,0 +1,8 @@ +%YAML 1.1 +%TAG !u! tag:unity3d.com,2011: +--- !u!890905787 &1 +VersionControlSettings: + m_ObjectHideFlags: 0 + m_Mode: Visible Meta Files + m_CollabEditorSettings: + inProgressEnabled: 1 diff --git a/ProjectSettings/boot.config b/ProjectSettings/boot.config new file mode 100644 index 00000000..e69de29b diff --git a/UserSettings/EditorUserSettings.asset b/UserSettings/EditorUserSettings.asset new file mode 100644 index 00000000..d1ecbdff --- /dev/null +++ b/UserSettings/EditorUserSettings.asset @@ -0,0 +1,25 @@ +%YAML 1.1 +%TAG !u! tag:unity3d.com,2011: +--- !u!162 &1 +EditorUserSettings: + m_ObjectHideFlags: 0 + serializedVersion: 4 + m_ConfigSettings: + vcSharedLogLevel: + value: 0d5e400f0650 + flags: 0 + m_VCAutomaticAdd: 1 + m_VCDebugCom: 0 + m_VCDebugCmd: 0 + m_VCDebugOut: 0 + m_SemanticMergeMode: 2 + m_DesiredImportWorkerCount: 1 + m_StandbyImportWorkerCount: 1 + m_IdleImportWorkerShutdownDelay: 60000 + m_VCShowFailedCheckout: 1 + m_VCOverwriteFailedCheckoutAssets: 1 + m_VCProjectOverlayIcons: 1 + m_VCHierarchyOverlayIcons: 1 + m_VCOtherOverlayIcons: 1 + m_VCAllowAsyncUpdate: 1 + m_ArtifactGarbageCollection: 1 diff --git a/UserSettings/Layouts/default-2021.dwlt b/UserSettings/Layouts/default-2021.dwlt new file mode 100644 index 00000000..6a0b8ede --- /dev/null +++ b/UserSettings/Layouts/default-2021.dwlt @@ -0,0 +1,746 @@ +%YAML 1.1 +%TAG !u! tag:unity3d.com,2011: +--- !u!114 &1 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12004, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_PixelRect: + serializedVersion: 2 + x: 2249 + y: 302.5 + width: 1206 + height: 715 + m_ShowMode: 4 + m_Title: + m_RootView: {fileID: 6} + m_MinSize: {x: 875, y: 300} + m_MaxSize: {x: 10000, y: 10000} + m_Maximized: 0 +--- !u!114 &2 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12010, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: + - {fileID: 9} + - {fileID: 3} + m_Position: + serializedVersion: 2 + x: 0 + y: 30 + width: 1206 + height: 665 + m_MinSize: {x: 679, y: 492} + m_MaxSize: {x: 14002, y: 14042} + vertical: 0 + controlID: 119 +--- !u!114 &3 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: [] + m_Position: + serializedVersion: 2 + x: 921 + y: 0 + width: 285 + height: 665 + m_MinSize: {x: 276, y: 71} + m_MaxSize: {x: 4001, y: 4021} + m_ActualView: {fileID: 13} + m_Panes: + - {fileID: 13} + m_Selected: 0 + m_LastSelected: 0 +--- !u!114 &4 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: [] + m_Position: + serializedVersion: 2 + x: 0 + y: 0 + width: 228 + height: 394 + m_MinSize: {x: 201, y: 221} + m_MaxSize: {x: 4001, y: 4021} + m_ActualView: {fileID: 14} + m_Panes: + - {fileID: 14} + m_Selected: 0 + m_LastSelected: 0 +--- !u!114 &5 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} + m_Name: ProjectBrowser + m_EditorClassIdentifier: + m_Children: [] + m_Position: + serializedVersion: 2 + x: 0 + y: 394 + width: 921 + height: 271 + m_MinSize: {x: 231, y: 271} + m_MaxSize: {x: 10001, y: 10021} + m_ActualView: {fileID: 12} + m_Panes: + - {fileID: 12} + - {fileID: 17} + m_Selected: 0 + m_LastSelected: 1 +--- !u!114 &6 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12008, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: + - {fileID: 7} + - {fileID: 2} + - {fileID: 8} + m_Position: + serializedVersion: 2 + x: 0 + y: 0 + width: 1206 + height: 715 + m_MinSize: {x: 875, y: 300} + m_MaxSize: {x: 10000, y: 10000} +--- !u!114 &7 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12011, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: [] + m_Position: + serializedVersion: 2 + x: 0 + y: 0 + width: 1206 + height: 30 + m_MinSize: {x: 0, y: 0} + m_MaxSize: {x: 0, y: 0} + m_LoadedToolbars: [] + m_MainToolbar: {fileID: 18} + m_LastLoadedLayoutName: Default +--- !u!114 &8 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12042, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: [] + m_Position: + serializedVersion: 2 + x: 0 + y: 695 + width: 1206 + height: 20 + m_MinSize: {x: 0, y: 0} + m_MaxSize: {x: 0, y: 0} +--- !u!114 &9 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12010, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: + - {fileID: 10} + - {fileID: 5} + m_Position: + serializedVersion: 2 + x: 0 + y: 0 + width: 921 + height: 665 + m_MinSize: {x: 403, y: 492} + m_MaxSize: {x: 10001, y: 14042} + vertical: 1 + controlID: 92 +--- !u!114 &10 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12010, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: + - {fileID: 4} + - {fileID: 11} + m_Position: + serializedVersion: 2 + x: 0 + y: 0 + width: 921 + height: 394 + m_MinSize: {x: 403, y: 221} + m_MaxSize: {x: 8003, y: 4021} + vertical: 0 + controlID: 93 +--- !u!114 &11 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_Children: [] + m_Position: + serializedVersion: 2 + x: 228 + y: 0 + width: 693 + height: 394 + m_MinSize: {x: 202, y: 221} + m_MaxSize: {x: 4002, y: 4021} + m_ActualView: {fileID: 15} + m_Panes: + - {fileID: 15} + - {fileID: 16} + m_Selected: 0 + m_LastSelected: 1 +--- !u!114 &12 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12014, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_MinSize: {x: 230, y: 250} + m_MaxSize: {x: 10000, y: 10000} + m_TitleContent: + m_Text: Project + m_Image: {fileID: -5467254957812901981, guid: 0000000000000000d000000000000000, type: 0} + m_Tooltip: + m_Pos: + serializedVersion: 2 + x: 2249 + y: 726.5 + width: 920 + height: 250 + m_ViewDataDictionary: {fileID: 0} + m_SearchFilter: + m_NameFilter: + m_ClassNames: [] + m_AssetLabels: [] + m_AssetBundleNames: [] + m_VersionControlStates: [] + m_SoftLockControlStates: [] + m_ReferencingInstanceIDs: + m_SceneHandles: + m_ShowAllHits: 0 + m_SkipHidden: 0 + m_SearchArea: 1 + m_Folders: + - Assets + m_Globs: [] + m_ViewMode: 1 + m_StartGridSize: 64 + m_LastFolders: + - Assets + m_LastFoldersGridSize: -1 + m_LastProjectPath: U:\layout + m_LockTracker: + m_IsLocked: 0 + m_FolderTreeState: + scrollPos: {x: 0, y: 0} + m_SelectedIDs: f4350000 + m_LastClickedID: 13812 + m_ExpandedIDs: 00000000f435000000ca9a3b + m_RenameOverlay: + m_UserAcceptedRename: 0 + m_Name: + m_OriginalName: + m_EditFieldRect: + serializedVersion: 2 + x: 0 + y: 0 + width: 0 + height: 0 + m_UserData: 0 + m_IsWaitingForDelay: 0 + m_IsRenaming: 0 + m_OriginalEventType: 11 + m_IsRenamingFilename: 1 + m_ClientGUIView: {fileID: 0} + m_SearchString: + m_CreateAssetUtility: + m_EndAction: {fileID: 0} + m_InstanceID: 0 + m_Path: + m_Icon: {fileID: 0} + m_ResourceFile: + m_AssetTreeState: + scrollPos: {x: 0, y: 0} + m_SelectedIDs: + m_LastClickedID: 0 + m_ExpandedIDs: 00000000f4350000 + m_RenameOverlay: + m_UserAcceptedRename: 0 + m_Name: + m_OriginalName: + m_EditFieldRect: + serializedVersion: 2 + x: 0 + y: 0 + width: 0 + height: 0 + m_UserData: 0 + m_IsWaitingForDelay: 0 + m_IsRenaming: 0 + m_OriginalEventType: 11 + m_IsRenamingFilename: 1 + m_ClientGUIView: {fileID: 0} + m_SearchString: + m_CreateAssetUtility: + m_EndAction: {fileID: 0} + m_InstanceID: 0 + m_Path: + m_Icon: {fileID: 0} + m_ResourceFile: + m_ListAreaState: + m_SelectedInstanceIDs: + m_LastClickedInstanceID: 0 + m_HadKeyboardFocusLastEvent: 0 + m_ExpandedInstanceIDs: c6230000 + m_RenameOverlay: + m_UserAcceptedRename: 0 + m_Name: + m_OriginalName: + m_EditFieldRect: + serializedVersion: 2 + x: 0 + y: 0 + width: 0 + height: 0 + m_UserData: 0 + m_IsWaitingForDelay: 0 + m_IsRenaming: 0 + m_OriginalEventType: 11 + m_IsRenamingFilename: 1 + m_ClientGUIView: {fileID: 0} + m_CreateAssetUtility: + m_EndAction: {fileID: 0} + m_InstanceID: 0 + m_Path: + m_Icon: {fileID: 0} + m_ResourceFile: + m_NewAssetIndexInList: -1 + m_ScrollPosition: {x: 0, y: 0} + m_GridSize: 64 + m_SkipHiddenPackages: 0 + m_DirectoriesAreaWidth: 207 +--- !u!114 &13 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12019, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_MinSize: {x: 275, y: 50} + m_MaxSize: {x: 4000, y: 4000} + m_TitleContent: + m_Text: Inspector + m_Image: {fileID: -2667387946076563598, guid: 0000000000000000d000000000000000, type: 0} + m_Tooltip: + m_Pos: + serializedVersion: 2 + x: 3170 + y: 332.5 + width: 284 + height: 644 + m_ViewDataDictionary: {fileID: 0} + m_ObjectsLockedBeforeSerialization: [] + m_InstanceIDsLockedBeforeSerialization: + m_PreviewResizer: + m_CachedPref: 160 + m_ControlHash: -371814159 + m_PrefName: Preview_InspectorPreview + m_LastInspectedObjectInstanceID: -1 + m_LastVerticalScrollValue: 0 + m_AssetGUID: + m_InstanceID: 0 + m_LockTracker: + m_IsLocked: 0 + m_PreviewWindow: {fileID: 0} +--- !u!114 &14 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12061, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_MinSize: {x: 200, y: 200} + m_MaxSize: {x: 4000, y: 4000} + m_TitleContent: + m_Text: Hierarchy + m_Image: {fileID: 7966133145522015247, guid: 0000000000000000d000000000000000, type: 0} + m_Tooltip: + m_Pos: + serializedVersion: 2 + x: 2249 + y: 332.5 + width: 227 + height: 373 + m_ViewDataDictionary: {fileID: 0} + m_SceneHierarchy: + m_TreeViewState: + scrollPos: {x: 0, y: 0} + m_SelectedIDs: + m_LastClickedID: 0 + m_ExpandedIDs: 42fbffff + m_RenameOverlay: + m_UserAcceptedRename: 0 + m_Name: + m_OriginalName: + m_EditFieldRect: + serializedVersion: 2 + x: 0 + y: 0 + width: 0 + height: 0 + m_UserData: 0 + m_IsWaitingForDelay: 0 + m_IsRenaming: 0 + m_OriginalEventType: 11 + m_IsRenamingFilename: 0 + m_ClientGUIView: {fileID: 0} + m_SearchString: + m_ExpandedScenes: [] + m_CurrenRootInstanceID: 0 + m_LockTracker: + m_IsLocked: 0 + m_CurrentSortingName: TransformSorting + m_WindowGUID: 4c969a2b90040154d917609493e03593 +--- !u!114 &15 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12013, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_MinSize: {x: 200, y: 200} + m_MaxSize: {x: 4000, y: 4000} + m_TitleContent: + m_Text: Scene + m_Image: {fileID: 2593428753322112591, guid: 0000000000000000d000000000000000, type: 0} + m_Tooltip: + m_Pos: + serializedVersion: 2 + x: 2477 + y: 332.5 + width: 691 + height: 373 + m_ViewDataDictionary: {fileID: 0} + m_ShowContextualTools: 0 + m_WindowGUID: cc27987af1a868c49b0894db9c0f5429 + m_Gizmos: 1 + m_OverrideSceneCullingMask: 6917529027641081856 + m_SceneIsLit: 1 + m_SceneLighting: 1 + m_2DMode: 0 + m_isRotationLocked: 0 + m_PlayAudio: 0 + m_AudioPlay: 0 + m_Position: + m_Target: {x: 0, y: 0, z: 0} + speed: 2 + m_Value: {x: 0, y: 0, z: 0} + m_RenderMode: 0 + m_CameraMode: + drawMode: 0 + name: Shaded + section: Shading Mode + m_ValidateTrueMetals: 0 + m_DoValidateTrueMetals: 0 + m_ExposureSliderValue: 0 + m_SceneViewState: + showFog: 1 + showMaterialUpdate: 0 + showSkybox: 1 + showFlares: 1 + showImageEffects: 1 + showParticleSystems: 1 + showVisualEffectGraphs: 1 + m_Grid: + xGrid: + m_Fade: + m_Target: 0 + speed: 2 + m_Value: 0 + m_Color: {r: 0.5, g: 0.5, b: 0.5, a: 0.4} + m_Pivot: {x: 0, y: 0, z: 0} + m_Size: {x: 0, y: 0} + yGrid: + m_Fade: + m_Target: 1 + speed: 2 + m_Value: 1 + m_Color: {r: 0.5, g: 0.5, b: 0.5, a: 0.4} + m_Pivot: {x: 0, y: 0, z: 0} + m_Size: {x: 1, y: 1} + zGrid: + m_Fade: + m_Target: 0 + speed: 2 + m_Value: 0 + m_Color: {r: 0.5, g: 0.5, b: 0.5, a: 0.4} + m_Pivot: {x: 0, y: 0, z: 0} + m_Size: {x: 0, y: 0} + m_ShowGrid: 1 + m_GridAxis: 1 + m_gridOpacity: 0.5 + m_Rotation: + m_Target: {x: -0.08717229, y: 0.89959055, z: -0.21045254, w: -0.3726226} + speed: 2 + m_Value: {x: -0.08717229, y: 0.89959055, z: -0.21045254, w: -0.3726226} + m_Size: + m_Target: 10 + speed: 2 + m_Value: 10 + m_Ortho: + m_Target: 0 + speed: 2 + m_Value: 0 + m_CameraSettings: + m_Speed: 1 + m_SpeedNormalized: 0.5 + m_SpeedMin: 0.001 + m_SpeedMax: 2 + m_EasingEnabled: 1 + m_EasingDuration: 0.4 + m_AccelerationEnabled: 1 + m_FieldOfView: 90 + m_NearClip: 0.03 + m_FarClip: 10000 + m_DynamicClip: 1 + m_OcclusionCulling: 0 + m_LastSceneViewRotation: {x: 0, y: 0, z: 0, w: 0} + m_LastSceneViewOrtho: 0 + m_ReplacementShader: {fileID: 0} + m_ReplacementString: + m_SceneVisActive: 1 + m_LastLockedObject: {fileID: 0} + m_ViewIsLockedToObject: 0 +--- !u!114 &16 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12015, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_MinSize: {x: 200, y: 200} + m_MaxSize: {x: 4000, y: 4000} + m_TitleContent: + m_Text: Game + m_Image: {fileID: -6423792434712278376, guid: 0000000000000000d000000000000000, type: 0} + m_Tooltip: + m_Pos: + serializedVersion: 2 + x: 507 + y: 94 + width: 1532 + height: 790 + m_ViewDataDictionary: {fileID: 0} + m_SerializedViewsNames: [] + m_SerializedViewsValues: [] + m_PlayModeViewName: GameView + m_ShowGizmos: 0 + m_TargetDisplay: 0 + m_ClearColor: {r: 0, g: 0, b: 0, a: 0} + m_TargetSize: {x: 640, y: 480} + m_TextureFilterMode: 0 + m_TextureHideFlags: 61 + m_RenderIMGUI: 0 + m_MaximizeOnPlay: 0 + m_UseMipMap: 0 + m_VSyncEnabled: 0 + m_Gizmos: 0 + m_Stats: 0 + m_SelectedSizes: 00000000000000000000000000000000000000000000000000000000000000000000000000000000 + m_ZoomArea: + m_HRangeLocked: 0 + m_VRangeLocked: 0 + hZoomLockedByDefault: 0 + vZoomLockedByDefault: 0 + m_HBaseRangeMin: -766 + m_HBaseRangeMax: 766 + m_VBaseRangeMin: -395 + m_VBaseRangeMax: 395 + m_HAllowExceedBaseRangeMin: 1 + m_HAllowExceedBaseRangeMax: 1 + m_VAllowExceedBaseRangeMin: 1 + m_VAllowExceedBaseRangeMax: 1 + m_ScaleWithWindow: 0 + m_HSlider: 0 + m_VSlider: 0 + m_IgnoreScrollWheelUntilClicked: 0 + m_EnableMouseInput: 1 + m_EnableSliderZoomHorizontal: 0 + m_EnableSliderZoomVertical: 0 + m_UniformScale: 1 + m_UpDirection: 1 + m_DrawArea: + serializedVersion: 2 + x: 0 + y: 0 + width: 1532 + height: 790 + m_Scale: {x: 1, y: 1} + m_Translation: {x: 766, y: 395} + m_MarginLeft: 0 + m_MarginRight: 0 + m_MarginTop: 0 + m_MarginBottom: 0 + m_LastShownAreaInsideMargins: + serializedVersion: 2 + x: -766 + y: -395 + width: 1532 + height: 790 + m_MinimalGUI: 1 + m_defaultScale: 1 + m_LastWindowPixelSize: {x: 1532, y: 790} + m_ClearInEditMode: 1 + m_NoCameraWarning: 1 + m_LowResolutionForAspectRatios: 01000000000000000000 + m_XRRenderMode: 0 + m_RenderTexture: {fileID: 0} +--- !u!114 &17 +MonoBehaviour: + m_ObjectHideFlags: 52 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 1 + m_Script: {fileID: 12003, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_MinSize: {x: 100, y: 100} + m_MaxSize: {x: 4000, y: 4000} + m_TitleContent: + m_Text: Console + m_Image: {fileID: -4327648978806127646, guid: 0000000000000000d000000000000000, type: 0} + m_Tooltip: + m_Pos: + serializedVersion: 2 + x: 2249 + y: 726.5 + width: 920 + height: 250 + m_ViewDataDictionary: {fileID: 0} +--- !u!114 &18 +MonoBehaviour: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 0} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 13963, guid: 0000000000000000e000000000000000, type: 0} + m_Name: + m_EditorClassIdentifier: + m_DontSaveToLayout: 0 From d7216b4cc3beb916c06556d04780a01a46b7c2ce Mon Sep 17 00:00:00 2001 From: Dewald Bodenstein Date: Wed, 7 Feb 2024 17:22:51 +0200 Subject: [PATCH 2/4] Convert into a Unity Package so this can be used as a dependancy through Unity's Package Manager --- .gitignore | 114 - .vsconfig | 6 - Assets/Plugins/Protobuf/Google.Protobuf.dll | Bin 305664 -> 0 bytes CodeFormatting.mdpolicy | 222 - .../Images/MapStyleEditingOptions.png | Bin 7197 -> 0 bytes Documentation/Images/MapStyleEditor.png | Bin 47006 -> 0 bytes Documentation/Images/MapStyleLayerList.png | Bin 12414 -> 0 bytes .../Images/MapStyleLayerProperties.png | Bin 39655 -> 0 bytes Documentation/Images/RegionMapEditor.png | Bin 40319 -> 0 bytes Documentation/MapStyleEditor.md | 90 - Documentation/RegionMapEditor.md | 45 - LICENSE.md.meta | 7 + Packages/manifest.json | 43 - Packages/packages-lock.json | 338 - ProjectSettings/AudioManager.asset | 16 - ProjectSettings/ClusterInputManager.asset | 6 - ProjectSettings/DynamicsManager.asset | 18 - ProjectSettings/EditorBuildSettings.asset | 10 - ProjectSettings/EditorSettings.asset | 35 - ProjectSettings/GraphicsSettings.asset | 64 - ProjectSettings/InputManager.asset | 295 - ProjectSettings/MemorySettings.asset | 35 - ProjectSettings/NavMeshAreas.asset | 89 - ProjectSettings/NetworkManager.asset | 8 - ProjectSettings/PackageManagerSettings.asset | 36 - ProjectSettings/Physics2DSettings.asset | 35 - ProjectSettings/PresetManager.asset | 7 - ProjectSettings/ProjectSettings.asset | 812 - ProjectSettings/ProjectVersion.txt | 2 - ProjectSettings/QualitySettings.asset | 165 - ProjectSettings/TagManager.asset | 43 - ProjectSettings/TimeManager.asset | 9 - ProjectSettings/UnityConnectSettings.asset | 32 - ProjectSettings/VFXManager.asset | 12 - ProjectSettings/VersionControlSettings.asset | 8 - ProjectSettings/XRSettings.asset | 10 - ProjectSettings/boot.config | 0 README.md.meta | 7 + Runtime.meta | 8 + {Assets => Runtime}/Dependencies.meta | 2 +- {Assets => Runtime}/Dependencies/Mapbox.meta | 2 +- .../Dependencies/Mapbox/Earcut.cs | 0 .../Dependencies/Mapbox/Earcut.cs.meta | 2 +- .../Dependencies/SimpleJSON.meta | 2 +- .../Dependencies/SimpleJSON/SimpleJSON.cs | 0 .../SimpleJSON/SimpleJSON.cs.meta | 2 +- {Assets => Runtime}/Mapzen.meta | 2 +- {Assets => Runtime}/Mapzen/Geo.cs | 0 {Assets => Runtime}/Mapzen/Geo.cs.meta | 2 +- {Assets => Runtime}/Mapzen/LngLat.cs | 0 {Assets => Runtime}/Mapzen/LngLat.cs.meta | 2 +- {Assets => Runtime}/Mapzen/MercatorMeters.cs | 0 .../Mapzen/MercatorMeters.cs.meta | 2 +- {Assets => Runtime}/Mapzen/SceneGroupType.cs | 0 .../Mapzen/SceneGroupType.cs.meta | 2 +- {Assets => Runtime}/Mapzen/TileAddress.cs | 0 .../Mapzen/TileAddress.cs.meta | 2 +- {Assets => Runtime}/Mapzen/TileBounds.cs | 0 {Assets => Runtime}/Mapzen/TileBounds.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity.meta | 2 +- .../Mapzen/Unity/AsyncWorker.cs | 0 .../Mapzen/Unity/AsyncWorker.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity/Editor.meta | 2 +- .../Mapzen/Unity/Editor/EditorConfig.cs | 0 .../Mapzen/Unity/Editor/EditorConfig.cs.meta | 2 +- .../Unity/Editor/FeatureLayerTreeView.cs | 0 .../Unity/Editor/FeatureLayerTreeView.cs.meta | 2 +- .../Mapzen/Unity/Editor/LayerMatcherDrawer.cs | 0 .../Unity/Editor/LayerMatcherDrawer.cs.meta | 2 +- .../Mapzen/Unity/Editor/MapStyleEditor.cs | 0 .../Unity/Editor/MapStyleEditor.cs.meta | 2 +- .../Editor/PolygonPolylineOptionsDrawer.cs | 0 .../PolygonPolylineOptionsDrawer.cs.meta | 2 +- .../Mapzen/Unity/Editor/RegionMapEditor.cs | 0 .../Unity/Editor/RegionMapEditor.cs.meta | 2 +- .../Mapzen/Unity/ExtrusionType.cs | 0 .../Mapzen/Unity/ExtrusionType.cs.meta | 2 +- .../Mapzen/Unity/FeatureLayer.cs | 0 .../Mapzen/Unity/FeatureLayer.cs.meta | 2 +- .../Mapzen/Unity/FeatureMesh.cs | 0 .../Mapzen/Unity/FeatureMesh.cs.meta | 2 +- .../Mapzen/Unity/GameObjectOptions.cs | 0 .../Mapzen/Unity/GameObjectOptions.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity/IO.cs | 0 {Assets => Runtime}/Mapzen/Unity/IO.cs.meta | 2 +- .../Mapzen/Unity/LayerMatcher.cs | 0 .../Mapzen/Unity/LayerMatcher.cs.meta | 2 +- .../Mapzen/Unity/LayerStyle.cs | 0 .../Mapzen/Unity/LayerStyle.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity/MapStyle.cs | 0 .../Mapzen/Unity/MapStyle.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity/MeshData.cs | 0 .../Mapzen/Unity/MeshData.cs.meta | 2 +- .../Mapzen/Unity/PolygonBuilder.cs | 0 .../Mapzen/Unity/PolygonBuilder.cs.meta | 2 +- .../Mapzen/Unity/PolygonOptions.cs | 0 .../Mapzen/Unity/PolygonOptions.cs.meta | 2 +- .../Mapzen/Unity/PolylineBuilder.cs | 0 .../Mapzen/Unity/PolylineBuilder.cs.meta | 2 +- .../Mapzen/Unity/PolylineOptions.cs | 0 .../Mapzen/Unity/PolylineOptions.cs.meta | 2 +- .../Mapzen/Unity/SceneGraph.cs | 0 .../Mapzen/Unity/SceneGraph.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity/TileTask.cs | 0 .../Mapzen/Unity/TileTask.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Unity/UVMode.cs | 0 .../Mapzen/Unity/UVMode.cs.meta | 2 +- {Assets => Runtime}/Mapzen/Util.cs | 0 {Assets => Runtime}/Mapzen/Util.cs.meta | 2 +- {Assets => Runtime}/Mapzen/VectorData.meta | 2 +- .../Mapzen/VectorData/Feature.cs | 0 .../Mapzen/VectorData/Feature.cs.meta | 2 +- .../Mapzen/VectorData/FeatureCollection.cs | 0 .../VectorData/FeatureCollection.cs.meta | 2 +- .../Mapzen/VectorData/Filters.meta | 2 +- .../Filters/CompoundFeatureMatcher.cs | 0 .../Filters/CompoundFeatureMatcher.cs.meta | 2 +- .../VectorData/Filters/FeatureFilter.cs | 82 +- .../VectorData/Filters/FeatureFilter.cs.meta | 2 +- .../VectorData/Filters/FeatureMatcher.cs | 0 .../VectorData/Filters/FeatureMatcher.cs.meta | 2 +- .../VectorData/Filters/IFeatureFilter.cs | 0 .../VectorData/Filters/IFeatureFilter.cs.meta | 2 +- .../VectorData/Filters/IFeatureMatcher.cs | 0 .../Filters/IFeatureMatcher.cs.meta | 2 +- .../Filters/PropertyFeatureMatcher.cs | 0 .../Filters/PropertyFeatureMatcher.cs.meta | 2 +- .../Filters/PropertyRangeFeatureMatcher.cs | 0 .../PropertyRangeFeatureMatcher.cs.meta | 2 +- .../Filters/PropertyRegexFeatureMatcher.cs | 0 .../PropertyRegexFeatureMatcher.cs.meta | 2 +- .../Filters/PropertyValueFeatureMatcher.cs | 0 .../PropertyValueFeatureMatcher.cs.meta | 2 +- .../Mapzen/VectorData/Formats.meta | 2 +- .../VectorData/Formats/GeoJsonFeature.cs | 0 .../VectorData/Formats/GeoJsonFeature.cs.meta | 2 +- .../Formats/GeoJsonFeatureCollection.cs | 0 .../Formats/GeoJsonFeatureCollection.cs.meta | 2 +- .../Mapzen/VectorData/Formats/GeoJsonTile.cs | 0 .../VectorData/Formats/GeoJsonTile.cs.meta | 2 +- .../Mapzen/VectorData/Formats/Mvt.cs | 0 .../Mapzen/VectorData/Formats/Mvt.cs.meta | 2 +- .../Mapzen/VectorData/Formats/MvtFeature.cs | 0 .../VectorData/Formats/MvtFeature.cs.meta | 2 +- .../Formats/MvtFeatureCollection.cs | 0 .../Formats/MvtFeatureCollection.cs.meta | 2 +- .../Mapzen/VectorData/Formats/MvtTile.cs | 0 .../Mapzen/VectorData/Formats/MvtTile.cs.meta | 2 +- .../Mapzen/VectorData/GeometryContainer.cs | 0 .../VectorData/GeometryContainer.cs.meta | 2 +- .../Mapzen/VectorData/GeometryType.cs | 0 .../Mapzen/VectorData/GeometryType.cs.meta | 2 +- .../Mapzen/VectorData/IGeometryHandler.cs | 0 .../VectorData/IGeometryHandler.cs.meta | 2 +- .../Mapzen/VectorData/Layer.cs | 0 .../Mapzen/VectorData/Layer.cs.meta | 2 +- .../Mapzen/VectorData/Point.cs | 0 .../Mapzen/VectorData/Point.cs.meta | 2 +- {Assets => Runtime}/Mapzen/VectorData/Tile.cs | 0 .../Mapzen/VectorData/Tile.cs.meta | 2 +- .../Mapzen/VectorData/TileCache.cs | 0 .../Mapzen/VectorData/TileCache.cs.meta | 2 +- {Assets => Runtime}/Plugins.meta | 2 +- {Assets => Runtime}/Plugins/Protobuf.meta | 2 +- .../Plugins/Protobuf/Google.Protobuf.dll.meta | 2 +- .../Plugins/Protobuf/Google.Protobuf.xml | 14056 ++++++++-------- .../Plugins/Protobuf/Google.Protobuf.xml.meta | 2 +- {Assets => Runtime}/RegionMap.cs | 0 {Assets => Runtime}/RegionMap.cs.meta | 2 +- {Assets => Runtime}/Scenes.meta | 2 +- {Assets => Runtime}/Scenes/Blue.mat | 0 {Assets => Runtime}/Scenes/Blue.mat.meta | 2 +- .../Scenes/ExampleMapStyle.asset | 0 .../Scenes/ExampleMapStyle.asset.meta | 2 +- {Assets => Runtime}/Scenes/Green Lighter.mat | 0 .../Scenes/Green Lighter.mat.meta | 2 +- {Assets => Runtime}/Scenes/Green.mat | 0 {Assets => Runtime}/Scenes/Green.mat.meta | 2 +- {Assets => Runtime}/Scenes/Red Lighter.mat | 0 .../Scenes/Red Lighter.mat.meta | 2 +- {Assets => Runtime}/Scenes/Red.mat | 0 {Assets => Runtime}/Scenes/Red.mat.meta | 2 +- .../Scenes/RegionMapExample.unity | 0 .../Scenes/RegionMapExample.unity.meta | 2 +- {Assets => Runtime}/Scenes/UVGrid.mat | 0 {Assets => Runtime}/Scenes/UVGrid.mat.meta | 2 +- Runtime/tangram-unity.asmdef | 3 + Runtime/tangram-unity.asmdef.meta | 7 + UserSettings/EditorUserSettings.asset | 25 - UserSettings/Layouts/default-2021.dwlt | 746 - circle.yml | 13 - package.json | 19 + package.json.meta | 7 + tangram-unity.png.meta | 114 + tangram-unity.sln.DotSettings | 2 - 195 files changed, 7321 insertions(+), 10540 deletions(-) delete mode 100644 .gitignore delete mode 100644 .vsconfig delete mode 100644 Assets/Plugins/Protobuf/Google.Protobuf.dll delete mode 100644 CodeFormatting.mdpolicy delete mode 100644 Documentation/Images/MapStyleEditingOptions.png delete mode 100644 Documentation/Images/MapStyleEditor.png delete mode 100644 Documentation/Images/MapStyleLayerList.png delete mode 100644 Documentation/Images/MapStyleLayerProperties.png delete mode 100644 Documentation/Images/RegionMapEditor.png delete mode 100644 Documentation/MapStyleEditor.md delete mode 100644 Documentation/RegionMapEditor.md create mode 100644 LICENSE.md.meta delete mode 100644 Packages/manifest.json delete mode 100644 Packages/packages-lock.json delete mode 100644 ProjectSettings/AudioManager.asset delete mode 100644 ProjectSettings/ClusterInputManager.asset delete mode 100644 ProjectSettings/DynamicsManager.asset delete mode 100644 ProjectSettings/EditorBuildSettings.asset delete mode 100644 ProjectSettings/EditorSettings.asset delete mode 100644 ProjectSettings/GraphicsSettings.asset delete mode 100644 ProjectSettings/InputManager.asset delete mode 100644 ProjectSettings/MemorySettings.asset delete mode 100644 ProjectSettings/NavMeshAreas.asset delete mode 100644 ProjectSettings/NetworkManager.asset delete mode 100644 ProjectSettings/PackageManagerSettings.asset delete mode 100644 ProjectSettings/Physics2DSettings.asset delete mode 100644 ProjectSettings/PresetManager.asset delete mode 100644 ProjectSettings/ProjectSettings.asset delete mode 100644 ProjectSettings/ProjectVersion.txt delete mode 100644 ProjectSettings/QualitySettings.asset delete mode 100644 ProjectSettings/TagManager.asset delete mode 100644 ProjectSettings/TimeManager.asset delete mode 100644 ProjectSettings/UnityConnectSettings.asset delete mode 100644 ProjectSettings/VFXManager.asset delete mode 100644 ProjectSettings/VersionControlSettings.asset delete mode 100644 ProjectSettings/XRSettings.asset delete mode 100644 ProjectSettings/boot.config create mode 100644 README.md.meta create mode 100644 Runtime.meta rename {Assets => Runtime}/Dependencies.meta (79%) rename {Assets => Runtime}/Dependencies/Mapbox.meta (79%) rename {Assets => Runtime}/Dependencies/Mapbox/Earcut.cs (100%) rename {Assets => Runtime}/Dependencies/Mapbox/Earcut.cs.meta (85%) rename {Assets => Runtime}/Dependencies/SimpleJSON.meta (79%) rename {Assets => Runtime}/Dependencies/SimpleJSON/SimpleJSON.cs (100%) rename {Assets => Runtime}/Dependencies/SimpleJSON/SimpleJSON.cs.meta (85%) rename {Assets => Runtime}/Mapzen.meta (79%) rename {Assets => Runtime}/Mapzen/Geo.cs (100%) rename {Assets => Runtime}/Mapzen/Geo.cs.meta (85%) rename {Assets => Runtime}/Mapzen/LngLat.cs (100%) rename {Assets => Runtime}/Mapzen/LngLat.cs.meta (85%) rename {Assets => Runtime}/Mapzen/MercatorMeters.cs (100%) rename {Assets => Runtime}/Mapzen/MercatorMeters.cs.meta (85%) rename {Assets => Runtime}/Mapzen/SceneGroupType.cs (100%) rename {Assets => Runtime}/Mapzen/SceneGroupType.cs.meta (85%) rename {Assets => Runtime}/Mapzen/TileAddress.cs (100%) rename {Assets => Runtime}/Mapzen/TileAddress.cs.meta (85%) rename {Assets => Runtime}/Mapzen/TileBounds.cs (100%) rename {Assets => Runtime}/Mapzen/TileBounds.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity.meta (79%) rename {Assets => Runtime}/Mapzen/Unity/AsyncWorker.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/AsyncWorker.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/Editor.meta (79%) rename {Assets => Runtime}/Mapzen/Unity/Editor/EditorConfig.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/Editor/EditorConfig.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/Editor/FeatureLayerTreeView.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/Editor/LayerMatcherDrawer.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/Editor/MapStyleEditor.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/Editor/MapStyleEditor.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/Editor/RegionMapEditor.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/Editor/RegionMapEditor.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/ExtrusionType.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/ExtrusionType.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/FeatureLayer.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/FeatureLayer.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/FeatureMesh.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/FeatureMesh.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/GameObjectOptions.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/GameObjectOptions.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/IO.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/IO.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/LayerMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/LayerMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/LayerStyle.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/LayerStyle.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/MapStyle.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/MapStyle.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/MeshData.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/MeshData.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/PolygonBuilder.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/PolygonBuilder.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/PolygonOptions.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/PolygonOptions.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/PolylineBuilder.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/PolylineBuilder.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/PolylineOptions.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/PolylineOptions.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/SceneGraph.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/SceneGraph.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/TileTask.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/TileTask.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Unity/UVMode.cs (100%) rename {Assets => Runtime}/Mapzen/Unity/UVMode.cs.meta (85%) rename {Assets => Runtime}/Mapzen/Util.cs (100%) rename {Assets => Runtime}/Mapzen/Util.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData.meta (79%) rename {Assets => Runtime}/Mapzen/VectorData/Feature.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Feature.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/FeatureCollection.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/FeatureCollection.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters.meta (79%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/FeatureFilter.cs (96%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/FeatureFilter.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/FeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/IFeatureFilter.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/IFeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats.meta (79%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/GeoJsonFeature.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/GeoJsonTile.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/Mvt.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/Mvt.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/MvtFeature.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/MvtFeature.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/MvtFeatureCollection.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/MvtTile.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Formats/MvtTile.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/GeometryContainer.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/GeometryContainer.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/GeometryType.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/GeometryType.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/IGeometryHandler.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/IGeometryHandler.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Layer.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Layer.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Point.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Point.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/Tile.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/Tile.cs.meta (85%) rename {Assets => Runtime}/Mapzen/VectorData/TileCache.cs (100%) rename {Assets => Runtime}/Mapzen/VectorData/TileCache.cs.meta (85%) rename {Assets => Runtime}/Plugins.meta (79%) rename {Assets => Runtime}/Plugins/Protobuf.meta (79%) rename {Assets => Runtime}/Plugins/Protobuf/Google.Protobuf.dll.meta (94%) rename {Assets => Runtime}/Plugins/Protobuf/Google.Protobuf.xml (98%) rename {Assets => Runtime}/Plugins/Protobuf/Google.Protobuf.xml.meta (78%) rename {Assets => Runtime}/RegionMap.cs (100%) rename {Assets => Runtime}/RegionMap.cs.meta (85%) rename {Assets => Runtime}/Scenes.meta (79%) rename {Assets => Runtime}/Scenes/Blue.mat (100%) rename {Assets => Runtime}/Scenes/Blue.mat.meta (81%) rename {Assets => Runtime}/Scenes/ExampleMapStyle.asset (100%) rename {Assets => Runtime}/Scenes/ExampleMapStyle.asset.meta (81%) rename {Assets => Runtime}/Scenes/Green Lighter.mat (100%) rename {Assets => Runtime}/Scenes/Green Lighter.mat.meta (81%) rename {Assets => Runtime}/Scenes/Green.mat (100%) rename {Assets => Runtime}/Scenes/Green.mat.meta (81%) rename {Assets => Runtime}/Scenes/Red Lighter.mat (100%) rename {Assets => Runtime}/Scenes/Red Lighter.mat.meta (81%) rename {Assets => Runtime}/Scenes/Red.mat (100%) rename {Assets => Runtime}/Scenes/Red.mat.meta (81%) rename {Assets => Runtime}/Scenes/RegionMapExample.unity (100%) rename {Assets => Runtime}/Scenes/RegionMapExample.unity.meta (77%) rename {Assets => Runtime}/Scenes/UVGrid.mat (100%) rename {Assets => Runtime}/Scenes/UVGrid.mat.meta (81%) create mode 100644 Runtime/tangram-unity.asmdef create mode 100644 Runtime/tangram-unity.asmdef.meta delete mode 100644 UserSettings/EditorUserSettings.asset delete mode 100644 UserSettings/Layouts/default-2021.dwlt delete mode 100644 circle.yml create mode 100644 package.json create mode 100644 package.json.meta create mode 100644 tangram-unity.png.meta delete mode 100644 tangram-unity.sln.DotSettings diff --git a/.gitignore b/.gitignore deleted file mode 100644 index 3ae14181..00000000 --- a/.gitignore +++ /dev/null @@ -1,114 +0,0 @@ -**/build - -# Vim -*.swp - -.vscode/ - -# Created by https://www.gitignore.io/api/macos,windows,linux,unity - -### Linux ### -*~ - -# temporary files which can be created if a process still has a handle open of a deleted file -.fuse_hidden* - -# KDE directory preferences -.directory - -# Linux trash folder which might appear on any partition or disk -.Trash-* - -# .nfs files are created when an open file is removed but is still being accessed -.nfs* - -### macOS ### -*.DS_Store -.AppleDouble -.LSOverride - -# Icon must end with two \r -Icon - - -# Thumbnails -._* - -# Files that might appear in the root of a volume -.DocumentRevisions-V100 -.fseventsd -.Spotlight-V100 -.TemporaryItems -.Trashes -.VolumeIcon.icns -.com.apple.timemachine.donotpresent - -# Directories potentially created on remote AFP share -.AppleDB -.AppleDesktop -Network Trash Folder -Temporary Items -.apdisk - -### Unity ### -/[Ll]ibrary/ -/[Tt]emp/ -/[Oo]bj/ -/[Bb]uild/ -/[Bb]uilds/ -/[Ll]ogs/ -/Assets/AssetStoreTools* - -# Visual Studio 2015 cache directory -/.vs/ - -# Autogenerated VS/MD/Consulo solution and project files -ExportedObj/ -.consulo/ -*.csproj -*.unityproj -*.sln -*.suo -*.tmp -*.user -*.userprefs -*.pidb -*.booproj -*.svd -*.pdb - -# Unity3D generated meta files -*.pidb.meta - -# Unity3D Generated File On Crash Reports -sysinfo.txt - -# Builds -*.apk -*.unitypackage - -### Windows ### -# Windows thumbnail cache files -Thumbs.db -ehthumbs.db -ehthumbs_vista.db - -# Folder config file -Desktop.ini - -# Recycle Bin used on file shares -$RECYCLE.BIN/ - -# Windows Installer files -*.cab -*.msi -*.msm -*.msp - -# Windows shortcuts -*.lnk - -# End of https://www.gitignore.io/api/macos,windows,linux,unity - -# Rider generated files -/.idea/ diff --git a/.vsconfig b/.vsconfig deleted file mode 100644 index d70cd98b..00000000 --- a/.vsconfig +++ /dev/null @@ -1,6 +0,0 @@ -{ - "version": "1.0", - "components": [ - "Microsoft.VisualStudio.Workload.ManagedGame" - ] -} diff --git a/Assets/Plugins/Protobuf/Google.Protobuf.dll b/Assets/Plugins/Protobuf/Google.Protobuf.dll deleted file mode 100644 index 22e0cc857d5bc4ff7f5a9e9a139f8e46e3ffcca8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 305664 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 diff --git a/CodeFormatting.mdpolicy b/CodeFormatting.mdpolicy deleted file mode 100644 index 81841538..00000000 --- a/CodeFormatting.mdpolicy +++ /dev/null @@ -1,222 +0,0 @@ - - - - 120 - True - - - - True - True - NextLine - NextLine - NextLine - NextLine - NextLine - NextLine - NextLine - NextLine - NewLine - NewLine - NewLine - DoNotCare - DoNotChange - NextLine - False - False - False - NewLine - SameLine - False - False - False - - - - - Namespaces - Namespace - VisibilityMask - PascalCase - True - True - - - Types - Class, Struct, Enum, Delegate - VisibilityMask - PascalCase - True - True - - - Interfaces - - I - - Interface - VisibilityMask - PascalCase - True - True - - - Attributes - - Attribute - - CustomAttributes - VisibilityMask - PascalCase - True - True - - - Event Arguments - - EventArgs - - CustomEventArgs - VisibilityMask - PascalCase - True - True - - - Exceptions - - Exception - - CustomExceptions - VisibilityMask - PascalCase - True - True - - - Methods - Methods - VisibilityMask - PascalCase - True - True - - - Static Readonly Fields - ReadonlyField - Internal, Protected, Public - PascalCase - False - True - - - Fields (Non Private) - Field - Internal, Protected, Public - PascalCase - True - True - - - ReadOnly Fields (Non Private) - ReadonlyField - Internal, Protected, Public - PascalCase - True - False - - - Fields (Private) - - _ - m_ - - Field, ReadonlyField - Private - CamelCase - True - False - - - Static Fields (Private) - Field - Private - CamelCase - False - True - - - ReadOnly Fields (Private) - - _ - m_ - - ReadonlyField - Private - CamelCase - True - False - - - Constant Fields - ConstantField - VisibilityMask - PascalCase - True - True - - - Properties - Property - VisibilityMask - PascalCase - True - True - - - Events - Event - VisibilityMask - PascalCase - True - True - - - Enum Members - EnumMember - VisibilityMask - PascalCase - True - True - - - Parameters - Parameter - VisibilityMask - CamelCase - True - True - - - Type Parameters - - T - - TypeParameter - VisibilityMask - PascalCase - True - True - - - - - - 120 - True - - - 120 - True - - \ No newline at end of file diff --git a/Documentation/Images/MapStyleEditingOptions.png b/Documentation/Images/MapStyleEditingOptions.png deleted file mode 100644 index 18ec8c046d994dddb2fa555e62033556bfad1ce6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7197 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

2-!R!nC+tylda$sd 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 ayr^?Rtja*))4%%%mZX@RXo0Yv&;J0=q*P%5 diff --git a/Documentation/Images/MapStyleLayerProperties.png b/Documentation/Images/MapStyleLayerProperties.png deleted file mode 100644 index b6f5088dd9d2be42e09e6286c84cfd269f1bb927..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 39655 zcmce-WmHvL`v(deknR$xO?QfvbSMqd4U*E`jdX)_m(txxcY|~{(%pR*o^yQvW8C}s zI@Sl=d*xnpKF_aau$;_CWP~>e5D*Z^;$kB55D*|b2nfh8aIb(*;zNEqK|mlBm>;$amP)QEbH-I$ukKbbqRsPoit?Dp(* ze#Au#5zALA5Cs~9h#DBhdga!@N}7|6cS8aJi3En!%Ix}W0H^8e`v6hcaC_|P1*;Xl z_v5sBruF$rhhi{%a1{aqCW~Njcr`cM{S~1!fe$k#gu%S5nZpm=WTz~8CJ}s*2Ge9r zqXxrded7jWBk3>Y_yc+na9Hdbi4YJjNF{G8IpOnB{e3HGG6pwtnxG9o%8;gn+M*1E z$}3F#Xn1A#IO}yLev@Kc-1Ti(ChFv%YA9%RWDqU4eC8=*;j}d_nKb!lASE|-u+Xut zeZ0_hF(ucqO2@;jcN^Dl8{_Fw>+HVw<`G&1#`ymcix7zVW|=+ z`#Y?4Gh;gXc&y1e!=yswb!zlJ~|UixcA=53wiVKxbhMaPL@UWo(SEQ4Qozr8C2u1=RKlp zG1mLm3pTJe$o1@+{Fbjde0n$HPChupx`WfhN4vH+P*)>2nATxW$ZjH`Sq0N{WlqRN zFmL=cg;>^JuYo>$pM)`s$CB)!9R~S`FxoKKP*sG?N;C-)kjTUsh`W-*%2U$>S0^b7 z6;f$Y@{%`GeCtm(&^VK4jcf|m6yg(aksu=V%I^DwL}MAdg@tYiyG8vy+&1zoUgGjuoNT>qpwm)LuyHaN$_gP#YyIw=7k52bNZD_m7`lHwvDz#wwet*4P>?nn*k

- Provides a utility routine to copy small arrays much more quickly than Buffer.BlockCopy - - - - - The threshold above which you should use Buffer.BlockCopy rather than ByteArray.Copy - - - - - Determines which copy routine to use based on the number of bytes to be copied. - - - - - Reverses the order of bytes in the array - - - - - Immutable array of bytes. - - - - - Unsafe operations that can cause IO Failure and/or other catestrophic side-effects. - - - - - Constructs a new ByteString from the given byte array. The array is - *not* copied, and must not be modified after this constructor is called. - - - - - Provides direct, unrestricted access to the bytes contained in this instance. - You must not modify or resize the byte array returned by this method. - - - - - Internal use only. Ensure that the provided array is not mutated and belongs to this instance. - - - - - Constructs a new ByteString from the given byte array. The array is - *not* copied, and must not be modified after this constructor is called. - - - - - Returns an empty ByteString. - - - - - Returns the length of this ByteString in bytes. - - - - - Returns true if this byte string is empty, false otherwise. - - - - - Converts this into a byte array. - - The data is copied - changes to the returned array will not be reflected in this ByteString. - A byte array with the same data as this ByteString. - - - - Converts this into a standard base64 representation. - - A base64 representation of this ByteString. - - - - Constructs a from the Base64 Encoded String. - - - - - Constructs a from data in the given stream, synchronously. - - If successful, will be read completely, from the position - at the start of the call. - The stream to copy into a ByteString. - A ByteString with content read from the given stream. - - - - Constructs a from the given array. The contents - are copied, so further modifications to the array will not - be reflected in the returned ByteString. - This method can also be invoked in ByteString.CopyFrom(0xaa, 0xbb, ...) form - which is primarily useful for testing. - - - - - Constructs a from a portion of a byte array. - - - - - Creates a new by encoding the specified text with - the given encoding. - - - - - Creates a new by encoding the specified text in UTF-8. - - - - - Retuns the byte at the given index. - - - - - Converts this into a string by applying the given encoding. - - - This method should only be used to convert binary data which was the result of encoding - text with the given encoding. - - The encoding to use to decode the binary data into text. - The result of decoding the binary data with the given decoding. - - - - Converts this into a string by applying the UTF-8 encoding. - - - This method should only be used to convert binary data which was the result of encoding - text with UTF-8. - - The result of decoding the binary data with the given decoding. - - - - Returns an iterator over the bytes in this . - - An iterator over the bytes in this object. - - - - Returns an iterator over the bytes in this . - - An iterator over the bytes in this object. - - - - Creates a CodedInputStream from this ByteString's data. - - - - - Compares two byte strings for equality. - - The first byte string to compare. - The second byte string to compare. - true if the byte strings are equal; false otherwise. - - - - Compares two byte strings for inequality. - - The first byte string to compare. - The second byte string to compare. - false if the byte strings are equal; true otherwise. - - - - Compares this byte string with another object. - - The object to compare this with. - true if refers to an equal ; false otherwise. - - - - Returns a hash code for this object. Two equal byte strings - will return the same hash code. - - A hash code for this object. - - - - Compares this byte string with another. - - The to compare this with. - true if refers to an equal byte string; false otherwise. - - - - Used internally by CodedOutputStream to avoid creating a copy for the write - - - - - Copies the entire byte array to the destination array provided at the offset specified. - - - - - Writes the entire byte array to the provided stream - - - - - Reads and decodes protocol message fields. - - - - This class is generally used by generated code to read appropriate - primitives from the stream. It effectively encapsulates the lowest - levels of protocol buffer format. - - - Repeated fields and map fields are not handled by this class; use - and to serialize such fields. - - - - - - Whether to leave the underlying stream open when disposing of this stream. - This is always true when there's no stream. - - - - - Buffer of data read from the stream or provided at construction time. - - - - - The index of the buffer at which we need to refill from the stream (if there is one). - - - - - The position within the current buffer (i.e. the next byte to read) - - - - - The stream to read further input from, or null if the byte array buffer was provided - directly on construction, with no further data available. - - - - - The last tag we read. 0 indicates we've read to the end of the stream - (or haven't read anything yet). - - - - - The next tag, used to store the value read by PeekTag. - - - - - The total number of bytes read before the current buffer. The - total bytes read up to the current position can be computed as - totalBytesRetired + bufferPos. - - - - - The absolute position of the end of the current message. - - - - - Creates a new CodedInputStream reading data from the given byte array. - - - - - Creates a new that reads from the given byte array slice. - - - - - Creates a new reading data from the given stream, which will be disposed - when the returned object is disposed. - - The stream to read from. - - - - Creates a new reading data from the given stream. - - The stream to read from. - true to leave open when the returned - is disposed; false to dispose of the given stream when the - returned object is disposed. - - - - Creates a new CodedInputStream reading data from the given - stream and buffer, using the default limits. - - - - - Creates a new CodedInputStream reading data from the given - stream and buffer, using the specified limits. - - - This chains to the version with the default limits instead of vice versa to avoid - having to check that the default values are valid every time. - - - - - Creates a with the specified size and recursion limits, reading - from an input stream. - - - This method exists separately from the constructor to reduce the number of constructor overloads. - It is likely to be used considerably less frequently than the constructors, as the default limits - are suitable for most use cases. - - The input stream to read from - The total limit of data to read from the stream. - The maximum recursion depth to allow while reading. - A CodedInputStream reading from with the specified size - and recursion limits. - - - - Returns the current position in the input stream, or the position in the input buffer - - - - - Returns the last tag read, or 0 if no tags have been read or we've read beyond - the end of the stream. - - - - - Returns the size limit for this stream. - - - This limit is applied when reading from the underlying stream, as a sanity check. It is - not applied when reading from a byte array data source without an underlying stream. - The default value is 64MB. - - - The size limit. - - - - - Returns the recursion limit for this stream. This limit is applied whilst reading messages, - to avoid maliciously-recursive data. - - - The default limit is 64. - - - The recursion limit for this stream. - - - - - Disposes of this instance, potentially closing any underlying stream. - - - As there is no flushing to perform here, disposing of a which - was constructed with the leaveOpen option parameter set to true (or one which - was constructed to read from a byte array) has no effect. - - - - - Verifies that the last call to ReadTag() returned tag 0 - in other words, - we've reached the end of the stream when we expected to. - - The - tag read was not the one specified - - - - Peeks at the next field tag. This is like calling , but the - tag is not consumed. (So a subsequent call to will return the - same value.) - - - - - Reads a field tag, returning the tag of 0 for "end of stream". - - - If this method returns 0, it doesn't necessarily mean the end of all - the data in this CodedInputStream; it may be the end of the logical stream - for an embedded message, for example. - - The next field tag, or 0 for end of stream. (0 is never a valid tag.) - - - - Skips the data for the field with the tag we've just read. - This should be called directly after , when - the caller wishes to skip an unknown field. - - - This method throws if the last-read tag was an end-group tag. - If a caller wishes to skip a group, they should skip the whole group, by calling this method after reading the - start-group tag. This behavior allows callers to call this method on any field they don't understand, correctly - resulting in an error if an end-group tag has not been paired with an earlier start-group tag. - - The last tag was an end-group tag - The last read operation read to the end of the logical stream - - - - Reads a double field from the stream. - - - - - Reads a float field from the stream. - - - - - Reads a uint64 field from the stream. - - - - - Reads an int64 field from the stream. - - - - - Reads an int32 field from the stream. - - - - - Reads a fixed64 field from the stream. - - - - - Reads a fixed32 field from the stream. - - - - - Reads a bool field from the stream. - - - - - Reads a string field from the stream. - - - - - Reads an embedded message field value from the stream. - - - - - Reads a bytes field value from the stream. - - - - - Reads a uint32 field value from the stream. - - - - - Reads an enum field value from the stream. - - - - - Reads an sfixed32 field value from the stream. - - - - - Reads an sfixed64 field value from the stream. - - - - - Reads an sint32 field value from the stream. - - - - - Reads an sint64 field value from the stream. - - - - - Reads a length for length-delimited data. - - - This is internally just reading a varint, but this method exists - to make the calling code clearer. - - - - - Peeks at the next tag in the stream. If it matches , - the tag is consumed and the method returns true; otherwise, the - stream is left in the original position and the method returns false. - - - - - Same code as ReadRawVarint32, but read each byte individually, checking for - buffer overflow. - - - - - Reads a raw Varint from the stream. If larger than 32 bits, discard the upper bits. - This method is optimised for the case where we've got lots of data in the buffer. - That means we can check the size just once, then just read directly from the buffer - without constant rechecking of the buffer length. - - - - - Reads a varint from the input one byte at a time, so that it does not - read any bytes after the end of the varint. If you simply wrapped the - stream in a CodedInputStream and used ReadRawVarint32(Stream) - then you would probably end up reading past the end of the varint since - CodedInputStream buffers its input. - - - - - - - Reads a raw varint from the stream. - - - - - Reads a 32-bit little-endian integer from the stream. - - - - - Reads a 64-bit little-endian integer from the stream. - - - - - Decode a 32-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Decode a 32-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Sets currentLimit to (current position) + byteLimit. This is called - when descending into a length-delimited embedded message. The previous - limit is returned. - - The old limit. - - - - Discards the current limit, returning the previous limit. - - - - - Returns whether or not all the data before the limit has been read. - - - - - - Returns true if the stream has reached the end of the input. This is the - case if either the end of the underlying input source has been reached or - the stream has reached a limit created using PushLimit. - - - - - Called when buffer is empty to read more bytes from the - input. If is true, RefillBuffer() gurantees that - either there will be at least one byte in the buffer when it returns - or it will throw an exception. If is false, - RefillBuffer() returns false if no more bytes were available. - - - - - - - Read one byte from the input. - - - the end of the stream or the current limit was reached - - - - - Reads a fixed size of bytes from the input. - - - the end of the stream or the current limit was reached - - - - - Reads and discards bytes. - - the end of the stream - or the current limit was reached - - - - Abstraction of skipping to cope with streams which can't really skip. - - - - - Encodes and writes protocol message fields. - - - - This class is generally used by generated code to write appropriate - primitives to the stream. It effectively encapsulates the lowest - levels of protocol buffer format. Unlike some other implementations, - this does not include combined "write tag and value" methods. Generated - code knows the exact byte representations of the tags they're going to write, - so there's no need to re-encode them each time. Manually-written code calling - this class should just call one of the WriteTag overloads before each value. - - - Repeated fields and map fields are not handled by this class; use RepeatedField<T> - and MapField<TKey, TValue> to serialize such fields. - - - - - - Computes the number of bytes that would be needed to encode a - double field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - float field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - uint64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - int64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - int32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - fixed64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - fixed32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - bool field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - string field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - group field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - embedded message field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - bytes field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - uint32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - enum field, including the tag. The caller is responsible for - converting the enum value to its numeric value. - - - - - Computes the number of bytes that would be needed to encode an - sfixed32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - sfixed64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - sint32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - sint64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a length, - as written by . - - - - - Computes the number of bytes that would be needed to encode a varint. - - - - - Computes the number of bytes that would be needed to encode a varint. - - - - - Computes the number of bytes that would be needed to encode a tag. - - - - - The buffer size used by CreateInstance(Stream). - - - - - Creates a new CodedOutputStream that writes directly to the given - byte array. If more bytes are written than fit in the array, - OutOfSpaceException will be thrown. - - - - - Creates a new CodedOutputStream that writes directly to the given - byte array slice. If more bytes are written than fit in the array, - OutOfSpaceException will be thrown. - - - - - Creates a new which write to the given stream, and disposes of that - stream when the returned CodedOutputStream is disposed. - - The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. - - - - Creates a new CodedOutputStream which write to the given stream and uses - the specified buffer size. - - The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. - The size of buffer to use internally. - - - - Creates a new CodedOutputStream which write to the given stream. - - The stream to write to. - If true, is left open when the returned CodedOutputStream is disposed; - if false, the provided stream is disposed as well. - - - - Creates a new CodedOutputStream which write to the given stream and uses - the specified buffer size. - - The stream to write to. - The size of buffer to use internally. - If true, is left open when the returned CodedOutputStream is disposed; - if false, the provided stream is disposed as well. - - - - Returns the current position in the stream, or the position in the output buffer - - - - - Writes a double field value, without a tag, to the stream. - - The value to write - - - - Writes a float field value, without a tag, to the stream. - - The value to write - - - - Writes a uint64 field value, without a tag, to the stream. - - The value to write - - - - Writes an int64 field value, without a tag, to the stream. - - The value to write - - - - Writes an int32 field value, without a tag, to the stream. - - The value to write - - - - Writes a fixed64 field value, without a tag, to the stream. - - The value to write - - - - Writes a fixed32 field value, without a tag, to the stream. - - The value to write - - - - Writes a bool field value, without a tag, to the stream. - - The value to write - - - - Writes a string field value, without a tag, to the stream. - The data is length-prefixed. - - The value to write - - - - Writes a message, without a tag, to the stream. - The data is length-prefixed. - - The value to write - - - - Write a byte string, without a tag, to the stream. - The data is length-prefixed. - - The value to write - - - - Writes a uint32 value, without a tag, to the stream. - - The value to write - - - - Writes an enum value, without a tag, to the stream. - - The value to write - - - - Writes an sfixed32 value, without a tag, to the stream. - - The value to write. - - - - Writes an sfixed64 value, without a tag, to the stream. - - The value to write - - - - Writes an sint32 value, without a tag, to the stream. - - The value to write - - - - Writes an sint64 value, without a tag, to the stream. - - The value to write - - - - Writes a length (in bytes) for length-delimited data. - - - This method simply writes a rawint, but exists for clarity in calling code. - - Length value, in bytes. - - - - Encodes and writes a tag. - - The number of the field to write the tag for - The wire format type of the tag to write - - - - Writes an already-encoded tag. - - The encoded tag - - - - Writes the given single-byte tag directly to the stream. - - The encoded tag - - - - Writes the given two-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - - - - Writes the given three-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - The third byte of the encoded tag - - - - Writes the given four-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - The third byte of the encoded tag - The fourth byte of the encoded tag - - - - Writes the given five-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - The third byte of the encoded tag - The fourth byte of the encoded tag - The fifth byte of the encoded tag - - - - Writes a 32 bit value as a varint. The fast route is taken when - there's enough buffer space left to whizz through without checking - for each byte; otherwise, we resort to calling WriteRawByte each time. - - - - - Writes out an array of bytes. - - - - - Writes out part of an array of bytes. - - - - - Encode a 32-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Encode a 64-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Indicates that a CodedOutputStream wrapping a flat byte array - ran out of space. - - - - - Flushes any buffered data and optionally closes the underlying stream, if any. - - - - By default, any underlying stream is closed by this method. To configure this behaviour, - use a constructor overload with a leaveOpen parameter. If this instance does not - have an underlying stream, this method does nothing. - - - For the sake of efficiency, calling this method does not prevent future write calls - but - if a later write ends up writing to a stream which has been disposed, that is likely to - fail. It is recommend that you not call any other methods after this. - - - - - - Flushes any buffered data to the underlying stream (if there is one). - - - - - Verifies that SpaceLeft returns zero. It's common to create a byte array - that is exactly big enough to hold a message, then write to it with - a CodedOutputStream. Calling CheckNoSpaceLeft after writing verifies that - the message was actually as big as expected, which can help bugs. - - - - - If writing to a flat array, returns the space left in the array. Otherwise, - throws an InvalidOperationException. - - - - - Representation of a map field in a Protocol Buffer message. - - Key type in the map. Must be a type supported by Protocol Buffer map keys. - Value type in the map. Must be a type supported by Protocol Buffers. - - - For string keys, the equality comparison is provided by . - - - Null values are not permitted in the map, either for wrapper types or regular messages. - If a map is deserialized from a data stream and the value is missing from an entry, a default value - is created instead. For primitive types, that is the regular default value (0, the empty string and so - on); for message types, an empty instance of the message is created, as if the map entry contained a 0-length - encoded value for the field. - - - This implementation does not generally prohibit the use of key/value types which are not - supported by Protocol Buffers (e.g. using a key type of byte) but nor does it guarantee - that all operations will work in such cases. - - - The order in which entries are returned when iterating over this object is undefined, and may change - in future versions. - - - - - - Creates a deep clone of this object. - - - A deep clone of this object. - - - - - Adds the specified key/value pair to the map. - - - This operation fails if the key already exists in the map. To replace an existing entry, use the indexer. - - The key to add - The value to add. - The given key already exists in map. - - - - Determines whether the specified key is present in the map. - - The key to check. - true if the map contains the given key; false otherwise. - - - - Removes the entry identified by the given key from the map. - - The key indicating the entry to remove from the map. - true if the map contained the given key before the entry was removed; false otherwise. - - - - Gets the value associated with the specified key. - - The key whose value to get. - When this method returns, the value associated with the specified key, if the key is found; - otherwise, the default value for the type of the parameter. - This parameter is passed uninitialized. - true if the map contains an element with the specified key; otherwise, false. - - - - Gets or sets the value associated with the specified key. - - The key of the value to get or set. - The property is retrieved and key does not exist in the collection. - The value associated with the specified key. If the specified key is not found, - a get operation throws a , and a set operation creates a new element with the specified key. - - - - Gets a collection containing the keys in the map. - - - - - Gets a collection containing the values in the map. - - - - - Adds the specified entries to the map. The keys and values are not automatically cloned. - - The entries to add to the map. - - - - Returns an enumerator that iterates through the collection. - - - An enumerator that can be used to iterate through the collection. - - - - - Returns an enumerator that iterates through a collection. - - - An object that can be used to iterate through the collection. - - - - - Adds the specified item to the map. - - The item to add to the map. - - - - Removes all items from the map. - - - - - Determines whether map contains an entry equivalent to the given key/value pair. - - The key/value pair to find. - - - - - Copies the key/value pairs in this map to an array. - - The array to copy the entries into. - The index of the array at which to start copying values. - - - - Removes the specified key/value pair from the map. - - Both the key and the value must be found for the entry to be removed. - The key/value pair to remove. - true if the key/value pair was found and removed; false otherwise. - - - - Gets the number of elements contained in the map. - - - - - Gets a value indicating whether the map is read-only. - - - - - Determines whether the specified , is equal to this instance. - - The to compare with this instance. - - true if the specified is equal to this instance; otherwise, false. - - - - - Returns a hash code for this instance. - - - A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. - - - - - Compares this map with another for equality. - - - The order of the key/value pairs in the maps is not deemed significant in this comparison. - - The map to compare this with. - true if refers to an equal map; false otherwise. - - - - Adds entries to the map from the given stream. - - - It is assumed that the stream is initially positioned after the tag specified by the codec. - This method will continue reading entries from the stream until the end is reached, or - a different tag is encountered. - - Stream to read from - Codec describing how the key/value pairs are encoded - - - - Writes the contents of this map to the given coded output stream, using the specified codec - to encode each entry. - - The output stream to write to. - The codec to use for each entry. - - - - Calculates the size of this map based on the given entry codec. - - The codec to use to encode each entry. - - - - - Returns a string representation of this repeated field, in the same - way as it would be represented by the default JSON formatter. - - - - - A codec for a specific map field. This contains all the information required to encode and - decode the nested messages. - - - - - Creates a new entry codec based on a separate key codec and value codec, - and the tag to use for each map entry. - - The key codec. - The value codec. - The map tag to use to introduce each map entry. - - - - The tag used in the enclosing message to indicate map entries. - - - - - A mutable message class, used for parsing and serializing. This - delegates the work to a codec, but implements the interface - for interop with and . - This is nested inside Codec as it's tightly coupled to the associated codec, - and it's simpler if it has direct access to all its fields. - - - - - Read-only wrapper around another dictionary. - - - - - The contents of a repeated field: essentially, a collection with some extra - restrictions (no null values) and capabilities (deep cloning). - - - This implementation does not generally prohibit the use of types which are not - supported by Protocol Buffers but nor does it guarantee that all operations will work in such cases. - - The element type of the repeated field. - - - - Creates a deep clone of this repeated field. - - - If the field type is - a message type, each element is also cloned; otherwise, it is - assumed that the field type is primitive (including string and - bytes, both of which are immutable) and so a simple copy is - equivalent to a deep clone. - - A deep clone of this repeated field. - - - - Adds the entries from the given input stream, decoding them with the specified codec. - - The input stream to read from. - The codec to use in order to read each entry. - - - - Calculates the size of this collection based on the given codec. - - The codec to use when encoding each field. - The number of bytes that would be written to a by , - using the same codec. - - - - Writes the contents of this collection to the given , - encoding each value using the specified codec. - - The output stream to write to. - The codec to use when encoding each value. - - - - Adds the specified item to the collection. - - The item to add. - - - - Removes all items from the collection. - - - - - Determines whether this collection contains the given item. - - The item to find. - true if this collection contains the given item; false otherwise. - - - - Copies this collection to the given array. - - The array to copy to. - The first index of the array to copy to. - - - - Removes the specified item from the collection - - The item to remove. - true if the item was found and removed; false otherwise. - - - - Gets the number of elements contained in the collection. - - - - - Gets a value indicating whether the collection is read-only. - - - - - Adds all of the specified values into this collection. - - The values to add to this collection. - - - - Adds all of the specified values into this collection. This method is present to - allow repeated fields to be constructed from queries within collection initializers. - Within non-collection-initializer code, consider using the equivalent - method instead for clarity. - - The values to add to this collection. - - - - Returns an enumerator that iterates through the collection. - - - An enumerator that can be used to iterate through the collection. - - - - - Determines whether the specified , is equal to this instance. - - The to compare with this instance. - - true if the specified is equal to this instance; otherwise, false. - - - - - Returns an enumerator that iterates through a collection. - - - An object that can be used to iterate through the collection. - - - - - Returns a hash code for this instance. - - - A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. - - - - - Compares this repeated field with another for equality. - - The repeated field to compare this with. - true if refers to an equal repeated field; false otherwise. - - - - Returns the index of the given item within the collection, or -1 if the item is not - present. - - The item to find in the collection. - The zero-based index of the item, or -1 if it is not found. - - - - Inserts the given item at the specified index. - - The index at which to insert the item. - The item to insert. - - - - Removes the item at the given index. - - The zero-based index of the item to remove. - - - - Returns a string representation of this repeated field, in the same - way as it would be represented by the default JSON formatter. - - - - - Gets or sets the item at the specified index. - - - The element at the specified index. - - The zero-based index of the element to get or set. - The item at the specified index. - - - - Extension methods for , effectively providing - the familiar members from previous desktop framework versions while - targeting the newer releases, .NET Core etc. - - - - - Returns the public getter of a property, or null if there is no such getter - (either because it's read-only, or the getter isn't public). - - - - - Returns the public setter of a property, or null if there is no such setter - (either because it's write-only, or the setter isn't public). - - - - - Extension methods for in order to provide - backwards compatibility with .NET 3.5 - - - - - Write the contents of the current stream to the destination stream - - - - - Factory methods for . - - - - - Retrieves a codec suitable for a string field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a bytes field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a bool field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an int32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sint32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a fixed32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sfixed32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a uint32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an int64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sint64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a fixed64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sfixed64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a uint64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a float field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a double field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an enum field with the given tag. - - The tag. - A conversion function from to the enum type. - A conversion function from the enum type to . - A codec for the given tag. - - - - Retrieves a codec suitable for a message field with the given tag. - - The tag. - A parser to use for the message type. - A codec for the given tag. - - - - Creates a codec for a wrapper type of a class - which must be string or ByteString. - - - - - Creates a codec for a wrapper type of a struct - which must be Int32, Int64, UInt32, UInt64, - Bool, Single or Double. - - - - - Helper code to create codecs for wrapper types. - - - Somewhat ugly with all the static methods, but the conversions involved to/from nullable types make it - slightly tricky to improve. So long as we keep the public API (ForClassWrapper, ForStructWrapper) in place, - we can refactor later if we come up with something cleaner. - - - - - Returns a field codec which effectively wraps a value of type T in a message. - - - - - - - An encode/decode pair for a single field. This effectively encapsulates - all the information needed to read or write the field value from/to a coded - stream. - - - This class is public and has to be as it is used by generated code, but its public - API is very limited - just what the generated code needs to call directly. - - - - This never writes default values to the stream, and does not address "packedness" - in repeated fields itself, other than to know whether or not the field *should* be packed. - - - - - Returns a delegate to write a value (unconditionally) to a coded output stream. - - - - - Returns the size calculator for just a value. - - - - - Returns a delegate to read a value from a coded input stream. It is assumed that - the stream is already positioned on the appropriate tag. - - - - - Returns the fixed size for an entry, or 0 if sizes vary. - - - - - Gets the tag of the codec. - - - The tag of the codec. - - - - - Default value for this codec. Usually the same for every instance of the same type, but - for string/ByteString wrapper fields the codec's default value is null, whereas for - other string/ByteString fields it's "" or ByteString.Empty. - - - The default value of the codec's type. - - - - - Write a tag and the given value, *if* the value is not the default. - - - - - Reads a value of the codec type from the given . - - The input stream to read from. - The value read from the stream. - - - - Calculates the size required to write the given value, with a tag, - if the value is not the default. - - - - - Class containing helpful workarounds for various platform compatibility - - - - - A message type that has a custom string format for diagnostic purposes. - - - - Calling on a generated message type normally - returns the JSON representation. If a message type implements this interface, - then the method will be called instead of the regular - JSON formatting code, but only when ToString() is called either on the message itself - or on another message which contains it. This does not affect the normal JSON formatting of - the message. - - - For example, if you create a proto message representing a GUID, the internal - representation may be a bytes field or four fixed32 fields. However, when debugging - it may be more convenient to see a result in the same format as provides. - - This interface extends to avoid it accidentally being implemented - on types other than messages, where it would not be used by anything in the framework. - - - - - Returns a string representation of this object, for diagnostic purposes. - - - This method is called when a message is formatted as part of a - call. It does not affect the JSON representation used by other than - in calls to . While it is recommended - that the result is valid JSON, this is never assumed by the Protobuf library. - - A string representation of this object, for diagnostic purposes. - - - - Generic interface for a deeply cloneable type. - - - - All generated messages implement this interface, but so do some non-message types. - Additionally, due to the type constraint on T in , - it is simpler to keep this as a separate interface. - - - The type itself, returned by the method. - - - - Creates a deep clone of this object. - - A deep clone of this object. - - - - Interface for a Protocol Buffers message, supporting - basic operations required for serialization. - - - - - Merges the data from the specified coded input stream with the current message. - - See the user guide for precise merge semantics. - - - - - Writes the data to the given coded output stream. - - Coded output stream to write the data to. Must not be null. - - - - Calculates the size of this message in Protocol Buffer wire format, in bytes. - - The number of bytes required to write this message - to a coded output stream. - - - - Descriptor for this message. All instances are expected to return the same descriptor, - and for generated types this will be an explicitly-implemented member, returning the - same value as the static property declared on the type. - - - - - Generic interface for a Protocol Buffers message, - where the type parameter is expected to be the same type as - the implementation class. - - The message type. - - - - Merges the given message into this one. - - See the user guide for precise merge semantics. - The message to merge with this one. Must not be null. - - - - Thrown when an attempt is made to parse invalid JSON, e.g. using - a non-string property key, or including a redundant comma. Parsing a protocol buffer - message represented in JSON using can throw both this - exception and depending on the situation. This - exception is only thrown for "pure JSON" errors, whereas InvalidProtocolBufferException - is thrown when the JSON may be valid in and of itself, but cannot be parsed as a protocol buffer - message. - - - - - Thrown when a protocol message being parsed is invalid in some way, - e.g. it contains a malformed varint or a negative byte length. - - - - - Creates an exception for an error condition of an invalid tag being encountered. - - - - - Reflection-based converter from messages to JSON. - - - - Instances of this class are thread-safe, with no mutable state. - - - This is a simple start to get JSON formatting working. As it's reflection-based, - it's not as quick as baking calls into generated messages - but is a simpler implementation. - (This code is generally not heavily optimized.) - - - - - - Returns a formatter using the default settings. - - - - - The JSON representation of the first 160 characters of Unicode. - Empty strings are replaced by the static constructor. - - - - - Creates a new formatted with the given settings. - - The settings. - - - - Formats the specified message as JSON. - - The message to format. - The formatted message. - - - - Formats the specified message as JSON. - - The message to format. - The TextWriter to write the formatted message to. - The formatted message. - - - - Converts a message to JSON for diagnostic purposes with no extra context. - - - - This differs from calling on the default JSON - formatter in its handling of . As no type registry is available - in calls, the normal way of resolving the type of - an Any message cannot be applied. Instead, a JSON property named @value - is included with the base64 data from the property of the message. - - The value returned by this method is only designed to be used for diagnostic - purposes. It may not be parsable by , and may not be parsable - by other Protocol Buffer implementations. - - The message to format for diagnostic purposes. - The diagnostic-only JSON representation of the message - - - - Writes a single value to the given writer as JSON. Only types understood by - Protocol Buffers can be written in this way. This method is only exposed for - advanced use cases; most users should be using - or . - - The writer to write the value to. Must not be null. - The value to write. May be null. - - - - Central interception point for well-known type formatting. Any well-known types which - don't need special handling can fall back to WriteMessage. We avoid assuming that the - values are using the embedded well-known types, in order to allow for dynamic messages - in the future. - - - - - Writes a string (including leading and trailing double quotes) to a builder, escaping as required. - - - Other than surrogate pair handling, this code is mostly taken from src/google/protobuf/util/internal/json_escaping.cc. - - - - - Settings controlling JSON formatting. - - - - - Default settings, as used by - - - - - Whether fields whose values are the default for the field type (e.g. 0 for integers) - should be formatted (true) or omitted (false). - - - - - The type registry used to format messages. - - - - - Whether to format enums as ints. Defaults to false. - - - - - Creates a new object with the specified formatting of default values - and an empty type registry. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - - - - Creates a new object with the specified formatting of default values - and type registry. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - The to use when formatting messages. - - - - Creates a new object with the specified parameters. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - The to use when formatting messages. TypeRegistry.Empty will be used if it is null. - true to format the enums as integers; false to format enums as enum names. - - - - Creates a new object with the specified formatting of default values and the current settings. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - - - - Creates a new object with the specified type registry and the current settings. - - The to use when formatting messages. - - - - Creates a new object with the specified enums formatting option and the current settings. - - true to format the enums as integers; false to format enums as enum names. - - - - Reflection-based converter from JSON to messages. - - - - Instances of this class are thread-safe, with no mutable state. - - - This is a simple start to get JSON parsing working. As it's reflection-based, - it's not as quick as baking calls into generated messages - but is a simpler implementation. - (This code is generally not heavily optimized.) - - - - - - Returns a formatter using the default settings. - - - - - Creates a new formatted with the given settings. - - The settings. - - - - Parses and merges the information into the given message. - - The message to merge the JSON information into. - The JSON to parse. - - - - Parses JSON read from and merges the information into the given message. - - The message to merge the JSON information into. - Reader providing the JSON to parse. - - - - Merges the given message using data from the given tokenizer. In most cases, the next - token should be a "start object" token, but wrapper types and nullity can invalidate - that assumption. This is implemented as an LL(1) recursive descent parser over the stream - of tokens provided by the tokenizer. This token stream is assumed to be valid JSON, with the - tokenizer performing that validation - but not every token stream is valid "protobuf JSON". - - - - - Parses into a new message. - - The type of message to create. - The JSON to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Parses JSON read from into a new message. - - The type of message to create. - Reader providing the JSON to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Parses into a new message. - - The JSON to parse. - Descriptor of message type to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Parses JSON read from into a new message. - - Reader providing the JSON to parse. - Descriptor of message type to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Creates a new instance of the message type for the given field. - - - - - Checks that any infinite/NaN values originated from the correct text. - This corrects the lenient whitespace handling of double.Parse/float.Parse, as well as the - way that Mono parses out-of-range values as infinity. - - - - - Settings controlling JSON parsing. - - - - - Default settings, as used by . This has the same default - recursion limit as , and an empty type registry. - - - - - The maximum depth of messages to parse. Note that this limit only applies to parsing - messages, not collections - so a message within a collection within a message only counts as - depth 2, not 3. - - - - - The type registry used to parse messages. - - - - - Creates a new object with the specified recursion limit. - - The maximum depth of messages to parse - - - - Creates a new object with the specified recursion limit and type registry. - - The maximum depth of messages to parse - The type registry used to parse messages - - - - Simple but strict JSON tokenizer, rigidly following RFC 7159. - - - - This tokenizer is stateful, and only returns "useful" tokens - names, values etc. - It does not create tokens for the separator between names and values, or for the comma - between values. It validates the token stream as it goes - so callers can assume that the - tokens it produces are appropriate. For example, it would never produce "start object, end array." - - Implementation details: the base class handles single token push-back and - Not thread-safe. - - - - - Creates a tokenizer that reads from the given text reader. - - - - - Creates a tokenizer that first replays the given list of tokens, then continues reading - from another tokenizer. Note that if the returned tokenizer is "pushed back", that does not push back - on the continuation tokenizer, or vice versa. Care should be taken when using this method - it was - created for the sake of Any parsing. - - - - - Returns the depth of the stack, purely in objects (not collections). - Informally, this is the number of remaining unclosed '{' characters we have. - - - - - Returns the next JSON token in the stream. An EndDocument token is returned to indicate the end of the stream, - after which point Next() should not be called again. - - This implementation provides single-token buffering, and calls if there is no buffered token. - The next token in the stream. This is never null. - This method is called after an EndDocument token has been returned - The input text does not comply with RFC 7159 - - - - Returns the next JSON token in the stream, when requested by the base class. (The method delegates - to this if it doesn't have a buffered token.) - - This method is called after an EndDocument token has been returned - The input text does not comply with RFC 7159 - - - - Tokenizer which first exhausts a list of tokens, then consults another tokenizer. - - - - - Tokenizer which does all the *real* work of parsing JSON. - - - - - This method essentially just loops through characters skipping whitespace, validating and - changing state (e.g. from ObjectBeforeColon to ObjectAfterColon) - until it reaches something which will be a genuine token (e.g. a start object, or a value) at which point - it returns the token. Although the method is large, it would be relatively hard to break down further... most - of it is the large switch statement, which sometimes returns and sometimes doesn't. - - - - - Reads a string token. It is assumed that the opening " has already been read. - - - - - Reads an escaped character. It is assumed that the leading backslash has already been read. - - - - - Reads an escaped Unicode 4-nybble hex sequence. It is assumed that the leading \u has already been read. - - - - - Consumes a text-only literal, throwing an exception if the read text doesn't match it. - It is assumed that the first letter of the literal has already been read. - - - - - Validates that we're in a valid state to read a value (using the given error prefix if necessary) - and changes the state to the appropriate one, e.g. ObjectAfterColon to ObjectAfterProperty. - - - - - Pops the top-most container, and sets the state to the appropriate one for the end of a value - in the parent container. - - - - - Possible states of the tokenizer. - - - This is a flags enum purely so we can simply and efficiently represent a set of valid states - for checking. - - Each is documented with an example, - where ^ represents the current position within the text stream. The examples all use string values, - but could be any value, including nested objects/arrays. - The complete state of the tokenizer also includes a stack to indicate the contexts (arrays/objects). - Any additional notional state of "AfterValue" indicates that a value has been completed, at which - point there's an immediate transition to ExpectedEndOfDocument, ObjectAfterProperty or ArrayAfterValue. - - - These states were derived manually by reading RFC 7159 carefully. - - - - - - ^ { "foo": "bar" } - Before the value in a document. Next states: ObjectStart, ArrayStart, "AfterValue" - - - - - { "foo": "bar" } ^ - After the value in a document. Next states: ReaderExhausted - - - - - { "foo": "bar" } ^ (and already read to the end of the reader) - Terminal state. - - - - - { ^ "foo": "bar" } - Before the *first* property in an object. - Next states: - "AfterValue" (empty object) - ObjectBeforeColon (read a name) - - - - - { "foo" ^ : "bar", "x": "y" } - Next state: ObjectAfterColon - - - - - { "foo" : ^ "bar", "x": "y" } - Before any property other than the first in an object. - (Equivalently: after any property in an object) - Next states: - "AfterValue" (value is simple) - ObjectStart (value is object) - ArrayStart (value is array) - - - - - { "foo" : "bar" ^ , "x" : "y" } - At the end of a property, so expecting either a comma or end-of-object - Next states: ObjectAfterComma or "AfterValue" - - - - - { "foo":"bar", ^ "x":"y" } - Read the comma after the previous property, so expecting another property. - This is like ObjectStart, but closing brace isn't valid here - Next state: ObjectBeforeColon. - - - - - [ ^ "foo", "bar" ] - Before the *first* value in an array. - Next states: - "AfterValue" (read a value) - "AfterValue" (end of array; will pop stack) - - - - - [ "foo" ^ , "bar" ] - After any value in an array, so expecting either a comma or end-of-array - Next states: ArrayAfterComma or "AfterValue" - - - - - [ "foo", ^ "bar" ] - After a comma in an array, so there *must* be another value (simple or complex). - Next states: "AfterValue" (simple value), StartObject, StartArray - - - - - Wrapper around a text reader allowing small amounts of buffering and location handling. - - - - - The buffered next character, if we have one. - - - - - Returns the next character in the stream, or null if we have reached the end. - - - - - - Creates a new exception appropriate for the current state of the reader. - - - - - Stream implementation which proxies another stream, only allowing a certain amount - of data to be read. Note that this is only used to read delimited streams, so it - doesn't attempt to implement everything. - - - - - Extension methods on and . - - - - - Merges data from the given byte array into an existing message. - - The message to merge the data into. - The data to merge, which must be protobuf-encoded binary data. - - - - Merges data from the given byte string into an existing message. - - The message to merge the data into. - The data to merge, which must be protobuf-encoded binary data. - - - - Merges data from the given stream into an existing message. - - The message to merge the data into. - Stream containing the data to merge, which must be protobuf-encoded binary data. - - - - Merges length-delimited data from the given stream into an existing message. - - - The stream is expected to contain a length and then the data. Only the amount of data - specified by the length will be consumed. - - The message to merge the data into. - Stream containing the data to merge, which must be protobuf-encoded binary data. - - - - Converts the given message into a byte array in protobuf encoding. - - The message to convert. - The message data as a byte array. - - - - Writes the given message data to the given stream in protobuf encoding. - - The message to write to the stream. - The stream to write to. - - - - Writes the length and then data of the given message to a stream. - - The message to write. - The output stream to write to. - - - - Converts the given message into a byte string in protobuf encoding. - - The message to convert. - The message data as a byte string. - - - - A general message parser, typically used by reflection-based code as all the methods - return simple . - - - - - Creates a template instance ready for population. - - An empty message. - - - - Parses a message from a byte array. - - The byte array containing the message. Must not be null. - The newly parsed message. - - - - Parses a message from the given byte string. - - The data to parse. - The parsed message. - - - - Parses a message from the given stream. - - The stream to parse. - The parsed message. - - - - Parses a length-delimited message from the given stream. - - - The stream is expected to contain a length and then the data. Only the amount of data - specified by the length will be consumed. - - The stream to parse. - The parsed message. - - - - Parses a message from the given coded input stream. - - The stream to parse. - The parsed message. - - - - Parses a message from the given JSON. - - The JSON to parse. - The parsed message. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - A parser for a specific message type. - - -

- This delegates most behavior to the - implementation within the original type, but - provides convenient overloads to parse from a variety of sources. -

-

- Most applications will never need to create their own instances of this type; - instead, use the static Parser property of a generated message type to obtain a - parser for that type. -

-
- The type of message to be parsed. -
- - - Creates a new parser. - - - The factory method is effectively an optimization over using a generic constraint - to require a parameterless constructor: delegates are significantly faster to execute. - - Function to invoke when a new, empty message is required. - - - - Creates a template instance ready for population. - - An empty message. - - - - Parses a message from a byte array. - - The byte array containing the message. Must not be null. - The newly parsed message. - - - - Parses a message from the given byte string. - - The data to parse. - The parsed message. - - - - Parses a message from the given stream. - - The stream to parse. - The parsed message. - - - - Parses a length-delimited message from the given stream. - - - The stream is expected to contain a length and then the data. Only the amount of data - specified by the length will be consumed. - - The stream to parse. - The parsed message. - - - - Parses a message from the given coded input stream. - - The stream to parse. - The parsed message. - - - - Parses a message from the given JSON. - - The JSON to parse. - The parsed message. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Helper methods for throwing exceptions when preconditions are not met. - - - This class is used internally and by generated code; it is not particularly - expected to be used from application code, although nothing prevents it - from being used that way. - - - - - Throws an ArgumentNullException if the given value is null, otherwise - return the value to the caller. - - - - - Throws an ArgumentNullException if the given value is null, otherwise - return the value to the caller. - - - This is equivalent to but without the type parameter - constraint. In most cases, the constraint is useful to prevent you from calling CheckNotNull - with a value type - but it gets in the way if either you want to use it with a nullable - value type, or you want to use it with an unconstrained type parameter. - - - - - Container for a set of custom options specified within a message, field etc. - - - - This type is publicly immutable, but internally mutable. It is only populated - by the descriptor parsing code - by the time any user code is able to see an instance, - it will be fully initialized. - - - If an option is requested using the incorrect method, an answer may still be returned: all - of the numeric types are represented internally using 64-bit integers, for example. It is up to - the caller to ensure that they make the appropriate method call for the option they're interested in. - Note that enum options are simply stored as integers, so the value should be fetched using - and then cast appropriately. - - - Repeated options are currently not supported. Asking for a single value of an option - which was actually repeated will return the last value, except for message types where - all the set values are merged together. - - - - - - Singleton for all descriptors with an empty set of options. - - - - - A sequence of values per field. This needs to be per field rather than per tag to allow correct deserialization - of repeated fields which could be "int, ByteString, int" - unlikely as that is. The fact that values are boxed - is unfortunate; we might be able to use a struct instead, and we could combine uint and ulong values. - - - - - Retrieves a Boolean value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 32-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 64-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 32-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 64-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 32-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 64-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 32-bit integer value for the specified option field, - assuming a zigzag encoding. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 64-bit integer value for the specified option field, - assuming a zigzag encoding. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 32-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 64-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a 32-bit floating point value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a 64-bit floating point value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a string value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a bytes value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a message value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Reads an unknown field, either parsing it and storing it or skipping it. - - - If the current set of options is empty and we manage to read a field, a new set of options - will be created and returned. Otherwise, the return value is this. This allows - us to start with a singleton empty set of options and just create new ones where necessary. - - Input stream to read from. - The resulting set of custom options, either this or a new set. - - - - All field values can be stored as a byte string or a 64-bit integer. - This struct avoids unnecessary boxing. - - - - Holder for reflection information generated from google/protobuf/descriptor.proto - - - File descriptor for google/protobuf/descriptor.proto - - - - The protocol compiler can output a FileDescriptorSet containing the .proto - files it parses. - - - - Field number for the "file" field. - - - - Describes a complete .proto file. - - - - Field number for the "name" field. - - - - file name, relative to root of source tree - - - - Field number for the "package" field. - - - - e.g. "foo", "foo.bar", etc. - - - - Field number for the "dependency" field. - - - - Names of files imported by this file. - - - - Field number for the "public_dependency" field. - - - - Indexes of the public imported files in the dependency list above. - - - - Field number for the "weak_dependency" field. - - - - Indexes of the weak imported files in the dependency list. - For Google-internal migration only. Do not use. - - - - Field number for the "message_type" field. - - - - All top-level definitions in this file. - - - - Field number for the "enum_type" field. - - - Field number for the "service" field. - - - Field number for the "extension" field. - - - Field number for the "options" field. - - - Field number for the "source_code_info" field. - - - - This field contains optional information about the original source code. - You may safely remove this entire field without harming runtime - functionality of the descriptors -- the information is needed only by - development tools. - - - - Field number for the "syntax" field. - - - - The syntax of the proto file. - The supported values are "proto2" and "proto3". - - - - - Describes a message type. - - - - Field number for the "name" field. - - - Field number for the "field" field. - - - Field number for the "extension" field. - - - Field number for the "nested_type" field. - - - Field number for the "enum_type" field. - - - Field number for the "extension_range" field. - - - Field number for the "oneof_decl" field. - - - Field number for the "options" field. - - - Field number for the "reserved_range" field. - - - Field number for the "reserved_name" field. - - - - Reserved field names, which may not be used by fields in the same message. - A given name may only be reserved once. - - - - Container for nested types declared in the DescriptorProto message type. - - - Field number for the "start" field. - - - Field number for the "end" field. - - - - Range of reserved tag numbers. Reserved tag numbers may not be used by - fields or extension ranges in the same message. Reserved ranges may - not overlap. - - - - Field number for the "start" field. - - - - Inclusive. - - - - Field number for the "end" field. - - - - Exclusive. - - - - - Describes a field within a message. - - - - Field number for the "name" field. - - - Field number for the "number" field. - - - Field number for the "label" field. - - - Field number for the "type" field. - - - - If type_name is set, this need not be set. If both this and type_name - are set, this must be one of TYPE_ENUM, TYPE_MESSAGE or TYPE_GROUP. - - - - Field number for the "type_name" field. - - - - For message and enum types, this is the name of the type. If the name - starts with a '.', it is fully-qualified. Otherwise, C++-like scoping - rules are used to find the type (i.e. first the nested types within this - message are searched, then within the parent, on up to the root - namespace). - - - - Field number for the "extendee" field. - - - - For extensions, this is the name of the type being extended. It is - resolved in the same manner as type_name. - - - - Field number for the "default_value" field. - - - - For numeric types, contains the original text representation of the value. - For booleans, "true" or "false". - For strings, contains the default text contents (not escaped in any way). - For bytes, contains the C escaped value. All bytes >= 128 are escaped. - TODO(kenton): Base-64 encode? - - - - Field number for the "oneof_index" field. - - - - If set, gives the index of a oneof in the containing type's oneof_decl - list. This field is a member of that oneof. - - - - Field number for the "json_name" field. - - - - JSON name of this field. The value is set by protocol compiler. If the - user has set a "json_name" option on this field, that option's value - will be used. Otherwise, it's deduced from the field's name by converting - it to camelCase. - - - - Field number for the "options" field. - - - Container for nested types declared in the FieldDescriptorProto message type. - - - - 0 is reserved for errors. - Order is weird for historical reasons. - - - - - Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT64 if - negative values are likely. - - - - - Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT32 if - negative values are likely. - - - - - Tag-delimited aggregate. - Group type is deprecated and not supported in proto3. However, Proto3 - implementations should still be able to parse the group wire format and - treat group fields as unknown fields. - - - - - Length-delimited aggregate. - - - - - New in version 2. - - - - - Uses ZigZag encoding. - - - - - Uses ZigZag encoding. - - - - - 0 is reserved for errors - - - - - Describes a oneof. - - - - Field number for the "name" field. - - - Field number for the "options" field. - - - - Describes an enum type. - - - - Field number for the "name" field. - - - Field number for the "value" field. - - - Field number for the "options" field. - - - - Describes a value within an enum. - - - - Field number for the "name" field. - - - Field number for the "number" field. - - - Field number for the "options" field. - - - - Describes a service. - - - - Field number for the "name" field. - - - Field number for the "method" field. - - - Field number for the "options" field. - - - - Describes a method of a service. - - - - Field number for the "name" field. - - - Field number for the "input_type" field. - - - - Input and output type names. These are resolved in the same way as - FieldDescriptorProto.type_name, but must refer to a message type. - - - - Field number for the "output_type" field. - - - Field number for the "options" field. - - - Field number for the "client_streaming" field. - - - - Identifies if client streams multiple client messages - - - - Field number for the "server_streaming" field. - - - - Identifies if server streams multiple server messages - - - - Field number for the "java_package" field. - - - - Sets the Java package where classes generated from this .proto will be - placed. By default, the proto package is used, but this is often - inappropriate because proto packages do not normally start with backwards - domain names. - - - - Field number for the "java_outer_classname" field. - - - - If set, all the classes from the .proto file are wrapped in a single - outer class with the given name. This applies to both Proto1 - (equivalent to the old "--one_java_file" option) and Proto2 (where - a .proto always translates to a single class, but you may want to - explicitly choose the class name). - - - - Field number for the "java_multiple_files" field. - - - - If set true, then the Java code generator will generate a separate .java - file for each top-level message, enum, and service defined in the .proto - file. Thus, these types will *not* be nested inside the outer class - named by java_outer_classname. However, the outer class will still be - generated to contain the file's getDescriptor() method as well as any - top-level extensions defined in the file. - - - - Field number for the "java_generate_equals_and_hash" field. - - - - This option does nothing. - - - - Field number for the "java_string_check_utf8" field. - - - - If set true, then the Java2 code generator will generate code that - throws an exception whenever an attempt is made to assign a non-UTF-8 - byte sequence to a string field. - Message reflection will do the same. - However, an extension field still accepts non-UTF-8 byte sequences. - This option has no effect on when used with the lite runtime. - - - - Field number for the "optimize_for" field. - - - Field number for the "go_package" field. - - - - Sets the Go package where structs generated from this .proto will be - placed. If omitted, the Go package will be derived from the following: - - The basename of the package import path, if provided. - - Otherwise, the package statement in the .proto file, if present. - - Otherwise, the basename of the .proto file, without extension. - - - - Field number for the "cc_generic_services" field. - - - - Should generic services be generated in each language? "Generic" services - are not specific to any particular RPC system. They are generated by the - main code generators in each language (without additional plugins). - Generic services were the only kind of service generation supported by - early versions of google.protobuf. - - Generic services are now considered deprecated in favor of using plugins - that generate code specific to your particular RPC system. Therefore, - these default to false. Old code which depends on generic services should - explicitly set them to true. - - - - Field number for the "java_generic_services" field. - - - Field number for the "py_generic_services" field. - - - Field number for the "deprecated" field. - - - - Is this file deprecated? - Depending on the target platform, this can emit Deprecated annotations - for everything in the file, or it will be completely ignored; in the very - least, this is a formalization for deprecating files. - - - - Field number for the "cc_enable_arenas" field. - - - - Enables the use of arenas for the proto messages in this file. This applies - only to generated classes for C++. - - - - Field number for the "objc_class_prefix" field. - - - - Sets the objective c class prefix which is prepended to all objective c - generated classes from this .proto. There is no default. - - - - Field number for the "csharp_namespace" field. - - - - Namespace for generated classes; defaults to the package. - - - - Field number for the "swift_prefix" field. - - - - By default Swift generators will take the proto package and CamelCase it - replacing '.' with underscore and use that to prefix the types/symbols - defined. When this options is provided, they will use this value instead - to prefix the types/symbols defined. - - - - Field number for the "php_class_prefix" field. - - - - Sets the php class prefix which is prepended to all php generated classes - from this .proto. Default is empty. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Container for nested types declared in the FileOptions message type. - - - - Generated classes can be optimized for speed or code size. - - - - - Generate complete code for parsing, serialization, - - - - - etc. - - - - - Generate code using MessageLite and the lite runtime. - - - - Field number for the "message_set_wire_format" field. - - - - Set true to use the old proto1 MessageSet wire format for extensions. - This is provided for backwards-compatibility with the MessageSet wire - format. You should not use this for any other reason: It's less - efficient, has fewer features, and is more complicated. - - The message must be defined exactly as follows: - message Foo { - option message_set_wire_format = true; - extensions 4 to max; - } - Note that the message cannot have any defined fields; MessageSets only - have extensions. - - All extensions of your type must be singular messages; e.g. they cannot - be int32s, enums, or repeated messages. - - Because this is an option, the above two restrictions are not enforced by - the protocol compiler. - - - - Field number for the "no_standard_descriptor_accessor" field. - - - - Disables the generation of the standard "descriptor()" accessor, which can - conflict with a field of the same name. This is meant to make migration - from proto1 easier; new code should avoid fields named "descriptor". - - - - Field number for the "deprecated" field. - - - - Is this message deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the message, or it will be completely ignored; in the very least, - this is a formalization for deprecating messages. - - - - Field number for the "map_entry" field. - - - - Whether the message is an automatically generated map entry type for the - maps field. - - For maps fields: - map<KeyType, ValueType> map_field = 1; - The parsed descriptor looks like: - message MapFieldEntry { - option map_entry = true; - optional KeyType key = 1; - optional ValueType value = 2; - } - repeated MapFieldEntry map_field = 1; - - Implementations may choose not to generate the map_entry=true message, but - use a native map in the target language to hold the keys and values. - The reflection APIs in such implementions still need to work as - if the field is a repeated message field. - - NOTE: Do not set the option in .proto files. Always use the maps syntax - instead. The option should only be implicitly set by the proto compiler - parser. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "ctype" field. - - - - The ctype option instructs the C++ code generator to use a different - representation of the field than it normally would. See the specific - options below. This option is not yet implemented in the open source - release -- sorry, we'll try to include it in a future version! - - - - Field number for the "packed" field. - - - - The packed option can be enabled for repeated primitive fields to enable - a more efficient representation on the wire. Rather than repeatedly - writing the tag and type for each element, the entire array is encoded as - a single length-delimited blob. In proto3, only explicit setting it to - false will avoid using packed encoding. - - - - Field number for the "jstype" field. - - - - The jstype option determines the JavaScript type used for values of the - field. The option is permitted only for 64 bit integral and fixed types - (int64, uint64, sint64, fixed64, sfixed64). By default these types are - represented as JavaScript strings. This avoids loss of precision that can - happen when a large value is converted to a floating point JavaScript - numbers. Specifying JS_NUMBER for the jstype causes the generated - JavaScript code to use the JavaScript "number" type instead of strings. - This option is an enum to permit additional types to be added, - e.g. goog.math.Integer. - - - - Field number for the "lazy" field. - - - - Should this field be parsed lazily? Lazy applies only to message-type - fields. It means that when the outer message is initially parsed, the - inner message's contents will not be parsed but instead stored in encoded - form. The inner message will actually be parsed when it is first accessed. - - This is only a hint. Implementations are free to choose whether to use - eager or lazy parsing regardless of the value of this option. However, - setting this option true suggests that the protocol author believes that - using lazy parsing on this field is worth the additional bookkeeping - overhead typically needed to implement it. - - This option does not affect the public interface of any generated code; - all method signatures remain the same. Furthermore, thread-safety of the - interface is not affected by this option; const methods remain safe to - call from multiple threads concurrently, while non-const methods continue - to require exclusive access. - - Note that implementations may choose not to check required fields within - a lazy sub-message. That is, calling IsInitialized() on the outer message - may return true even if the inner message has missing required fields. - This is necessary because otherwise the inner message would have to be - parsed in order to perform the check, defeating the purpose of lazy - parsing. An implementation which chooses not to check required fields - must be consistent about it. That is, for any particular sub-message, the - implementation must either *always* check its required fields, or *never* - check its required fields, regardless of whether or not the message has - been parsed. - - - - Field number for the "deprecated" field. - - - - Is this field deprecated? - Depending on the target platform, this can emit Deprecated annotations - for accessors, or it will be completely ignored; in the very least, this - is a formalization for deprecating fields. - - - - Field number for the "weak" field. - - - - For Google-internal migration only. Do not use. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Container for nested types declared in the FieldOptions message type. - - - - Default mode. - - - - - Use the default type. - - - - - Use JavaScript strings. - - - - - Use JavaScript numbers. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "allow_alias" field. - - - - Set this option to true to allow mapping different tag names to the same - value. - - - - Field number for the "deprecated" field. - - - - Is this enum deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the enum, or it will be completely ignored; in the very least, this - is a formalization for deprecating enums. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "deprecated" field. - - - - Is this enum value deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the enum value, or it will be completely ignored; in the very least, - this is a formalization for deprecating enum values. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "deprecated" field. - - - - Is this service deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the service, or it will be completely ignored; in the very least, - this is a formalization for deprecating services. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "deprecated" field. - - - - Is this method deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the method, or it will be completely ignored; in the very least, - this is a formalization for deprecating methods. - - - - Field number for the "idempotency_level" field. - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Container for nested types declared in the MethodOptions message type. - - - - Is this method side-effect-free (or safe in HTTP parlance), or idempotent, - or neither? HTTP based RPC implementation may choose GET verb for safe - methods, and PUT verb for idempotent methods instead of the default POST. - - - - - implies idempotent - - - - - idempotent, but may have side effects - - - - - A message representing a option the parser does not recognize. This only - appears in options protos created by the compiler::Parser class. - DescriptorPool resolves these when building Descriptor objects. Therefore, - options protos in descriptor objects (e.g. returned by Descriptor::options(), - or produced by Descriptor::CopyTo()) will never have UninterpretedOptions - in them. - - - - Field number for the "name" field. - - - Field number for the "identifier_value" field. - - - - The value of the uninterpreted option, in whatever type the tokenizer - identified it as during parsing. Exactly one of these should be set. - - - - Field number for the "positive_int_value" field. - - - Field number for the "negative_int_value" field. - - - Field number for the "double_value" field. - - - Field number for the "string_value" field. - - - Field number for the "aggregate_value" field. - - - Container for nested types declared in the UninterpretedOption message type. - - - - The name of the uninterpreted option. Each string represents a segment in - a dot-separated name. is_extension is true iff a segment represents an - extension (denoted with parentheses in options specs in .proto files). - E.g.,{ ["foo", false], ["bar.baz", true], ["qux", false] } represents - "foo.(bar.baz).qux". - - - - Field number for the "name_part" field. - - - Field number for the "is_extension" field. - - - - Encapsulates information about the original source file from which a - FileDescriptorProto was generated. - - - - Field number for the "location" field. - - - - A Location identifies a piece of source code in a .proto file which - corresponds to a particular definition. This information is intended - to be useful to IDEs, code indexers, documentation generators, and similar - tools. - - For example, say we have a file like: - message Foo { - optional string foo = 1; - } - Let's look at just the field definition: - optional string foo = 1; - ^ ^^ ^^ ^ ^^^ - a bc de f ghi - We have the following locations: - span path represents - [a,i) [ 4, 0, 2, 0 ] The whole field definition. - [a,b) [ 4, 0, 2, 0, 4 ] The label (optional). - [c,d) [ 4, 0, 2, 0, 5 ] The type (string). - [e,f) [ 4, 0, 2, 0, 1 ] The name (foo). - [g,h) [ 4, 0, 2, 0, 3 ] The number (1). - - Notes: - - A location may refer to a repeated field itself (i.e. not to any - particular index within it). This is used whenever a set of elements are - logically enclosed in a single code segment. For example, an entire - extend block (possibly containing multiple extension definitions) will - have an outer location whose path refers to the "extensions" repeated - field without an index. - - Multiple locations may have the same path. This happens when a single - logical declaration is spread out across multiple places. The most - obvious example is the "extend" block again -- there may be multiple - extend blocks in the same scope, each of which will have the same path. - - A location's span is not always a subset of its parent's span. For - example, the "extendee" of an extension declaration appears at the - beginning of the "extend" block and is shared by all extensions within - the block. - - Just because a location's span is a subset of some other location's span - does not mean that it is a descendent. For example, a "group" defines - both a type and a field in a single declaration. Thus, the locations - corresponding to the type and field and their components will overlap. - - Code which tries to interpret locations should probably be designed to - ignore those that it doesn't understand, as more types of locations could - be recorded in the future. - - - - Container for nested types declared in the SourceCodeInfo message type. - - - Field number for the "path" field. - - - - Identifies which part of the FileDescriptorProto was defined at this - location. - - Each element is a field number or an index. They form a path from - the root FileDescriptorProto to the place where the definition. For - example, this path: - [ 4, 3, 2, 7, 1 ] - refers to: - file.message_type(3) // 4, 3 - .field(7) // 2, 7 - .name() // 1 - This is because FileDescriptorProto.message_type has field number 4: - repeated DescriptorProto message_type = 4; - and DescriptorProto.field has field number 2: - repeated FieldDescriptorProto field = 2; - and FieldDescriptorProto.name has field number 1: - optional string name = 1; - - Thus, the above path gives the location of a field name. If we removed - the last element: - [ 4, 3, 2, 7 ] - this path refers to the whole field declaration (from the beginning - of the label to the terminating semicolon). - - - - Field number for the "span" field. - - - - Always has exactly three or four elements: start line, start column, - end line (optional, otherwise assumed same as start line), end column. - These are packed into a single field for efficiency. Note that line - and column numbers are zero-based -- typically you will want to add - 1 to each before displaying to a user. - - - - Field number for the "leading_comments" field. - - - - If this SourceCodeInfo represents a complete declaration, these are any - comments appearing before and after the declaration which appear to be - attached to the declaration. - - A series of line comments appearing on consecutive lines, with no other - tokens appearing on those lines, will be treated as a single comment. - - leading_detached_comments will keep paragraphs of comments that appear - before (but not connected to) the current element. Each paragraph, - separated by empty lines, will be one comment element in the repeated - field. - - Only the comment content is provided; comment markers (e.g. //) are - stripped out. For block comments, leading whitespace and an asterisk - will be stripped from the beginning of each line other than the first. - Newlines are included in the output. - - Examples: - - optional int32 foo = 1; // Comment attached to foo. - // Comment attached to bar. - optional int32 bar = 2; - - optional string baz = 3; - // Comment attached to baz. - // Another line attached to baz. - - // Comment attached to qux. - // - // Another line attached to qux. - optional double qux = 4; - - // Detached comment for corge. This is not leading or trailing comments - // to qux or corge because there are blank lines separating it from - // both. - - // Detached comment for corge paragraph 2. - - optional string corge = 5; - /* Block comment attached - * to corge. Leading asterisks - * will be removed. */ - /* Block comment attached to - * grault. */ - optional int32 grault = 6; - - // ignored detached comments. - - - - Field number for the "trailing_comments" field. - - - Field number for the "leading_detached_comments" field. - - - - Describes the relationship between generated code and its original source - file. A GeneratedCodeInfo message is associated with only one generated - source file, but may contain references to different source .proto files. - - - - Field number for the "annotation" field. - - - - An Annotation connects some span of text in generated code to an element - of its generating .proto file. - - - - Container for nested types declared in the GeneratedCodeInfo message type. - - - Field number for the "path" field. - - - - Identifies the element in the original source .proto file. This field - is formatted the same as SourceCodeInfo.Location.path. - - - - Field number for the "source_file" field. - - - - Identifies the filesystem path to the original source .proto. - - - - Field number for the "begin" field. - - - - Identifies the starting offset in bytes in the generated code - that relates to the identified object. - - - - Field number for the "end" field. - - - - Identifies the ending offset in bytes in the generated code that - relates to the identified offset. The end offset should be one past - the last relevant byte (so the length of the text = end - begin). - - - - - Base class for nearly all descriptors, providing common functionality. - - - - - The index of this descriptor within its parent descriptor. - - - This returns the index of this descriptor within its parent, for - this descriptor's type. (There can be duplicate values for different - types, e.g. one enum type with index 0 and one message type with index 0.) - - - - - Returns the name of the entity (field, message etc) being described. - - - - - The fully qualified name of the descriptor's target. - - - - - The file this descriptor was declared in. - - - - - Contains lookup tables containing all the descriptors defined in a particular file. - - - - - Finds a symbol of the given name within the pool. - - The type of symbol to look for - Fully-qualified name to look up - The symbol with the given name and type, - or null if the symbol doesn't exist or has the wrong type - - - - Adds a package to the symbol tables. If a package by the same name - already exists, that is fine, but if some other kind of symbol - exists under the same name, an exception is thrown. If the package - has multiple components, this also adds the parent package(s). - - - - - Adds a symbol to the symbol table. - - The symbol already existed - in the symbol table. - - - - Verifies that the descriptor's name is valid (i.e. it contains - only letters, digits and underscores, and does not start with a digit). - - - - - - Returns the field with the given number in the given descriptor, - or null if it can't be found. - - - - - Adds a field to the fieldsByNumber table. - - A field with the same - containing type and number already exists. - - - - Adds an enum value to the enumValuesByNumber table. If an enum value - with the same type and number already exists, this method does nothing. - (This is allowed; the first value defined with the number takes precedence.) - - - - - Looks up a descriptor by name, relative to some other descriptor. - The name may be fully-qualified (with a leading '.'), partially-qualified, - or unqualified. C++-like name lookup semantics are used to search for the - matching descriptor. - - - This isn't heavily optimized, but it's only used during cross linking anyway. - If it starts being used more widely, we should look at performance more carefully. - - - - - Struct used to hold the keys for the fieldByNumber table. - - - - - Internal class containing utility methods when working with descriptors. - - - - - Equivalent to Func[TInput, int, TOutput] but usable in .NET 2.0. Only used to convert - arrays. - - - - - Converts the given array into a read-only list, applying the specified conversion to - each input element. - - - - - Thrown when building descriptors fails because the source DescriptorProtos - are not valid. - - - - - The full name of the descriptor where the error occurred. - - - - - A human-readable description of the error. (The Message property - is made up of the descriptor's name and this description.) - - - - - Descriptor for an enum type in a .proto file. - - - - - The brief name of the descriptor's target. - - - - - The CLR type for this enum. For generated code, this will be a CLR enum type. - - - - - If this is a nested type, get the outer descriptor, otherwise null. - - - - - An unmodifiable list of defined value descriptors for this enum. - - - - - Finds an enum value by number. If multiple enum values have the - same number, this returns the first defined value with that number. - If there is no value for the given number, this returns null. - - - - - Finds an enum value by name. - - The unqualified name of the value (e.g. "FOO"). - The value's descriptor, or null if not found. - - - - The (possibly empty) set of custom options for this enum. - - - - - Descriptor for a single enum value within an enum in a .proto file. - - - - - Returns the name of the enum value described by this object. - - - - - Returns the number associated with this enum value. - - - - - Returns the enum descriptor that this value is part of. - - - - - The (possibly empty) set of custom options for this enum value. - - - - - Base class for field accessors. - - - - - Descriptor for a field or extension within a message in a .proto file. - - - - - Get the field's containing message type. - - - - - Returns the oneof containing this field, or null if it is not part of a oneof. - - - - - The effective JSON name for this field. This is usually the lower-camel-cased form of the field name, - but can be overridden using the json_name option in the .proto file. - - - - - The brief name of the descriptor's target. - - - - - Returns the accessor for this field. - - - - While a describes the field, it does not provide - any way of obtaining or changing the value of the field within a specific message; - that is the responsibility of the accessor. - - - The value returned by this property will be non-null for all regular fields. However, - if a message containing a map field is introspected, the list of nested messages will include - an auto-generated nested key/value pair message for the field. This is not represented in any - generated type, and the value of the map field itself is represented by a dictionary in the - reflection API. There are never instances of those "hidden" messages, so no accessor is provided - and this property will return null. - - - - - - Maps a field type as included in the .proto file to a FieldType. - - - - - Returns true if this field is a repeated field; false otherwise. - - - - - Returns true if this field is a map field; false otherwise. - - - - - Returns true if this field is a packed, repeated field; false otherwise. - - - - - Returns the type of the field. - - - - - Returns the field number declared in the proto file. - - - - - Compares this descriptor with another one, ordering in "canonical" order - which simply means ascending order by field number. - must be a field of the same type, i.e. the of - both fields must be the same. - - - - - For enum fields, returns the field's type. - - - - - For embedded message and group fields, returns the field's type. - - - - - The (possibly empty) set of custom options for this field. - - - - - Look up and cross-link all field types etc. - - - - - Enumeration of all the possible field types. - - - - - The double field type. - - - - - The float field type. - - - - - The int64 field type. - - - - - The uint64 field type. - - - - - The int32 field type. - - - - - The fixed64 field type. - - - - - The fixed32 field type. - - - - - The bool field type. - - - - - The string field type. - - - - - The field type used for groups (not supported in this implementation). - - - - - The field type used for message fields. - - - - - The bytes field type. - - - - - The uint32 field type. - - - - - The sfixed32 field type. - - - - - The sfixed64 field type. - - - - - The sint32 field type. - - - - - The sint64 field type. - - - - - The field type used for enum fields. - - - - - Describes a .proto file, including everything defined within. - IDescriptor is implemented such that the File property returns this descriptor, - and the FullName is the same as the Name. - - - - - Computes the full name of a descriptor within this file, with an optional parent message. - - - - - Extracts public dependencies from direct dependencies. This is a static method despite its - first parameter, as the value we're in the middle of constructing is only used for exceptions. - - - - - The descriptor in its protocol message representation. - - - - - The file name. - - - - - The package as declared in the .proto file. This may or may not - be equivalent to the .NET namespace of the generated classes. - - - - - Unmodifiable list of top-level message types declared in this file. - - - - - Unmodifiable list of top-level enum types declared in this file. - - - - - Unmodifiable list of top-level services declared in this file. - - - - - Unmodifiable list of this file's dependencies (imports). - - - - - Unmodifiable list of this file's public dependencies (public imports). - - - - - The original serialized binary form of this descriptor. - - - - - Implementation of IDescriptor.FullName - just returns the same as Name. - - - - - Implementation of IDescriptor.File - just returns this descriptor. - - - - - Pool containing symbol descriptors. - - - - - Finds a type (message, enum, service or extension) in the file by name. Does not find nested types. - - The unqualified type name to look for. - The type of descriptor to look for - The type's descriptor, or null if not found. - - - - Builds a FileDescriptor from its protocol buffer representation. - - The original serialized descriptor data. - We have only limited proto2 support, so serializing FileDescriptorProto - would not necessarily give us this. - The protocol message form of the FileDescriptor. - FileDescriptors corresponding to all of the - file's dependencies, in the exact order listed in the .proto file. May be null, - in which case it is treated as an empty array. - Whether unknown dependencies are ignored (true) or cause an exception to be thrown (false). - Details about generated code, for the purposes of reflection. - If is not - a valid descriptor. This can occur for a number of reasons, such as a field - having an undefined type or because two messages were defined with the same name. - - - - Creates a descriptor for generated code. - - - This method is only designed to be used by the results of generating code with protoc, - which creates the appropriate dependencies etc. It has to be public because the generated - code is "external", but should not be called directly by end users. - - - - - Returns a that represents this instance. - - - A that represents this instance. - - - - - Returns the file descriptor for descriptor.proto. - - - This is used for protos which take a direct dependency on descriptor.proto, typically for - annotations. While descriptor.proto is a proto2 file, it is built into the Google.Protobuf - runtime for reflection purposes. The messages are internal to the runtime as they would require - proto2 semantics for full support, but the file descriptor is available via this property. The - C# codegen in protoc automatically uses this property when it detects a dependency on descriptor.proto. - - - The file descriptor for descriptor.proto. - - - - - The (possibly empty) set of custom options for this file. - - - - - Extra information provided by generated code when initializing a message or file descriptor. - These are constructed as required, and are not long-lived. Hand-written code should - never need to use this type. - - - - - Irrelevant for file descriptors; the CLR type for the message for message descriptors. - - - - - Irrelevant for file descriptors; the parser for message descriptors. - - - - - Irrelevant for file descriptors; the CLR property names (in message descriptor field order) - for fields in the message for message descriptors. - - - - - Irrelevant for file descriptors; the CLR property "base" names (in message descriptor oneof order) - for oneofs in the message for message descriptors. It is expected that for a oneof name of "Foo", - there will be a "FooCase" property and a "ClearFoo" method. - - - - - The reflection information for types within this file/message descriptor. Elements may be null - if there is no corresponding generated type, e.g. for map entry types. - - - - - The CLR types for enums within this file/message descriptor. - - - - - Creates a GeneratedClrTypeInfo for a message descriptor, with nested types, nested enums, the CLR type, property names and oneof names. - Each array parameter may be null, to indicate a lack of values. - The parameter order is designed to make it feasible to format the generated code readably. - - - - - Creates a GeneratedClrTypeInfo for a file descriptor, with only types and enums. - - - - - Interface implemented by all descriptor types. - - - - - Returns the name of the entity (message, field etc) being described. - - - - - Returns the fully-qualified name of the entity being described. - - - - - Returns the descriptor for the .proto file that this entity is part of. - - - - - Allows fields to be reflectively accessed. - - - - - Returns the descriptor associated with this field. - - - - - Clears the field in the specified message. (For repeated fields, - this clears the list.) - - - - - Fetches the field value. For repeated values, this will be an - implementation. For map values, this will be an - implementation. - - - - - Mutator for single "simple" fields only. - - - Repeated fields are mutated by fetching the value and manipulating it as a list. - Map fields are mutated by fetching the value and manipulating it as a dictionary. - - The field is not a "simple" field. - - - - Accessor for map fields. - - - - - Describes a message type. - - - - - The brief name of the descriptor's target. - - - - - The CLR type used to represent message instances from this descriptor. - - - - The value returned by this property will be non-null for all regular fields. However, - if a message containing a map field is introspected, the list of nested messages will include - an auto-generated nested key/value pair message for the field. This is not represented in any - generated type, so this property will return null in such cases. - - - For wrapper types ( and the like), the type returned here - will be the generated message type, not the native type used by reflection for fields of those types. Code - using reflection should call to determine whether a message descriptor represents - a wrapper type, and handle the result appropriately. - - - - - - A parser for this message type. - - - - As is not generic, this cannot be statically - typed to the relevant type, but it should produce objects of a type compatible with . - - - The value returned by this property will be non-null for all regular fields. However, - if a message containing a map field is introspected, the list of nested messages will include - an auto-generated nested key/value pair message for the field. No message parser object is created for - such messages, so this property will return null in such cases. - - - For wrapper types ( and the like), the parser returned here - will be the generated message type, not the native type used by reflection for fields of those types. Code - using reflection should call to determine whether a message descriptor represents - a wrapper type, and handle the result appropriately. - - - - - - Returns whether this message is one of the "well known types" which may have runtime/protoc support. - - - - - Returns whether this message is one of the "wrapper types" used for fields which represent primitive values - with the addition of presence. - - - - - If this is a nested type, get the outer descriptor, otherwise null. - - - - - A collection of fields, which can be retrieved by name or field number. - - - - - An unmodifiable list of this message type's nested types. - - - - - An unmodifiable list of this message type's enum types. - - - - - An unmodifiable list of the "oneof" field collections in this message type. - - - - - Finds a field by field name. - - The unqualified name of the field (e.g. "foo"). - The field's descriptor, or null if not found. - - - - Finds a field by field number. - - The field number within this message type. - The field's descriptor, or null if not found. - - - - Finds a nested descriptor by name. The is valid for fields, nested - message types, oneofs and enums. - - The unqualified name of the descriptor, e.g. "Foo" - The descriptor, or null if not found. - - - - The (possibly empty) set of custom options for this message. - - - - - Looks up and cross-links all fields and nested types. - - - - - A collection to simplify retrieving the field accessor for a particular field. - - - - - Returns the fields in the message as an immutable list, in the order in which they - are declared in the source .proto file. - - - - - Returns the fields in the message as an immutable list, in ascending field number - order. Field numbers need not be contiguous, so there is no direct mapping from the - index in the list to the field number; to retrieve a field by field number, it is better - to use the indexer. - - - - - Returns a read-only dictionary mapping the field names in this message as they're available - in the JSON representation to the field descriptors. For example, a field foo_bar - in the message would result two entries, one with a key fooBar and one with a key - foo_bar, both referring to the same field. - - - - - Retrieves the descriptor for the field with the given number. - - Number of the field to retrieve the descriptor for - The accessor for the given field - The message descriptor does not contain a field - with the given number - - - - Retrieves the descriptor for the field with the given name. - - Name of the field to retrieve the descriptor for - The descriptor for the given field - The message descriptor does not contain a field - with the given name - - - - Describes a single method in a service. - - - - - The service this method belongs to. - - - - - The method's input type. - - - - - The method's input type. - - - - - Indicates if client streams multiple requests. - - - - - Indicates if server streams multiple responses. - - - - - The (possibly empty) set of custom options for this method. - - - - - The brief name of the descriptor's target. - - - - - Reflection access for a oneof, allowing clear and "get case" actions. - - - - - Gets the descriptor for this oneof. - - - The descriptor of the oneof. - - - - - Clears the oneof in the specified message. - - - - - Indicates which field in the oneof is set for specified message - - - - - Describes a "oneof" field collection in a message type: a set of - fields of which at most one can be set in any particular message. - - - - - The brief name of the descriptor's target. - - - - - Gets the message type containing this oneof. - - - The message type containing this oneof. - - - - - Gets the fields within this oneof, in declaration order. - - - The fields within this oneof, in declaration order. - - - - - Gets an accessor for reflective access to the values associated with the oneof - in a particular message. - - - The accessor used for reflective access. - - - - - The (possibly empty) set of custom options for this oneof. - - - - - Specifies the original name (in the .proto file) of a named element, - such as an enum value. - - - - - The name of the element in the .proto file. - - - - - If the name is preferred in the .proto file. - - - - - Constructs a new attribute instance for the given name. - - The name of the element in the .proto file. - - - - Represents a package in the symbol table. We use PackageDescriptors - just as placeholders so that someone cannot define, say, a message type - that has the same name as an existing package. - - - - - The methods in this class are somewhat evil, and should not be tampered with lightly. - Basically they allow the creation of relatively weakly typed delegates from MethodInfos - which are more strongly typed. They do this by creating an appropriate strongly typed - delegate from the MethodInfo, and then calling that within an anonymous method. - Mind-bending stuff (at least to your humble narrator) but the resulting delegates are - very fast compared with calling Invoke later on. - - - - - Empty Type[] used when calling GetProperty to force property instead of indexer fetching. - - - - - Creates a delegate which will cast the argument to the appropriate method target type, - call the method on it, then convert the result to object. - - - - - Creates a delegate which will cast the argument to the appropriate method target type, - call the method on it, then convert the result to the specified type. - - - - - Creates a delegate which will execute the given method after casting the first argument to - the target type of the method, and the second argument to the first parameter type of the method. - - - - - Creates a delegate which will execute the given method after casting the first argument to - the target type of the method. - - - - - Accessor for repeated fields. - - - - - Describes a service type. - - - - - The brief name of the descriptor's target. - - - - - An unmodifiable list of methods in this service. - - - - - Finds a method by name. - - The unqualified name of the method (e.g. "Foo"). - The method's decsriptor, or null if not found. - - - - The (possibly empty) set of custom options for this service. - - - - - Accessor for single fields. - - - - - An immutable registry of types which can be looked up by their full name. - - - - - An empty type registry, containing no types. - - - - - Attempts to find a message descriptor by its full name. - - The full name of the message, which is the dot-separated - combination of package, containing messages and message name - The message descriptor corresponding to or null - if there is no such message descriptor. - - - - Creates a type registry from the specified set of file descriptors. - - - This is a convenience overload for - to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). - - The set of files to include in the registry. Must not contain null values. - A type registry for the given files. - - - - Creates a type registry from the specified set of file descriptors. - - - All message types within all the specified files are added to the registry, and - the dependencies of the specified files are also added, recursively. - - The set of files to include in the registry. Must not contain null values. - A type registry for the given files. - - - - Creates a type registry from the file descriptor parents of the specified set of message descriptors. - - - This is a convenience overload for - to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). - - The set of message descriptors to use to identify file descriptors to include in the registry. - Must not contain null values. - A type registry for the given files. - - - - Creates a type registry from the file descriptor parents of the specified set of message descriptors. - - - The specified message descriptors are only used to identify their file descriptors; the returned registry - contains all the types within the file descriptors which contain the specified message descriptors (and - the dependencies of those files), not just the specified messages. - - The set of message descriptors to use to identify file descriptors to include in the registry. - Must not contain null values. - A type registry for the given files. - - - - Builder class which isn't exposed, but acts as a convenient alternative to passing round two dictionaries in recursive calls. - - - - Holder for reflection information generated from google/protobuf/any.proto - - - File descriptor for google/protobuf/any.proto - - - - `Any` contains an arbitrary serialized protocol buffer message along with a - URL that describes the type of the serialized message. - - Protobuf library provides support to pack/unpack Any values in the form - of utility functions or additional generated methods of the Any type. - - Example 1: Pack and unpack a message in C++. - - Foo foo = ...; - Any any; - any.PackFrom(foo); - ... - if (any.UnpackTo(&foo)) { - ... - } - - Example 2: Pack and unpack a message in Java. - - Foo foo = ...; - Any any = Any.pack(foo); - ... - if (any.is(Foo.class)) { - foo = any.unpack(Foo.class); - } - - Example 3: Pack and unpack a message in Python. - - foo = Foo(...) - any = Any() - any.Pack(foo) - ... - if any.Is(Foo.DESCRIPTOR): - any.Unpack(foo) - ... - - The pack methods provided by protobuf library will by default use - 'type.googleapis.com/full.type.name' as the type URL and the unpack - methods only use the fully qualified type name after the last '/' - in the type URL, for example "foo.bar.com/x/y.z" will yield type - name "y.z". - - JSON - ==== - The JSON representation of an `Any` value uses the regular - representation of the deserialized, embedded message, with an - additional field `@type` which contains the type URL. Example: - - package google.profile; - message Person { - string first_name = 1; - string last_name = 2; - } - - { - "@type": "type.googleapis.com/google.profile.Person", - "firstName": <string>, - "lastName": <string> - } - - If the embedded message type is well-known and has a custom JSON - representation, that representation will be embedded adding a field - `value` which holds the custom JSON in addition to the `@type` - field. Example (for message [google.protobuf.Duration][]): - - { - "@type": "type.googleapis.com/google.protobuf.Duration", - "value": "1.212s" - } - - - - Field number for the "type_url" field. - - - - A URL/resource name whose content describes the type of the - serialized protocol buffer message. - - For URLs which use the scheme `http`, `https`, or no scheme, the - following restrictions and interpretations apply: - - * If no scheme is provided, `https` is assumed. - * The last segment of the URL's path must represent the fully - qualified name of the type (as in `path/google.protobuf.Duration`). - The name should be in a canonical form (e.g., leading "." is - not accepted). - * An HTTP GET on the URL must yield a [google.protobuf.Type][] - value in binary format, or produce an error. - * Applications are allowed to cache lookup results based on the - URL, or have them precompiled into a binary to avoid any - lookup. Therefore, binary compatibility needs to be preserved - on changes to types. (Use versioned type names to manage - breaking changes.) - - Schemes other than `http`, `https` (or the empty scheme) might be - used with implementation specific semantics. - - - - Field number for the "value" field. - - - - Must be a valid serialized protocol buffer of the above specified type. - - - - - Retrieves the type name for a type URL. This is always just the last part of the URL, - after the trailing slash. No validation of anything before the trailing slash is performed. - If the type URL does not include a slash, an empty string is returned rather than an exception - being thrown; this won't match any types, and the calling code is probably in a better position - to give a meaningful error. - There is no handling of fragments or queries at the moment. - - The URL to extract the type name from - The type name - - - - Unpacks the content of this Any message into the target message type, - which must match the type URL within this Any message. - - The type of message to unpack the content into. - The unpacked message. - The target message type doesn't match the type URL in this message - - - - Packs the specified message into an Any message using a type URL prefix of "type.googleapis.com". - - The message to pack. - An Any message with the content and type URL of . - - - - Packs the specified message into an Any message using the specified type URL prefix. - - The message to pack. - The prefix for the type URL. - An Any message with the content and type URL of . - - - Holder for reflection information generated from google/protobuf/api.proto - - - File descriptor for google/protobuf/api.proto - - - - Api is a light-weight descriptor for a protocol buffer service. - - - - Field number for the "name" field. - - - - The fully qualified name of this api, including package name - followed by the api's simple name. - - - - Field number for the "methods" field. - - - - The methods of this api, in unspecified order. - - - - Field number for the "options" field. - - - - Any metadata attached to the API. - - - - Field number for the "version" field. - - - - A version string for this api. If specified, must have the form - `major-version.minor-version`, as in `1.10`. If the minor version - is omitted, it defaults to zero. If the entire version field is - empty, the major version is derived from the package name, as - outlined below. If the field is not empty, the version in the - package name will be verified to be consistent with what is - provided here. - - The versioning schema uses [semantic - versioning](http://semver.org) where the major version number - indicates a breaking change and the minor version an additive, - non-breaking change. Both version numbers are signals to users - what to expect from different versions, and should be carefully - chosen based on the product plan. - - The major version is also reflected in the package name of the - API, which must end in `v<major-version>`, as in - `google.feature.v1`. For major versions 0 and 1, the suffix can - be omitted. Zero major versions must only be used for - experimental, none-GA apis. - - - - Field number for the "source_context" field. - - - - Source context for the protocol buffer service represented by this - message. - - - - Field number for the "mixins" field. - - - - Included APIs. See [Mixin][]. - - - - Field number for the "syntax" field. - - - - The source syntax of the service. - - - - - Method represents a method of an api. - - - - Field number for the "name" field. - - - - The simple name of this method. - - - - Field number for the "request_type_url" field. - - - - A URL of the input message type. - - - - Field number for the "request_streaming" field. - - - - If true, the request is streamed. - - - - Field number for the "response_type_url" field. - - - - The URL of the output message type. - - - - Field number for the "response_streaming" field. - - - - If true, the response is streamed. - - - - Field number for the "options" field. - - - - Any metadata attached to the method. - - - - Field number for the "syntax" field. - - - - The source syntax of this method. - - - - - Declares an API to be included in this API. The including API must - redeclare all the methods from the included API, but documentation - and options are inherited as follows: - - - If after comment and whitespace stripping, the documentation - string of the redeclared method is empty, it will be inherited - from the original method. - - - Each annotation belonging to the service config (http, - visibility) which is not set in the redeclared method will be - inherited. - - - If an http annotation is inherited, the path pattern will be - modified as follows. Any version prefix will be replaced by the - version of the including API plus the [root][] path if specified. - - Example of a simple mixin: - - package google.acl.v1; - service AccessControl { - // Get the underlying ACL object. - rpc GetAcl(GetAclRequest) returns (Acl) { - option (google.api.http).get = "/v1/{resource=**}:getAcl"; - } - } - - package google.storage.v2; - service Storage { - rpc GetAcl(GetAclRequest) returns (Acl); - - // Get a data record. - rpc GetData(GetDataRequest) returns (Data) { - option (google.api.http).get = "/v2/{resource=**}"; - } - } - - Example of a mixin configuration: - - apis: - - name: google.storage.v2.Storage - mixins: - - name: google.acl.v1.AccessControl - - The mixin construct implies that all methods in `AccessControl` are - also declared with same name and request/response types in - `Storage`. A documentation generator or annotation processor will - see the effective `Storage.GetAcl` method after inherting - documentation and annotations as follows: - - service Storage { - // Get the underlying ACL object. - rpc GetAcl(GetAclRequest) returns (Acl) { - option (google.api.http).get = "/v2/{resource=**}:getAcl"; - } - ... - } - - Note how the version in the path pattern changed from `v1` to `v2`. - - If the `root` field in the mixin is specified, it should be a - relative path under which inherited HTTP paths are placed. Example: - - apis: - - name: google.storage.v2.Storage - mixins: - - name: google.acl.v1.AccessControl - root: acls - - This implies the following inherited HTTP annotation: - - service Storage { - // Get the underlying ACL object. - rpc GetAcl(GetAclRequest) returns (Acl) { - option (google.api.http).get = "/v2/acls/{resource=**}:getAcl"; - } - ... - } - - - - Field number for the "name" field. - - - - The fully qualified name of the API which is included. - - - - Field number for the "root" field. - - - - If non-empty specifies a path under which inherited HTTP paths - are rooted. - - - - Holder for reflection information generated from google/protobuf/duration.proto - - - File descriptor for google/protobuf/duration.proto - - - - A Duration represents a signed, fixed-length span of time represented - as a count of seconds and fractions of seconds at nanosecond - resolution. It is independent of any calendar and concepts like "day" - or "month". It is related to Timestamp in that the difference between - two Timestamp values is a Duration and it can be added or subtracted - from a Timestamp. Range is approximately +-10,000 years. - - # Examples - - Example 1: Compute Duration from two Timestamps in pseudo code. - - Timestamp start = ...; - Timestamp end = ...; - Duration duration = ...; - - duration.seconds = end.seconds - start.seconds; - duration.nanos = end.nanos - start.nanos; - - if (duration.seconds < 0 && duration.nanos > 0) { - duration.seconds += 1; - duration.nanos -= 1000000000; - } else if (durations.seconds > 0 && duration.nanos < 0) { - duration.seconds -= 1; - duration.nanos += 1000000000; - } - - Example 2: Compute Timestamp from Timestamp + Duration in pseudo code. - - Timestamp start = ...; - Duration duration = ...; - Timestamp end = ...; - - end.seconds = start.seconds + duration.seconds; - end.nanos = start.nanos + duration.nanos; - - if (end.nanos < 0) { - end.seconds -= 1; - end.nanos += 1000000000; - } else if (end.nanos >= 1000000000) { - end.seconds += 1; - end.nanos -= 1000000000; - } - - Example 3: Compute Duration from datetime.timedelta in Python. - - td = datetime.timedelta(days=3, minutes=10) - duration = Duration() - duration.FromTimedelta(td) - - # JSON Mapping - - In JSON format, the Duration type is encoded as a string rather than an - object, where the string ends in the suffix "s" (indicating seconds) and - is preceded by the number of seconds, with nanoseconds expressed as - fractional seconds. For example, 3 seconds with 0 nanoseconds should be - encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should - be expressed in JSON format as "3.000000001s", and 3 seconds and 1 - microsecond should be expressed in JSON format as "3.000001s". - - - - Field number for the "seconds" field. - - - - Signed seconds of the span of time. Must be from -315,576,000,000 - to +315,576,000,000 inclusive. Note: these bounds are computed from: - 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years - - - - Field number for the "nanos" field. - - - - Signed fractions of a second at nanosecond resolution of the span - of time. Durations less than one second are represented with a 0 - `seconds` field and a positive or negative `nanos` field. For durations - of one second or more, a non-zero value for the `nanos` field must be - of the same sign as the `seconds` field. Must be from -999,999,999 - to +999,999,999 inclusive. - - - - - The number of nanoseconds in a second. - - - - - The number of nanoseconds in a BCL tick (as used by and ). - - - - - The maximum permitted number of seconds. - - - - - The minimum permitted number of seconds. - - - - - Converts this to a . - - If the duration is not a precise number of ticks, it is truncated towards 0. - The value of this duration, as a TimeSpan. - This value isn't a valid normalized duration, as - described in the documentation. - - - - Converts the given to a . - - The TimeSpan to convert. - The value of the given TimeSpan, as a Duration. - - - - Returns the result of negating the duration. For example, the negation of 5 minutes is -5 minutes. - - The duration to negate. Must not be null. - The negated value of this duration. - - - - Adds the two specified values together. - - The first value to add. Must not be null. - The second value to add. Must not be null. - - - - - Subtracts one from another. - - The duration to subtract from. Must not be null. - The duration to subtract. Must not be null. - The difference between the two specified durations. - - - - Creates a duration with the normalized values from the given number of seconds and - nanoseconds, conforming with the description in the proto file. - - - - - Converts a duration specified in seconds/nanoseconds to a string. - - - If the value is a normalized duration in the range described in duration.proto, - is ignored. Otherwise, if the parameter is true, - a JSON object with a warning is returned; if it is false, an is thrown. - - Seconds portion of the duration. - Nanoseconds portion of the duration. - Determines the handling of non-normalized values - The represented duration is invalid, and is false. - - - - Returns a string representation of this for diagnostic purposes. - - - Normally the returned value will be a JSON string value (including leading and trailing quotes) but - when the value is non-normalized or out of range, a JSON object representation will be returned - instead, including a warning. This is to avoid exceptions being thrown when trying to - diagnose problems - the regular JSON formatter will still throw an exception for non-normalized - values. - - A string representation of this value. - - - - Appends a number of nanoseconds to a StringBuilder. Either 0 digits are added (in which - case no "." is appended), or 3 6 or 9 digits. This is internal for use in Timestamp as well - as Duration. - - - - Holder for reflection information generated from google/protobuf/empty.proto - - - File descriptor for google/protobuf/empty.proto - - - - A generic empty message that you can re-use to avoid defining duplicated - empty messages in your APIs. A typical example is to use it as the request - or the response type of an API method. For instance: - - service Foo { - rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); - } - - The JSON representation for `Empty` is empty JSON object `{}`. - - - - Holder for reflection information generated from google/protobuf/field_mask.proto - - - File descriptor for google/protobuf/field_mask.proto - - - - `FieldMask` represents a set of symbolic field paths, for example: - - paths: "f.a" - paths: "f.b.d" - - Here `f` represents a field in some root message, `a` and `b` - fields in the message found in `f`, and `d` a field found in the - message in `f.b`. - - Field masks are used to specify a subset of fields that should be - returned by a get operation or modified by an update operation. - Field masks also have a custom JSON encoding (see below). - - # Field Masks in Projections - - When used in the context of a projection, a response message or - sub-message is filtered by the API to only contain those fields as - specified in the mask. For example, if the mask in the previous - example is applied to a response message as follows: - - f { - a : 22 - b { - d : 1 - x : 2 - } - y : 13 - } - z: 8 - - The result will not contain specific values for fields x,y and z - (their value will be set to the default, and omitted in proto text - output): - - f { - a : 22 - b { - d : 1 - } - } - - A repeated field is not allowed except at the last position of a - paths string. - - If a FieldMask object is not present in a get operation, the - operation applies to all fields (as if a FieldMask of all fields - had been specified). - - Note that a field mask does not necessarily apply to the - top-level response message. In case of a REST get operation, the - field mask applies directly to the response, but in case of a REST - list operation, the mask instead applies to each individual message - in the returned resource list. In case of a REST custom method, - other definitions may be used. Where the mask applies will be - clearly documented together with its declaration in the API. In - any case, the effect on the returned resource/resources is required - behavior for APIs. - - # Field Masks in Update Operations - - A field mask in update operations specifies which fields of the - targeted resource are going to be updated. The API is required - to only change the values of the fields as specified in the mask - and leave the others untouched. If a resource is passed in to - describe the updated values, the API ignores the values of all - fields not covered by the mask. - - If a repeated field is specified for an update operation, the existing - repeated values in the target resource will be overwritten by the new values. - Note that a repeated field is only allowed in the last position of a `paths` - string. - - If a sub-message is specified in the last position of the field mask for an - update operation, then the existing sub-message in the target resource is - overwritten. Given the target message: - - f { - b { - d : 1 - x : 2 - } - c : 1 - } - - And an update message: - - f { - b { - d : 10 - } - } - - then if the field mask is: - - paths: "f.b" - - then the result will be: - - f { - b { - d : 10 - } - c : 1 - } - - However, if the update mask was: - - paths: "f.b.d" - - then the result would be: - - f { - b { - d : 10 - x : 2 - } - c : 1 - } - - In order to reset a field's value to the default, the field must - be in the mask and set to the default value in the provided resource. - Hence, in order to reset all fields of a resource, provide a default - instance of the resource and set all fields in the mask, or do - not provide a mask as described below. - - If a field mask is not present on update, the operation applies to - all fields (as if a field mask of all fields has been specified). - Note that in the presence of schema evolution, this may mean that - fields the client does not know and has therefore not filled into - the request will be reset to their default. If this is unwanted - behavior, a specific service may require a client to always specify - a field mask, producing an error if not. - - As with get operations, the location of the resource which - describes the updated values in the request message depends on the - operation kind. In any case, the effect of the field mask is - required to be honored by the API. - - ## Considerations for HTTP REST - - The HTTP kind of an update operation which uses a field mask must - be set to PATCH instead of PUT in order to satisfy HTTP semantics - (PUT must only be used for full updates). - - # JSON Encoding of Field Masks - - In JSON, a field mask is encoded as a single string where paths are - separated by a comma. Fields name in each path are converted - to/from lower-camel naming conventions. - - As an example, consider the following message declarations: - - message Profile { - User user = 1; - Photo photo = 2; - } - message User { - string display_name = 1; - string address = 2; - } - - In proto a field mask for `Profile` may look as such: - - mask { - paths: "user.display_name" - paths: "photo" - } - - In JSON, the same mask is represented as below: - - { - mask: "user.displayName,photo" - } - - # Field Masks and Oneof Fields - - Field masks treat fields in oneofs just as regular fields. Consider the - following message: - - message SampleMessage { - oneof test_oneof { - string name = 4; - SubMessage sub_message = 9; - } - } - - The field mask can be: - - mask { - paths: "name" - } - - Or: - - mask { - paths: "sub_message" - } - - Note that oneof type names ("test_oneof" in this case) cannot be used in - paths. - - - - Field number for the "paths" field. - - - - The set of field mask paths. - - - - - Converts a timestamp specified in seconds/nanoseconds to a string. - - - If the value is a normalized duration in the range described in field_mask.proto, - is ignored. Otherwise, if the parameter is true, - a JSON object with a warning is returned; if it is false, an is thrown. - - Paths in the field mask - Determines the handling of non-normalized values - The represented field mask is invalid, and is false. - - - - Checks whether the given path is valid for a field mask. - - true if the path is valid; false otherwise - - - - Returns a string representation of this for diagnostic purposes. - - - Normally the returned value will be a JSON string value (including leading and trailing quotes) but - when the value is non-normalized or out of range, a JSON object representation will be returned - instead, including a warning. This is to avoid exceptions being thrown when trying to - diagnose problems - the regular JSON formatter will still throw an exception for non-normalized - values. - - A string representation of this value. - - - Holder for reflection information generated from google/protobuf/source_context.proto - - - File descriptor for google/protobuf/source_context.proto - - - - `SourceContext` represents information about the source of a - protobuf element, like the file in which it is defined. - - - - Field number for the "file_name" field. - - - - The path-qualified name of the .proto file that contained the associated - protobuf element. For example: `"google/protobuf/source_context.proto"`. - - - - Holder for reflection information generated from google/protobuf/struct.proto - - - File descriptor for google/protobuf/struct.proto - - - - `NullValue` is a singleton enumeration to represent the null value for the - `Value` type union. - - The JSON representation for `NullValue` is JSON `null`. - - - - - Null value. - - - - - `Struct` represents a structured data value, consisting of fields - which map to dynamically typed values. In some languages, `Struct` - might be supported by a native representation. For example, in - scripting languages like JS a struct is represented as an - object. The details of that representation are described together - with the proto support for the language. - - The JSON representation for `Struct` is JSON object. - - - - Field number for the "fields" field. - - - - Unordered map of dynamically typed values. - - - - - `Value` represents a dynamically typed value which can be either - null, a number, a string, a boolean, a recursive struct value, or a - list of values. A producer of value is expected to set one of that - variants, absence of any variant indicates an error. - - The JSON representation for `Value` is JSON value. - - - - Field number for the "null_value" field. - - - - Represents a null value. - - - - Field number for the "number_value" field. - - - - Represents a double value. - - - - Field number for the "string_value" field. - - - - Represents a string value. - - - - Field number for the "bool_value" field. - - - - Represents a boolean value. - - - - Field number for the "struct_value" field. - - - - Represents a structured value. - - - - Field number for the "list_value" field. - - - - Represents a repeated `Value`. - - - - Enum of possible cases for the "kind" oneof. - - - - Convenience method to create a Value message with a string value. - - Value to set for the StringValue property. - A newly-created Value message with the given value. - - - - Convenience method to create a Value message with a number value. - - Value to set for the NumberValue property. - A newly-created Value message with the given value. - - - - Convenience method to create a Value message with a Boolean value. - - Value to set for the BoolValue property. - A newly-created Value message with the given value. - - - - Convenience method to create a Value message with a null initial value. - - A newly-created Value message a null initial value. - - - - Convenience method to create a Value message with an initial list of values. - - The values provided are not cloned; the references are copied directly. - A newly-created Value message an initial list value. - - - - Convenience method to create a Value message with an initial struct value - - The value provided is not cloned; the reference is copied directly. - A newly-created Value message an initial struct value. - - - - `ListValue` is a wrapper around a repeated field of values. - - The JSON representation for `ListValue` is JSON array. - - - - Field number for the "values" field. - - - - Repeated field of dynamically typed values. - - - - - Extension methods on BCL time-related types, converting to protobuf types. - - - - - Converts the given to a . - - The date and time to convert to a timestamp. - The value has a other than Utc. - The converted timestamp. - - - - Converts the given to a - - The offset is taken into consideration when converting the value (so the same instant in time - is represented) but is not a separate part of the resulting value. In other words, there is no - roundtrip operation to retrieve the original DateTimeOffset. - The date and time (with UTC offset) to convert to a timestamp. - The converted timestamp. - - - - Converts the given to a . - - The time span to convert. - The converted duration. - - - Holder for reflection information generated from google/protobuf/timestamp.proto - - - File descriptor for google/protobuf/timestamp.proto - - - - A Timestamp represents a point in time independent of any time zone - or calendar, represented as seconds and fractions of seconds at - nanosecond resolution in UTC Epoch time. It is encoded using the - Proleptic Gregorian Calendar which extends the Gregorian calendar - backwards to year one. It is encoded assuming all minutes are 60 - seconds long, i.e. leap seconds are "smeared" so that no leap second - table is needed for interpretation. Range is from - 0001-01-01T00:00:00Z to 9999-12-31T23:59:59.999999999Z. - By restricting to that range, we ensure that we can convert to - and from RFC 3339 date strings. - See [https://www.ietf.org/rfc/rfc3339.txt](https://www.ietf.org/rfc/rfc3339.txt). - - # Examples - - Example 1: Compute Timestamp from POSIX `time()`. - - Timestamp timestamp; - timestamp.set_seconds(time(NULL)); - timestamp.set_nanos(0); - - Example 2: Compute Timestamp from POSIX `gettimeofday()`. - - struct timeval tv; - gettimeofday(&tv, NULL); - - Timestamp timestamp; - timestamp.set_seconds(tv.tv_sec); - timestamp.set_nanos(tv.tv_usec * 1000); - - Example 3: Compute Timestamp from Win32 `GetSystemTimeAsFileTime()`. - - FILETIME ft; - GetSystemTimeAsFileTime(&ft); - UINT64 ticks = (((UINT64)ft.dwHighDateTime) << 32) | ft.dwLowDateTime; - - // A Windows tick is 100 nanoseconds. Windows epoch 1601-01-01T00:00:00Z - // is 11644473600 seconds before Unix epoch 1970-01-01T00:00:00Z. - Timestamp timestamp; - timestamp.set_seconds((INT64) ((ticks / 10000000) - 11644473600LL)); - timestamp.set_nanos((INT32) ((ticks % 10000000) * 100)); - - Example 4: Compute Timestamp from Java `System.currentTimeMillis()`. - - long millis = System.currentTimeMillis(); - - Timestamp timestamp = Timestamp.newBuilder().setSeconds(millis / 1000) - .setNanos((int) ((millis % 1000) * 1000000)).build(); - - Example 5: Compute Timestamp from current time in Python. - - timestamp = Timestamp() - timestamp.GetCurrentTime() - - # JSON Mapping - - In JSON format, the Timestamp type is encoded as a string in the - [RFC 3339](https://www.ietf.org/rfc/rfc3339.txt) format. That is, the - format is "{year}-{month}-{day}T{hour}:{min}:{sec}[.{frac_sec}]Z" - where {year} is always expressed using four digits while {month}, {day}, - {hour}, {min}, and {sec} are zero-padded to two digits each. The fractional - seconds, which can go up to 9 digits (i.e. up to 1 nanosecond resolution), - are optional. The "Z" suffix indicates the timezone ("UTC"); the timezone - is required, though only UTC (as indicated by "Z") is presently supported. - - For example, "2017-01-15T01:30:15.01Z" encodes 15.01 seconds past - 01:30 UTC on January 15, 2017. - - In JavaScript, one can convert a Date object to this format using the - standard [toISOString()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString] - method. In Python, a standard `datetime.datetime` object can be converted - to this format using [`strftime`](https://docs.python.org/2/library/time.html#time.strftime) - with the time format spec '%Y-%m-%dT%H:%M:%S.%fZ'. Likewise, in Java, one - can use the Joda Time's [`ISODateTimeFormat.dateTime()`]( - http://joda-time.sourceforge.net/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime()) - to obtain a formatter capable of generating timestamps in this format. - - - - Field number for the "seconds" field. - - - - Represents seconds of UTC time since Unix epoch - 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to - 9999-12-31T23:59:59Z inclusive. - - - - Field number for the "nanos" field. - - - - Non-negative fractions of a second at nanosecond resolution. Negative - second values with fractions must still have non-negative nanos values - that count forward in time. Must be from 0 to 999,999,999 - inclusive. - - - - - Returns the difference between one and another, as a . - - The timestamp to subtract from. Must not be null. - The timestamp to subtract. Must not be null. - The difference between the two specified timestamps. - - - - Adds a to a , to obtain another Timestamp. - - The timestamp to add the duration to. Must not be null. - The duration to add. Must not be null. - The result of adding the duration to the timestamp. - - - - Subtracts a from a , to obtain another Timestamp. - - The timestamp to subtract the duration from. Must not be null. - The duration to subtract. - The result of subtracting the duration from the timestamp. - - - - Converts this timestamp into a . - - - The resulting DateTime will always have a Kind of Utc. - If the timestamp is not a precise number of ticks, it will be truncated towards the start - of time. For example, a timestamp with a value of 99 will result in a - value precisely on a second. - - This timestamp as a DateTime. - The timestamp contains invalid values; either it is - incorrectly normalized or is outside the valid range. - - - - Converts this timestamp into a . - - - The resulting DateTimeOffset will always have an Offset of zero. - If the timestamp is not a precise number of ticks, it will be truncated towards the start - of time. For example, a timestamp with a value of 99 will result in a - value precisely on a second. - - This timestamp as a DateTimeOffset. - The timestamp contains invalid values; either it is - incorrectly normalized or is outside the valid range. - - - - Converts the specified to a . - - - The Kind of is not DateTimeKind.Utc. - The converted timestamp. - - - - Converts the given to a - - The offset is taken into consideration when converting the value (so the same instant in time - is represented) but is not a separate part of the resulting value. In other words, there is no - roundtrip operation to retrieve the original DateTimeOffset. - The date and time (with UTC offset) to convert to a timestamp. - The converted timestamp. - - - - Converts a timestamp specified in seconds/nanoseconds to a string. - - - If the value is a normalized duration in the range described in timestamp.proto, - is ignored. Otherwise, if the parameter is true, - a JSON object with a warning is returned; if it is false, an is thrown. - - Seconds portion of the duration. - Nanoseconds portion of the duration. - Determines the handling of non-normalized values - The represented duration is invalid, and is false. - - - - Returns a string representation of this for diagnostic purposes. - - - Normally the returned value will be a JSON string value (including leading and trailing quotes) but - when the value is non-normalized or out of range, a JSON object representation will be returned - instead, including a warning. This is to avoid exceptions being thrown when trying to - diagnose problems - the regular JSON formatter will still throw an exception for non-normalized - values. - - A string representation of this value. - - - Holder for reflection information generated from google/protobuf/type.proto - - - File descriptor for google/protobuf/type.proto - - - - The syntax in which a protocol buffer element is defined. - - - - - Syntax `proto2`. - - - - - Syntax `proto3`. - - - - - A protocol buffer message type. - - - - Field number for the "name" field. - - - - The fully qualified message name. - - - - Field number for the "fields" field. - - - - The list of fields. - - - - Field number for the "oneofs" field. - - - - The list of types appearing in `oneof` definitions in this type. - - - - Field number for the "options" field. - - - - The protocol buffer options. - - - - Field number for the "source_context" field. - - - - The source context. - - - - Field number for the "syntax" field. - - - - The source syntax. - - - - - A single field of a message type. - - - - Field number for the "kind" field. - - - - The field type. - - - - Field number for the "cardinality" field. - - - - The field cardinality. - - - - Field number for the "number" field. - - - - The field number. - - - - Field number for the "name" field. - - - - The field name. - - - - Field number for the "type_url" field. - - - - The field type URL, without the scheme, for message or enumeration - types. Example: `"type.googleapis.com/google.protobuf.Timestamp"`. - - - - Field number for the "oneof_index" field. - - - - The index of the field type in `Type.oneofs`, for message or enumeration - types. The first type has index 1; zero means the type is not in the list. - - - - Field number for the "packed" field. - - - - Whether to use alternative packed wire representation. - - - - Field number for the "options" field. - - - - The protocol buffer options. - - - - Field number for the "json_name" field. - - - - The field JSON name. - - - - Field number for the "default_value" field. - - - - The string value of the default value of this field. Proto2 syntax only. - - - - Container for nested types declared in the Field message type. - - - - Basic field types. - - - - - Field type unknown. - - - - - Field type double. - - - - - Field type float. - - - - - Field type int64. - - - - - Field type uint64. - - - - - Field type int32. - - - - - Field type fixed64. - - - - - Field type fixed32. - - - - - Field type bool. - - - - - Field type string. - - - - - Field type group. Proto2 syntax only, and deprecated. - - - - - Field type message. - - - - - Field type bytes. - - - - - Field type uint32. - - - - - Field type enum. - - - - - Field type sfixed32. - - - - - Field type sfixed64. - - - - - Field type sint32. - - - - - Field type sint64. - - - - - Whether a field is optional, required, or repeated. - - - - - For fields with unknown cardinality. - - - - - For optional fields. - - - - - For required fields. Proto2 syntax only. - - - - - For repeated fields. - - - - - Enum type definition. - - - - Field number for the "name" field. - - - - Enum type name. - - - - Field number for the "enumvalue" field. - - - - Enum value definitions. - - - - Field number for the "options" field. - - - - Protocol buffer options. - - - - Field number for the "source_context" field. - - - - The source context. - - - - Field number for the "syntax" field. - - - - The source syntax. - - - - - Enum value definition. - - - - Field number for the "name" field. - - - - Enum value name. - - - - Field number for the "number" field. - - - - Enum value number. - - - - Field number for the "options" field. - - - - Protocol buffer options. - - - - - A protocol buffer option, which can be attached to a message, field, - enumeration, etc. - - - - Field number for the "name" field. - - - - The option's name. For protobuf built-in options (options defined in - descriptor.proto), this is the short name. For example, `"map_entry"`. - For custom options, it should be the fully-qualified name. For example, - `"google.api.http"`. - - - - Field number for the "value" field. - - - - The option's value packed in an Any message. If the value is a primitive, - the corresponding wrapper type defined in google/protobuf/wrappers.proto - should be used. If the value is an enum, it should be stored as an int32 - value using the google.protobuf.Int32Value type. - - - - Holder for reflection information generated from google/protobuf/wrappers.proto - - - File descriptor for google/protobuf/wrappers.proto - - - - Field number for the single "value" field in all wrapper types. - - - - - Wrapper message for `double`. - - The JSON representation for `DoubleValue` is JSON number. - - - - Field number for the "value" field. - - - - The double value. - - - - - Wrapper message for `float`. - - The JSON representation for `FloatValue` is JSON number. - - - - Field number for the "value" field. - - - - The float value. - - - - - Wrapper message for `int64`. - - The JSON representation for `Int64Value` is JSON string. - - - - Field number for the "value" field. - - - - The int64 value. - - - - - Wrapper message for `uint64`. - - The JSON representation for `UInt64Value` is JSON string. - - - - Field number for the "value" field. - - - - The uint64 value. - - - - - Wrapper message for `int32`. - - The JSON representation for `Int32Value` is JSON number. - - - - Field number for the "value" field. - - - - The int32 value. - - - - - Wrapper message for `uint32`. - - The JSON representation for `UInt32Value` is JSON number. - - - - Field number for the "value" field. - - - - The uint32 value. - - - - - Wrapper message for `bool`. - - The JSON representation for `BoolValue` is JSON `true` and `false`. - - - - Field number for the "value" field. - - - - The bool value. - - - - - Wrapper message for `string`. - - The JSON representation for `StringValue` is JSON string. - - - - Field number for the "value" field. - - - - The string value. - - - - - Wrapper message for `bytes`. - - The JSON representation for `BytesValue` is JSON string. - - - - Field number for the "value" field. - - - - The bytes value. - - - - - This class is used internally by the Protocol Buffer Library and generated - message implementations. It is public only for the sake of those generated - messages. Others should not use this class directly. - - This class contains constants and helper functions useful for dealing with - the Protocol Buffer wire format. - - - - - - Wire types within protobuf encoding. - - - - - Variable-length integer. - - - - - A fixed-length 64-bit value. - - - - - A length-delimited value, i.e. a length followed by that many bytes of data. - - - - - A "start group" value - not supported by this implementation. - - - - - An "end group" value - not supported by this implementation. - - - - - A fixed-length 32-bit value. - - - - - Given a tag value, determines the wire type (lower 3 bits). - - - - - Given a tag value, determines the field number (the upper 29 bits). - - - - - Makes a tag value given a field number and wire type. - - - - + + + + Google.Protobuf + + + + + Provides a utility routine to copy small arrays much more quickly than Buffer.BlockCopy + + + + + The threshold above which you should use Buffer.BlockCopy rather than ByteArray.Copy + + + + + Determines which copy routine to use based on the number of bytes to be copied. + + + + + Reverses the order of bytes in the array + + + + + Immutable array of bytes. + + + + + Unsafe operations that can cause IO Failure and/or other catestrophic side-effects. + + + + + Constructs a new ByteString from the given byte array. The array is + *not* copied, and must not be modified after this constructor is called. + + + + + Provides direct, unrestricted access to the bytes contained in this instance. + You must not modify or resize the byte array returned by this method. + + + + + Internal use only. Ensure that the provided array is not mutated and belongs to this instance. + + + + + Constructs a new ByteString from the given byte array. The array is + *not* copied, and must not be modified after this constructor is called. + + + + + Returns an empty ByteString. + + + + + Returns the length of this ByteString in bytes. + + + + + Returns true if this byte string is empty, false otherwise. + + + + + Converts this into a byte array. + + The data is copied - changes to the returned array will not be reflected in this ByteString. + A byte array with the same data as this ByteString. + + + + Converts this into a standard base64 representation. + + A base64 representation of this ByteString. + + + + Constructs a from the Base64 Encoded String. + + + + + Constructs a from data in the given stream, synchronously. + + If successful, will be read completely, from the position + at the start of the call. + The stream to copy into a ByteString. + A ByteString with content read from the given stream. + + + + Constructs a from the given array. The contents + are copied, so further modifications to the array will not + be reflected in the returned ByteString. + This method can also be invoked in ByteString.CopyFrom(0xaa, 0xbb, ...) form + which is primarily useful for testing. + + + + + Constructs a from a portion of a byte array. + + + + + Creates a new by encoding the specified text with + the given encoding. + + + + + Creates a new by encoding the specified text in UTF-8. + + + + + Retuns the byte at the given index. + + + + + Converts this into a string by applying the given encoding. + + + This method should only be used to convert binary data which was the result of encoding + text with the given encoding. + + The encoding to use to decode the binary data into text. + The result of decoding the binary data with the given decoding. + + + + Converts this into a string by applying the UTF-8 encoding. + + + This method should only be used to convert binary data which was the result of encoding + text with UTF-8. + + The result of decoding the binary data with the given decoding. + + + + Returns an iterator over the bytes in this . + + An iterator over the bytes in this object. + + + + Returns an iterator over the bytes in this . + + An iterator over the bytes in this object. + + + + Creates a CodedInputStream from this ByteString's data. + + + + + Compares two byte strings for equality. + + The first byte string to compare. + The second byte string to compare. + true if the byte strings are equal; false otherwise. + + + + Compares two byte strings for inequality. + + The first byte string to compare. + The second byte string to compare. + false if the byte strings are equal; true otherwise. + + + + Compares this byte string with another object. + + The object to compare this with. + true if refers to an equal ; false otherwise. + + + + Returns a hash code for this object. Two equal byte strings + will return the same hash code. + + A hash code for this object. + + + + Compares this byte string with another. + + The to compare this with. + true if refers to an equal byte string; false otherwise. + + + + Used internally by CodedOutputStream to avoid creating a copy for the write + + + + + Copies the entire byte array to the destination array provided at the offset specified. + + + + + Writes the entire byte array to the provided stream + + + + + Reads and decodes protocol message fields. + + + + This class is generally used by generated code to read appropriate + primitives from the stream. It effectively encapsulates the lowest + levels of protocol buffer format. + + + Repeated fields and map fields are not handled by this class; use + and to serialize such fields. + + + + + + Whether to leave the underlying stream open when disposing of this stream. + This is always true when there's no stream. + + + + + Buffer of data read from the stream or provided at construction time. + + + + + The index of the buffer at which we need to refill from the stream (if there is one). + + + + + The position within the current buffer (i.e. the next byte to read) + + + + + The stream to read further input from, or null if the byte array buffer was provided + directly on construction, with no further data available. + + + + + The last tag we read. 0 indicates we've read to the end of the stream + (or haven't read anything yet). + + + + + The next tag, used to store the value read by PeekTag. + + + + + The total number of bytes read before the current buffer. The + total bytes read up to the current position can be computed as + totalBytesRetired + bufferPos. + + + + + The absolute position of the end of the current message. + + + + + Creates a new CodedInputStream reading data from the given byte array. + + + + + Creates a new that reads from the given byte array slice. + + + + + Creates a new reading data from the given stream, which will be disposed + when the returned object is disposed. + + The stream to read from. + + + + Creates a new reading data from the given stream. + + The stream to read from. + true to leave open when the returned + is disposed; false to dispose of the given stream when the + returned object is disposed. + + + + Creates a new CodedInputStream reading data from the given + stream and buffer, using the default limits. + + + + + Creates a new CodedInputStream reading data from the given + stream and buffer, using the specified limits. + + + This chains to the version with the default limits instead of vice versa to avoid + having to check that the default values are valid every time. + + + + + Creates a with the specified size and recursion limits, reading + from an input stream. + + + This method exists separately from the constructor to reduce the number of constructor overloads. + It is likely to be used considerably less frequently than the constructors, as the default limits + are suitable for most use cases. + + The input stream to read from + The total limit of data to read from the stream. + The maximum recursion depth to allow while reading. + A CodedInputStream reading from with the specified size + and recursion limits. + + + + Returns the current position in the input stream, or the position in the input buffer + + + + + Returns the last tag read, or 0 if no tags have been read or we've read beyond + the end of the stream. + + + + + Returns the size limit for this stream. + + + This limit is applied when reading from the underlying stream, as a sanity check. It is + not applied when reading from a byte array data source without an underlying stream. + The default value is 64MB. + + + The size limit. + + + + + Returns the recursion limit for this stream. This limit is applied whilst reading messages, + to avoid maliciously-recursive data. + + + The default limit is 64. + + + The recursion limit for this stream. + + + + + Disposes of this instance, potentially closing any underlying stream. + + + As there is no flushing to perform here, disposing of a which + was constructed with the leaveOpen option parameter set to true (or one which + was constructed to read from a byte array) has no effect. + + + + + Verifies that the last call to ReadTag() returned tag 0 - in other words, + we've reached the end of the stream when we expected to. + + The + tag read was not the one specified + + + + Peeks at the next field tag. This is like calling , but the + tag is not consumed. (So a subsequent call to will return the + same value.) + + + + + Reads a field tag, returning the tag of 0 for "end of stream". + + + If this method returns 0, it doesn't necessarily mean the end of all + the data in this CodedInputStream; it may be the end of the logical stream + for an embedded message, for example. + + The next field tag, or 0 for end of stream. (0 is never a valid tag.) + + + + Skips the data for the field with the tag we've just read. + This should be called directly after , when + the caller wishes to skip an unknown field. + + + This method throws if the last-read tag was an end-group tag. + If a caller wishes to skip a group, they should skip the whole group, by calling this method after reading the + start-group tag. This behavior allows callers to call this method on any field they don't understand, correctly + resulting in an error if an end-group tag has not been paired with an earlier start-group tag. + + The last tag was an end-group tag + The last read operation read to the end of the logical stream + + + + Reads a double field from the stream. + + + + + Reads a float field from the stream. + + + + + Reads a uint64 field from the stream. + + + + + Reads an int64 field from the stream. + + + + + Reads an int32 field from the stream. + + + + + Reads a fixed64 field from the stream. + + + + + Reads a fixed32 field from the stream. + + + + + Reads a bool field from the stream. + + + + + Reads a string field from the stream. + + + + + Reads an embedded message field value from the stream. + + + + + Reads a bytes field value from the stream. + + + + + Reads a uint32 field value from the stream. + + + + + Reads an enum field value from the stream. + + + + + Reads an sfixed32 field value from the stream. + + + + + Reads an sfixed64 field value from the stream. + + + + + Reads an sint32 field value from the stream. + + + + + Reads an sint64 field value from the stream. + + + + + Reads a length for length-delimited data. + + + This is internally just reading a varint, but this method exists + to make the calling code clearer. + + + + + Peeks at the next tag in the stream. If it matches , + the tag is consumed and the method returns true; otherwise, the + stream is left in the original position and the method returns false. + + + + + Same code as ReadRawVarint32, but read each byte individually, checking for + buffer overflow. + + + + + Reads a raw Varint from the stream. If larger than 32 bits, discard the upper bits. + This method is optimised for the case where we've got lots of data in the buffer. + That means we can check the size just once, then just read directly from the buffer + without constant rechecking of the buffer length. + + + + + Reads a varint from the input one byte at a time, so that it does not + read any bytes after the end of the varint. If you simply wrapped the + stream in a CodedInputStream and used ReadRawVarint32(Stream) + then you would probably end up reading past the end of the varint since + CodedInputStream buffers its input. + + + + + + + Reads a raw varint from the stream. + + + + + Reads a 32-bit little-endian integer from the stream. + + + + + Reads a 64-bit little-endian integer from the stream. + + + + + Decode a 32-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Decode a 32-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Sets currentLimit to (current position) + byteLimit. This is called + when descending into a length-delimited embedded message. The previous + limit is returned. + + The old limit. + + + + Discards the current limit, returning the previous limit. + + + + + Returns whether or not all the data before the limit has been read. + + + + + + Returns true if the stream has reached the end of the input. This is the + case if either the end of the underlying input source has been reached or + the stream has reached a limit created using PushLimit. + + + + + Called when buffer is empty to read more bytes from the + input. If is true, RefillBuffer() gurantees that + either there will be at least one byte in the buffer when it returns + or it will throw an exception. If is false, + RefillBuffer() returns false if no more bytes were available. + + + + + + + Read one byte from the input. + + + the end of the stream or the current limit was reached + + + + + Reads a fixed size of bytes from the input. + + + the end of the stream or the current limit was reached + + + + + Reads and discards bytes. + + the end of the stream + or the current limit was reached + + + + Abstraction of skipping to cope with streams which can't really skip. + + + + + Encodes and writes protocol message fields. + + + + This class is generally used by generated code to write appropriate + primitives to the stream. It effectively encapsulates the lowest + levels of protocol buffer format. Unlike some other implementations, + this does not include combined "write tag and value" methods. Generated + code knows the exact byte representations of the tags they're going to write, + so there's no need to re-encode them each time. Manually-written code calling + this class should just call one of the WriteTag overloads before each value. + + + Repeated fields and map fields are not handled by this class; use RepeatedField<T> + and MapField<TKey, TValue> to serialize such fields. + + + + + + Computes the number of bytes that would be needed to encode a + double field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + float field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + uint64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + int64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + int32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + fixed64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + fixed32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + bool field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + string field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + group field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + embedded message field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + bytes field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + uint32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + enum field, including the tag. The caller is responsible for + converting the enum value to its numeric value. + + + + + Computes the number of bytes that would be needed to encode an + sfixed32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + sfixed64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + sint32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + sint64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a length, + as written by . + + + + + Computes the number of bytes that would be needed to encode a varint. + + + + + Computes the number of bytes that would be needed to encode a varint. + + + + + Computes the number of bytes that would be needed to encode a tag. + + + + + The buffer size used by CreateInstance(Stream). + + + + + Creates a new CodedOutputStream that writes directly to the given + byte array. If more bytes are written than fit in the array, + OutOfSpaceException will be thrown. + + + + + Creates a new CodedOutputStream that writes directly to the given + byte array slice. If more bytes are written than fit in the array, + OutOfSpaceException will be thrown. + + + + + Creates a new which write to the given stream, and disposes of that + stream when the returned CodedOutputStream is disposed. + + The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. + + + + Creates a new CodedOutputStream which write to the given stream and uses + the specified buffer size. + + The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. + The size of buffer to use internally. + + + + Creates a new CodedOutputStream which write to the given stream. + + The stream to write to. + If true, is left open when the returned CodedOutputStream is disposed; + if false, the provided stream is disposed as well. + + + + Creates a new CodedOutputStream which write to the given stream and uses + the specified buffer size. + + The stream to write to. + The size of buffer to use internally. + If true, is left open when the returned CodedOutputStream is disposed; + if false, the provided stream is disposed as well. + + + + Returns the current position in the stream, or the position in the output buffer + + + + + Writes a double field value, without a tag, to the stream. + + The value to write + + + + Writes a float field value, without a tag, to the stream. + + The value to write + + + + Writes a uint64 field value, without a tag, to the stream. + + The value to write + + + + Writes an int64 field value, without a tag, to the stream. + + The value to write + + + + Writes an int32 field value, without a tag, to the stream. + + The value to write + + + + Writes a fixed64 field value, without a tag, to the stream. + + The value to write + + + + Writes a fixed32 field value, without a tag, to the stream. + + The value to write + + + + Writes a bool field value, without a tag, to the stream. + + The value to write + + + + Writes a string field value, without a tag, to the stream. + The data is length-prefixed. + + The value to write + + + + Writes a message, without a tag, to the stream. + The data is length-prefixed. + + The value to write + + + + Write a byte string, without a tag, to the stream. + The data is length-prefixed. + + The value to write + + + + Writes a uint32 value, without a tag, to the stream. + + The value to write + + + + Writes an enum value, without a tag, to the stream. + + The value to write + + + + Writes an sfixed32 value, without a tag, to the stream. + + The value to write. + + + + Writes an sfixed64 value, without a tag, to the stream. + + The value to write + + + + Writes an sint32 value, without a tag, to the stream. + + The value to write + + + + Writes an sint64 value, without a tag, to the stream. + + The value to write + + + + Writes a length (in bytes) for length-delimited data. + + + This method simply writes a rawint, but exists for clarity in calling code. + + Length value, in bytes. + + + + Encodes and writes a tag. + + The number of the field to write the tag for + The wire format type of the tag to write + + + + Writes an already-encoded tag. + + The encoded tag + + + + Writes the given single-byte tag directly to the stream. + + The encoded tag + + + + Writes the given two-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + + + + Writes the given three-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + The third byte of the encoded tag + + + + Writes the given four-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + The third byte of the encoded tag + The fourth byte of the encoded tag + + + + Writes the given five-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + The third byte of the encoded tag + The fourth byte of the encoded tag + The fifth byte of the encoded tag + + + + Writes a 32 bit value as a varint. The fast route is taken when + there's enough buffer space left to whizz through without checking + for each byte; otherwise, we resort to calling WriteRawByte each time. + + + + + Writes out an array of bytes. + + + + + Writes out part of an array of bytes. + + + + + Encode a 32-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Encode a 64-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Indicates that a CodedOutputStream wrapping a flat byte array + ran out of space. + + + + + Flushes any buffered data and optionally closes the underlying stream, if any. + + + + By default, any underlying stream is closed by this method. To configure this behaviour, + use a constructor overload with a leaveOpen parameter. If this instance does not + have an underlying stream, this method does nothing. + + + For the sake of efficiency, calling this method does not prevent future write calls - but + if a later write ends up writing to a stream which has been disposed, that is likely to + fail. It is recommend that you not call any other methods after this. + + + + + + Flushes any buffered data to the underlying stream (if there is one). + + + + + Verifies that SpaceLeft returns zero. It's common to create a byte array + that is exactly big enough to hold a message, then write to it with + a CodedOutputStream. Calling CheckNoSpaceLeft after writing verifies that + the message was actually as big as expected, which can help bugs. + + + + + If writing to a flat array, returns the space left in the array. Otherwise, + throws an InvalidOperationException. + + + + + Representation of a map field in a Protocol Buffer message. + + Key type in the map. Must be a type supported by Protocol Buffer map keys. + Value type in the map. Must be a type supported by Protocol Buffers. + + + For string keys, the equality comparison is provided by . + + + Null values are not permitted in the map, either for wrapper types or regular messages. + If a map is deserialized from a data stream and the value is missing from an entry, a default value + is created instead. For primitive types, that is the regular default value (0, the empty string and so + on); for message types, an empty instance of the message is created, as if the map entry contained a 0-length + encoded value for the field. + + + This implementation does not generally prohibit the use of key/value types which are not + supported by Protocol Buffers (e.g. using a key type of byte) but nor does it guarantee + that all operations will work in such cases. + + + The order in which entries are returned when iterating over this object is undefined, and may change + in future versions. + + + + + + Creates a deep clone of this object. + + + A deep clone of this object. + + + + + Adds the specified key/value pair to the map. + + + This operation fails if the key already exists in the map. To replace an existing entry, use the indexer. + + The key to add + The value to add. + The given key already exists in map. + + + + Determines whether the specified key is present in the map. + + The key to check. + true if the map contains the given key; false otherwise. + + + + Removes the entry identified by the given key from the map. + + The key indicating the entry to remove from the map. + true if the map contained the given key before the entry was removed; false otherwise. + + + + Gets the value associated with the specified key. + + The key whose value to get. + When this method returns, the value associated with the specified key, if the key is found; + otherwise, the default value for the type of the parameter. + This parameter is passed uninitialized. + true if the map contains an element with the specified key; otherwise, false. + + + + Gets or sets the value associated with the specified key. + + The key of the value to get or set. + The property is retrieved and key does not exist in the collection. + The value associated with the specified key. If the specified key is not found, + a get operation throws a , and a set operation creates a new element with the specified key. + + + + Gets a collection containing the keys in the map. + + + + + Gets a collection containing the values in the map. + + + + + Adds the specified entries to the map. The keys and values are not automatically cloned. + + The entries to add to the map. + + + + Returns an enumerator that iterates through the collection. + + + An enumerator that can be used to iterate through the collection. + + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Adds the specified item to the map. + + The item to add to the map. + + + + Removes all items from the map. + + + + + Determines whether map contains an entry equivalent to the given key/value pair. + + The key/value pair to find. + + + + + Copies the key/value pairs in this map to an array. + + The array to copy the entries into. + The index of the array at which to start copying values. + + + + Removes the specified key/value pair from the map. + + Both the key and the value must be found for the entry to be removed. + The key/value pair to remove. + true if the key/value pair was found and removed; false otherwise. + + + + Gets the number of elements contained in the map. + + + + + Gets a value indicating whether the map is read-only. + + + + + Determines whether the specified , is equal to this instance. + + The to compare with this instance. + + true if the specified is equal to this instance; otherwise, false. + + + + + Returns a hash code for this instance. + + + A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. + + + + + Compares this map with another for equality. + + + The order of the key/value pairs in the maps is not deemed significant in this comparison. + + The map to compare this with. + true if refers to an equal map; false otherwise. + + + + Adds entries to the map from the given stream. + + + It is assumed that the stream is initially positioned after the tag specified by the codec. + This method will continue reading entries from the stream until the end is reached, or + a different tag is encountered. + + Stream to read from + Codec describing how the key/value pairs are encoded + + + + Writes the contents of this map to the given coded output stream, using the specified codec + to encode each entry. + + The output stream to write to. + The codec to use for each entry. + + + + Calculates the size of this map based on the given entry codec. + + The codec to use to encode each entry. + + + + + Returns a string representation of this repeated field, in the same + way as it would be represented by the default JSON formatter. + + + + + A codec for a specific map field. This contains all the information required to encode and + decode the nested messages. + + + + + Creates a new entry codec based on a separate key codec and value codec, + and the tag to use for each map entry. + + The key codec. + The value codec. + The map tag to use to introduce each map entry. + + + + The tag used in the enclosing message to indicate map entries. + + + + + A mutable message class, used for parsing and serializing. This + delegates the work to a codec, but implements the interface + for interop with and . + This is nested inside Codec as it's tightly coupled to the associated codec, + and it's simpler if it has direct access to all its fields. + + + + + Read-only wrapper around another dictionary. + + + + + The contents of a repeated field: essentially, a collection with some extra + restrictions (no null values) and capabilities (deep cloning). + + + This implementation does not generally prohibit the use of types which are not + supported by Protocol Buffers but nor does it guarantee that all operations will work in such cases. + + The element type of the repeated field. + + + + Creates a deep clone of this repeated field. + + + If the field type is + a message type, each element is also cloned; otherwise, it is + assumed that the field type is primitive (including string and + bytes, both of which are immutable) and so a simple copy is + equivalent to a deep clone. + + A deep clone of this repeated field. + + + + Adds the entries from the given input stream, decoding them with the specified codec. + + The input stream to read from. + The codec to use in order to read each entry. + + + + Calculates the size of this collection based on the given codec. + + The codec to use when encoding each field. + The number of bytes that would be written to a by , + using the same codec. + + + + Writes the contents of this collection to the given , + encoding each value using the specified codec. + + The output stream to write to. + The codec to use when encoding each value. + + + + Adds the specified item to the collection. + + The item to add. + + + + Removes all items from the collection. + + + + + Determines whether this collection contains the given item. + + The item to find. + true if this collection contains the given item; false otherwise. + + + + Copies this collection to the given array. + + The array to copy to. + The first index of the array to copy to. + + + + Removes the specified item from the collection + + The item to remove. + true if the item was found and removed; false otherwise. + + + + Gets the number of elements contained in the collection. + + + + + Gets a value indicating whether the collection is read-only. + + + + + Adds all of the specified values into this collection. + + The values to add to this collection. + + + + Adds all of the specified values into this collection. This method is present to + allow repeated fields to be constructed from queries within collection initializers. + Within non-collection-initializer code, consider using the equivalent + method instead for clarity. + + The values to add to this collection. + + + + Returns an enumerator that iterates through the collection. + + + An enumerator that can be used to iterate through the collection. + + + + + Determines whether the specified , is equal to this instance. + + The to compare with this instance. + + true if the specified is equal to this instance; otherwise, false. + + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Returns a hash code for this instance. + + + A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. + + + + + Compares this repeated field with another for equality. + + The repeated field to compare this with. + true if refers to an equal repeated field; false otherwise. + + + + Returns the index of the given item within the collection, or -1 if the item is not + present. + + The item to find in the collection. + The zero-based index of the item, or -1 if it is not found. + + + + Inserts the given item at the specified index. + + The index at which to insert the item. + The item to insert. + + + + Removes the item at the given index. + + The zero-based index of the item to remove. + + + + Returns a string representation of this repeated field, in the same + way as it would be represented by the default JSON formatter. + + + + + Gets or sets the item at the specified index. + + + The element at the specified index. + + The zero-based index of the element to get or set. + The item at the specified index. + + + + Extension methods for , effectively providing + the familiar members from previous desktop framework versions while + targeting the newer releases, .NET Core etc. + + + + + Returns the public getter of a property, or null if there is no such getter + (either because it's read-only, or the getter isn't public). + + + + + Returns the public setter of a property, or null if there is no such setter + (either because it's write-only, or the setter isn't public). + + + + + Extension methods for in order to provide + backwards compatibility with .NET 3.5 + + + + + Write the contents of the current stream to the destination stream + + + + + Factory methods for . + + + + + Retrieves a codec suitable for a string field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a bytes field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a bool field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an int32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sint32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a fixed32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sfixed32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a uint32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an int64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sint64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a fixed64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sfixed64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a uint64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a float field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a double field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an enum field with the given tag. + + The tag. + A conversion function from to the enum type. + A conversion function from the enum type to . + A codec for the given tag. + + + + Retrieves a codec suitable for a message field with the given tag. + + The tag. + A parser to use for the message type. + A codec for the given tag. + + + + Creates a codec for a wrapper type of a class - which must be string or ByteString. + + + + + Creates a codec for a wrapper type of a struct - which must be Int32, Int64, UInt32, UInt64, + Bool, Single or Double. + + + + + Helper code to create codecs for wrapper types. + + + Somewhat ugly with all the static methods, but the conversions involved to/from nullable types make it + slightly tricky to improve. So long as we keep the public API (ForClassWrapper, ForStructWrapper) in place, + we can refactor later if we come up with something cleaner. + + + + + Returns a field codec which effectively wraps a value of type T in a message. + + + + + + + An encode/decode pair for a single field. This effectively encapsulates + all the information needed to read or write the field value from/to a coded + stream. + + + This class is public and has to be as it is used by generated code, but its public + API is very limited - just what the generated code needs to call directly. + + + + This never writes default values to the stream, and does not address "packedness" + in repeated fields itself, other than to know whether or not the field *should* be packed. + + + + + Returns a delegate to write a value (unconditionally) to a coded output stream. + + + + + Returns the size calculator for just a value. + + + + + Returns a delegate to read a value from a coded input stream. It is assumed that + the stream is already positioned on the appropriate tag. + + + + + Returns the fixed size for an entry, or 0 if sizes vary. + + + + + Gets the tag of the codec. + + + The tag of the codec. + + + + + Default value for this codec. Usually the same for every instance of the same type, but + for string/ByteString wrapper fields the codec's default value is null, whereas for + other string/ByteString fields it's "" or ByteString.Empty. + + + The default value of the codec's type. + + + + + Write a tag and the given value, *if* the value is not the default. + + + + + Reads a value of the codec type from the given . + + The input stream to read from. + The value read from the stream. + + + + Calculates the size required to write the given value, with a tag, + if the value is not the default. + + + + + Class containing helpful workarounds for various platform compatibility + + + + + A message type that has a custom string format for diagnostic purposes. + + + + Calling on a generated message type normally + returns the JSON representation. If a message type implements this interface, + then the method will be called instead of the regular + JSON formatting code, but only when ToString() is called either on the message itself + or on another message which contains it. This does not affect the normal JSON formatting of + the message. + + + For example, if you create a proto message representing a GUID, the internal + representation may be a bytes field or four fixed32 fields. However, when debugging + it may be more convenient to see a result in the same format as provides. + + This interface extends to avoid it accidentally being implemented + on types other than messages, where it would not be used by anything in the framework. + + + + + Returns a string representation of this object, for diagnostic purposes. + + + This method is called when a message is formatted as part of a + call. It does not affect the JSON representation used by other than + in calls to . While it is recommended + that the result is valid JSON, this is never assumed by the Protobuf library. + + A string representation of this object, for diagnostic purposes. + + + + Generic interface for a deeply cloneable type. + + + + All generated messages implement this interface, but so do some non-message types. + Additionally, due to the type constraint on T in , + it is simpler to keep this as a separate interface. + + + The type itself, returned by the method. + + + + Creates a deep clone of this object. + + A deep clone of this object. + + + + Interface for a Protocol Buffers message, supporting + basic operations required for serialization. + + + + + Merges the data from the specified coded input stream with the current message. + + See the user guide for precise merge semantics. + + + + + Writes the data to the given coded output stream. + + Coded output stream to write the data to. Must not be null. + + + + Calculates the size of this message in Protocol Buffer wire format, in bytes. + + The number of bytes required to write this message + to a coded output stream. + + + + Descriptor for this message. All instances are expected to return the same descriptor, + and for generated types this will be an explicitly-implemented member, returning the + same value as the static property declared on the type. + + + + + Generic interface for a Protocol Buffers message, + where the type parameter is expected to be the same type as + the implementation class. + + The message type. + + + + Merges the given message into this one. + + See the user guide for precise merge semantics. + The message to merge with this one. Must not be null. + + + + Thrown when an attempt is made to parse invalid JSON, e.g. using + a non-string property key, or including a redundant comma. Parsing a protocol buffer + message represented in JSON using can throw both this + exception and depending on the situation. This + exception is only thrown for "pure JSON" errors, whereas InvalidProtocolBufferException + is thrown when the JSON may be valid in and of itself, but cannot be parsed as a protocol buffer + message. + + + + + Thrown when a protocol message being parsed is invalid in some way, + e.g. it contains a malformed varint or a negative byte length. + + + + + Creates an exception for an error condition of an invalid tag being encountered. + + + + + Reflection-based converter from messages to JSON. + + + + Instances of this class are thread-safe, with no mutable state. + + + This is a simple start to get JSON formatting working. As it's reflection-based, + it's not as quick as baking calls into generated messages - but is a simpler implementation. + (This code is generally not heavily optimized.) + + + + + + Returns a formatter using the default settings. + + + + + The JSON representation of the first 160 characters of Unicode. + Empty strings are replaced by the static constructor. + + + + + Creates a new formatted with the given settings. + + The settings. + + + + Formats the specified message as JSON. + + The message to format. + The formatted message. + + + + Formats the specified message as JSON. + + The message to format. + The TextWriter to write the formatted message to. + The formatted message. + + + + Converts a message to JSON for diagnostic purposes with no extra context. + + + + This differs from calling on the default JSON + formatter in its handling of . As no type registry is available + in calls, the normal way of resolving the type of + an Any message cannot be applied. Instead, a JSON property named @value + is included with the base64 data from the property of the message. + + The value returned by this method is only designed to be used for diagnostic + purposes. It may not be parsable by , and may not be parsable + by other Protocol Buffer implementations. + + The message to format for diagnostic purposes. + The diagnostic-only JSON representation of the message + + + + Writes a single value to the given writer as JSON. Only types understood by + Protocol Buffers can be written in this way. This method is only exposed for + advanced use cases; most users should be using + or . + + The writer to write the value to. Must not be null. + The value to write. May be null. + + + + Central interception point for well-known type formatting. Any well-known types which + don't need special handling can fall back to WriteMessage. We avoid assuming that the + values are using the embedded well-known types, in order to allow for dynamic messages + in the future. + + + + + Writes a string (including leading and trailing double quotes) to a builder, escaping as required. + + + Other than surrogate pair handling, this code is mostly taken from src/google/protobuf/util/internal/json_escaping.cc. + + + + + Settings controlling JSON formatting. + + + + + Default settings, as used by + + + + + Whether fields whose values are the default for the field type (e.g. 0 for integers) + should be formatted (true) or omitted (false). + + + + + The type registry used to format messages. + + + + + Whether to format enums as ints. Defaults to false. + + + + + Creates a new object with the specified formatting of default values + and an empty type registry. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + + + + Creates a new object with the specified formatting of default values + and type registry. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + The to use when formatting messages. + + + + Creates a new object with the specified parameters. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + The to use when formatting messages. TypeRegistry.Empty will be used if it is null. + true to format the enums as integers; false to format enums as enum names. + + + + Creates a new object with the specified formatting of default values and the current settings. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + + + + Creates a new object with the specified type registry and the current settings. + + The to use when formatting messages. + + + + Creates a new object with the specified enums formatting option and the current settings. + + true to format the enums as integers; false to format enums as enum names. + + + + Reflection-based converter from JSON to messages. + + + + Instances of this class are thread-safe, with no mutable state. + + + This is a simple start to get JSON parsing working. As it's reflection-based, + it's not as quick as baking calls into generated messages - but is a simpler implementation. + (This code is generally not heavily optimized.) + + + + + + Returns a formatter using the default settings. + + + + + Creates a new formatted with the given settings. + + The settings. + + + + Parses and merges the information into the given message. + + The message to merge the JSON information into. + The JSON to parse. + + + + Parses JSON read from and merges the information into the given message. + + The message to merge the JSON information into. + Reader providing the JSON to parse. + + + + Merges the given message using data from the given tokenizer. In most cases, the next + token should be a "start object" token, but wrapper types and nullity can invalidate + that assumption. This is implemented as an LL(1) recursive descent parser over the stream + of tokens provided by the tokenizer. This token stream is assumed to be valid JSON, with the + tokenizer performing that validation - but not every token stream is valid "protobuf JSON". + + + + + Parses into a new message. + + The type of message to create. + The JSON to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Parses JSON read from into a new message. + + The type of message to create. + Reader providing the JSON to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Parses into a new message. + + The JSON to parse. + Descriptor of message type to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Parses JSON read from into a new message. + + Reader providing the JSON to parse. + Descriptor of message type to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Creates a new instance of the message type for the given field. + + + + + Checks that any infinite/NaN values originated from the correct text. + This corrects the lenient whitespace handling of double.Parse/float.Parse, as well as the + way that Mono parses out-of-range values as infinity. + + + + + Settings controlling JSON parsing. + + + + + Default settings, as used by . This has the same default + recursion limit as , and an empty type registry. + + + + + The maximum depth of messages to parse. Note that this limit only applies to parsing + messages, not collections - so a message within a collection within a message only counts as + depth 2, not 3. + + + + + The type registry used to parse messages. + + + + + Creates a new object with the specified recursion limit. + + The maximum depth of messages to parse + + + + Creates a new object with the specified recursion limit and type registry. + + The maximum depth of messages to parse + The type registry used to parse messages + + + + Simple but strict JSON tokenizer, rigidly following RFC 7159. + + + + This tokenizer is stateful, and only returns "useful" tokens - names, values etc. + It does not create tokens for the separator between names and values, or for the comma + between values. It validates the token stream as it goes - so callers can assume that the + tokens it produces are appropriate. For example, it would never produce "start object, end array." + + Implementation details: the base class handles single token push-back and + Not thread-safe. + + + + + Creates a tokenizer that reads from the given text reader. + + + + + Creates a tokenizer that first replays the given list of tokens, then continues reading + from another tokenizer. Note that if the returned tokenizer is "pushed back", that does not push back + on the continuation tokenizer, or vice versa. Care should be taken when using this method - it was + created for the sake of Any parsing. + + + + + Returns the depth of the stack, purely in objects (not collections). + Informally, this is the number of remaining unclosed '{' characters we have. + + + + + Returns the next JSON token in the stream. An EndDocument token is returned to indicate the end of the stream, + after which point Next() should not be called again. + + This implementation provides single-token buffering, and calls if there is no buffered token. + The next token in the stream. This is never null. + This method is called after an EndDocument token has been returned + The input text does not comply with RFC 7159 + + + + Returns the next JSON token in the stream, when requested by the base class. (The method delegates + to this if it doesn't have a buffered token.) + + This method is called after an EndDocument token has been returned + The input text does not comply with RFC 7159 + + + + Tokenizer which first exhausts a list of tokens, then consults another tokenizer. + + + + + Tokenizer which does all the *real* work of parsing JSON. + + + + + This method essentially just loops through characters skipping whitespace, validating and + changing state (e.g. from ObjectBeforeColon to ObjectAfterColon) + until it reaches something which will be a genuine token (e.g. a start object, or a value) at which point + it returns the token. Although the method is large, it would be relatively hard to break down further... most + of it is the large switch statement, which sometimes returns and sometimes doesn't. + + + + + Reads a string token. It is assumed that the opening " has already been read. + + + + + Reads an escaped character. It is assumed that the leading backslash has already been read. + + + + + Reads an escaped Unicode 4-nybble hex sequence. It is assumed that the leading \u has already been read. + + + + + Consumes a text-only literal, throwing an exception if the read text doesn't match it. + It is assumed that the first letter of the literal has already been read. + + + + + Validates that we're in a valid state to read a value (using the given error prefix if necessary) + and changes the state to the appropriate one, e.g. ObjectAfterColon to ObjectAfterProperty. + + + + + Pops the top-most container, and sets the state to the appropriate one for the end of a value + in the parent container. + + + + + Possible states of the tokenizer. + + + This is a flags enum purely so we can simply and efficiently represent a set of valid states + for checking. + + Each is documented with an example, + where ^ represents the current position within the text stream. The examples all use string values, + but could be any value, including nested objects/arrays. + The complete state of the tokenizer also includes a stack to indicate the contexts (arrays/objects). + Any additional notional state of "AfterValue" indicates that a value has been completed, at which + point there's an immediate transition to ExpectedEndOfDocument, ObjectAfterProperty or ArrayAfterValue. + + + These states were derived manually by reading RFC 7159 carefully. + + + + + + ^ { "foo": "bar" } + Before the value in a document. Next states: ObjectStart, ArrayStart, "AfterValue" + + + + + { "foo": "bar" } ^ + After the value in a document. Next states: ReaderExhausted + + + + + { "foo": "bar" } ^ (and already read to the end of the reader) + Terminal state. + + + + + { ^ "foo": "bar" } + Before the *first* property in an object. + Next states: + "AfterValue" (empty object) + ObjectBeforeColon (read a name) + + + + + { "foo" ^ : "bar", "x": "y" } + Next state: ObjectAfterColon + + + + + { "foo" : ^ "bar", "x": "y" } + Before any property other than the first in an object. + (Equivalently: after any property in an object) + Next states: + "AfterValue" (value is simple) + ObjectStart (value is object) + ArrayStart (value is array) + + + + + { "foo" : "bar" ^ , "x" : "y" } + At the end of a property, so expecting either a comma or end-of-object + Next states: ObjectAfterComma or "AfterValue" + + + + + { "foo":"bar", ^ "x":"y" } + Read the comma after the previous property, so expecting another property. + This is like ObjectStart, but closing brace isn't valid here + Next state: ObjectBeforeColon. + + + + + [ ^ "foo", "bar" ] + Before the *first* value in an array. + Next states: + "AfterValue" (read a value) + "AfterValue" (end of array; will pop stack) + + + + + [ "foo" ^ , "bar" ] + After any value in an array, so expecting either a comma or end-of-array + Next states: ArrayAfterComma or "AfterValue" + + + + + [ "foo", ^ "bar" ] + After a comma in an array, so there *must* be another value (simple or complex). + Next states: "AfterValue" (simple value), StartObject, StartArray + + + + + Wrapper around a text reader allowing small amounts of buffering and location handling. + + + + + The buffered next character, if we have one. + + + + + Returns the next character in the stream, or null if we have reached the end. + + + + + + Creates a new exception appropriate for the current state of the reader. + + + + + Stream implementation which proxies another stream, only allowing a certain amount + of data to be read. Note that this is only used to read delimited streams, so it + doesn't attempt to implement everything. + + + + + Extension methods on and . + + + + + Merges data from the given byte array into an existing message. + + The message to merge the data into. + The data to merge, which must be protobuf-encoded binary data. + + + + Merges data from the given byte string into an existing message. + + The message to merge the data into. + The data to merge, which must be protobuf-encoded binary data. + + + + Merges data from the given stream into an existing message. + + The message to merge the data into. + Stream containing the data to merge, which must be protobuf-encoded binary data. + + + + Merges length-delimited data from the given stream into an existing message. + + + The stream is expected to contain a length and then the data. Only the amount of data + specified by the length will be consumed. + + The message to merge the data into. + Stream containing the data to merge, which must be protobuf-encoded binary data. + + + + Converts the given message into a byte array in protobuf encoding. + + The message to convert. + The message data as a byte array. + + + + Writes the given message data to the given stream in protobuf encoding. + + The message to write to the stream. + The stream to write to. + + + + Writes the length and then data of the given message to a stream. + + The message to write. + The output stream to write to. + + + + Converts the given message into a byte string in protobuf encoding. + + The message to convert. + The message data as a byte string. + + + + A general message parser, typically used by reflection-based code as all the methods + return simple . + + + + + Creates a template instance ready for population. + + An empty message. + + + + Parses a message from a byte array. + + The byte array containing the message. Must not be null. + The newly parsed message. + + + + Parses a message from the given byte string. + + The data to parse. + The parsed message. + + + + Parses a message from the given stream. + + The stream to parse. + The parsed message. + + + + Parses a length-delimited message from the given stream. + + + The stream is expected to contain a length and then the data. Only the amount of data + specified by the length will be consumed. + + The stream to parse. + The parsed message. + + + + Parses a message from the given coded input stream. + + The stream to parse. + The parsed message. + + + + Parses a message from the given JSON. + + The JSON to parse. + The parsed message. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + A parser for a specific message type. + + +

+ This delegates most behavior to the + implementation within the original type, but + provides convenient overloads to parse from a variety of sources. +

+

+ Most applications will never need to create their own instances of this type; + instead, use the static Parser property of a generated message type to obtain a + parser for that type. +

+
+ The type of message to be parsed. +
+ + + Creates a new parser. + + + The factory method is effectively an optimization over using a generic constraint + to require a parameterless constructor: delegates are significantly faster to execute. + + Function to invoke when a new, empty message is required. + + + + Creates a template instance ready for population. + + An empty message. + + + + Parses a message from a byte array. + + The byte array containing the message. Must not be null. + The newly parsed message. + + + + Parses a message from the given byte string. + + The data to parse. + The parsed message. + + + + Parses a message from the given stream. + + The stream to parse. + The parsed message. + + + + Parses a length-delimited message from the given stream. + + + The stream is expected to contain a length and then the data. Only the amount of data + specified by the length will be consumed. + + The stream to parse. + The parsed message. + + + + Parses a message from the given coded input stream. + + The stream to parse. + The parsed message. + + + + Parses a message from the given JSON. + + The JSON to parse. + The parsed message. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Helper methods for throwing exceptions when preconditions are not met. + + + This class is used internally and by generated code; it is not particularly + expected to be used from application code, although nothing prevents it + from being used that way. + + + + + Throws an ArgumentNullException if the given value is null, otherwise + return the value to the caller. + + + + + Throws an ArgumentNullException if the given value is null, otherwise + return the value to the caller. + + + This is equivalent to but without the type parameter + constraint. In most cases, the constraint is useful to prevent you from calling CheckNotNull + with a value type - but it gets in the way if either you want to use it with a nullable + value type, or you want to use it with an unconstrained type parameter. + + + + + Container for a set of custom options specified within a message, field etc. + + + + This type is publicly immutable, but internally mutable. It is only populated + by the descriptor parsing code - by the time any user code is able to see an instance, + it will be fully initialized. + + + If an option is requested using the incorrect method, an answer may still be returned: all + of the numeric types are represented internally using 64-bit integers, for example. It is up to + the caller to ensure that they make the appropriate method call for the option they're interested in. + Note that enum options are simply stored as integers, so the value should be fetched using + and then cast appropriately. + + + Repeated options are currently not supported. Asking for a single value of an option + which was actually repeated will return the last value, except for message types where + all the set values are merged together. + + + + + + Singleton for all descriptors with an empty set of options. + + + + + A sequence of values per field. This needs to be per field rather than per tag to allow correct deserialization + of repeated fields which could be "int, ByteString, int" - unlikely as that is. The fact that values are boxed + is unfortunate; we might be able to use a struct instead, and we could combine uint and ulong values. + + + + + Retrieves a Boolean value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 32-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 64-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 32-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 64-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 32-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 64-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 32-bit integer value for the specified option field, + assuming a zigzag encoding. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 64-bit integer value for the specified option field, + assuming a zigzag encoding. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 32-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 64-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a 32-bit floating point value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a 64-bit floating point value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a string value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a bytes value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a message value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Reads an unknown field, either parsing it and storing it or skipping it. + + + If the current set of options is empty and we manage to read a field, a new set of options + will be created and returned. Otherwise, the return value is this. This allows + us to start with a singleton empty set of options and just create new ones where necessary. + + Input stream to read from. + The resulting set of custom options, either this or a new set. + + + + All field values can be stored as a byte string or a 64-bit integer. + This struct avoids unnecessary boxing. + + + + Holder for reflection information generated from google/protobuf/descriptor.proto + + + File descriptor for google/protobuf/descriptor.proto + + + + The protocol compiler can output a FileDescriptorSet containing the .proto + files it parses. + + + + Field number for the "file" field. + + + + Describes a complete .proto file. + + + + Field number for the "name" field. + + + + file name, relative to root of source tree + + + + Field number for the "package" field. + + + + e.g. "foo", "foo.bar", etc. + + + + Field number for the "dependency" field. + + + + Names of files imported by this file. + + + + Field number for the "public_dependency" field. + + + + Indexes of the public imported files in the dependency list above. + + + + Field number for the "weak_dependency" field. + + + + Indexes of the weak imported files in the dependency list. + For Google-internal migration only. Do not use. + + + + Field number for the "message_type" field. + + + + All top-level definitions in this file. + + + + Field number for the "enum_type" field. + + + Field number for the "service" field. + + + Field number for the "extension" field. + + + Field number for the "options" field. + + + Field number for the "source_code_info" field. + + + + This field contains optional information about the original source code. + You may safely remove this entire field without harming runtime + functionality of the descriptors -- the information is needed only by + development tools. + + + + Field number for the "syntax" field. + + + + The syntax of the proto file. + The supported values are "proto2" and "proto3". + + + + + Describes a message type. + + + + Field number for the "name" field. + + + Field number for the "field" field. + + + Field number for the "extension" field. + + + Field number for the "nested_type" field. + + + Field number for the "enum_type" field. + + + Field number for the "extension_range" field. + + + Field number for the "oneof_decl" field. + + + Field number for the "options" field. + + + Field number for the "reserved_range" field. + + + Field number for the "reserved_name" field. + + + + Reserved field names, which may not be used by fields in the same message. + A given name may only be reserved once. + + + + Container for nested types declared in the DescriptorProto message type. + + + Field number for the "start" field. + + + Field number for the "end" field. + + + + Range of reserved tag numbers. Reserved tag numbers may not be used by + fields or extension ranges in the same message. Reserved ranges may + not overlap. + + + + Field number for the "start" field. + + + + Inclusive. + + + + Field number for the "end" field. + + + + Exclusive. + + + + + Describes a field within a message. + + + + Field number for the "name" field. + + + Field number for the "number" field. + + + Field number for the "label" field. + + + Field number for the "type" field. + + + + If type_name is set, this need not be set. If both this and type_name + are set, this must be one of TYPE_ENUM, TYPE_MESSAGE or TYPE_GROUP. + + + + Field number for the "type_name" field. + + + + For message and enum types, this is the name of the type. If the name + starts with a '.', it is fully-qualified. Otherwise, C++-like scoping + rules are used to find the type (i.e. first the nested types within this + message are searched, then within the parent, on up to the root + namespace). + + + + Field number for the "extendee" field. + + + + For extensions, this is the name of the type being extended. It is + resolved in the same manner as type_name. + + + + Field number for the "default_value" field. + + + + For numeric types, contains the original text representation of the value. + For booleans, "true" or "false". + For strings, contains the default text contents (not escaped in any way). + For bytes, contains the C escaped value. All bytes >= 128 are escaped. + TODO(kenton): Base-64 encode? + + + + Field number for the "oneof_index" field. + + + + If set, gives the index of a oneof in the containing type's oneof_decl + list. This field is a member of that oneof. + + + + Field number for the "json_name" field. + + + + JSON name of this field. The value is set by protocol compiler. If the + user has set a "json_name" option on this field, that option's value + will be used. Otherwise, it's deduced from the field's name by converting + it to camelCase. + + + + Field number for the "options" field. + + + Container for nested types declared in the FieldDescriptorProto message type. + + + + 0 is reserved for errors. + Order is weird for historical reasons. + + + + + Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT64 if + negative values are likely. + + + + + Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT32 if + negative values are likely. + + + + + Tag-delimited aggregate. + Group type is deprecated and not supported in proto3. However, Proto3 + implementations should still be able to parse the group wire format and + treat group fields as unknown fields. + + + + + Length-delimited aggregate. + + + + + New in version 2. + + + + + Uses ZigZag encoding. + + + + + Uses ZigZag encoding. + + + + + 0 is reserved for errors + + + + + Describes a oneof. + + + + Field number for the "name" field. + + + Field number for the "options" field. + + + + Describes an enum type. + + + + Field number for the "name" field. + + + Field number for the "value" field. + + + Field number for the "options" field. + + + + Describes a value within an enum. + + + + Field number for the "name" field. + + + Field number for the "number" field. + + + Field number for the "options" field. + + + + Describes a service. + + + + Field number for the "name" field. + + + Field number for the "method" field. + + + Field number for the "options" field. + + + + Describes a method of a service. + + + + Field number for the "name" field. + + + Field number for the "input_type" field. + + + + Input and output type names. These are resolved in the same way as + FieldDescriptorProto.type_name, but must refer to a message type. + + + + Field number for the "output_type" field. + + + Field number for the "options" field. + + + Field number for the "client_streaming" field. + + + + Identifies if client streams multiple client messages + + + + Field number for the "server_streaming" field. + + + + Identifies if server streams multiple server messages + + + + Field number for the "java_package" field. + + + + Sets the Java package where classes generated from this .proto will be + placed. By default, the proto package is used, but this is often + inappropriate because proto packages do not normally start with backwards + domain names. + + + + Field number for the "java_outer_classname" field. + + + + If set, all the classes from the .proto file are wrapped in a single + outer class with the given name. This applies to both Proto1 + (equivalent to the old "--one_java_file" option) and Proto2 (where + a .proto always translates to a single class, but you may want to + explicitly choose the class name). + + + + Field number for the "java_multiple_files" field. + + + + If set true, then the Java code generator will generate a separate .java + file for each top-level message, enum, and service defined in the .proto + file. Thus, these types will *not* be nested inside the outer class + named by java_outer_classname. However, the outer class will still be + generated to contain the file's getDescriptor() method as well as any + top-level extensions defined in the file. + + + + Field number for the "java_generate_equals_and_hash" field. + + + + This option does nothing. + + + + Field number for the "java_string_check_utf8" field. + + + + If set true, then the Java2 code generator will generate code that + throws an exception whenever an attempt is made to assign a non-UTF-8 + byte sequence to a string field. + Message reflection will do the same. + However, an extension field still accepts non-UTF-8 byte sequences. + This option has no effect on when used with the lite runtime. + + + + Field number for the "optimize_for" field. + + + Field number for the "go_package" field. + + + + Sets the Go package where structs generated from this .proto will be + placed. If omitted, the Go package will be derived from the following: + - The basename of the package import path, if provided. + - Otherwise, the package statement in the .proto file, if present. + - Otherwise, the basename of the .proto file, without extension. + + + + Field number for the "cc_generic_services" field. + + + + Should generic services be generated in each language? "Generic" services + are not specific to any particular RPC system. They are generated by the + main code generators in each language (without additional plugins). + Generic services were the only kind of service generation supported by + early versions of google.protobuf. + + Generic services are now considered deprecated in favor of using plugins + that generate code specific to your particular RPC system. Therefore, + these default to false. Old code which depends on generic services should + explicitly set them to true. + + + + Field number for the "java_generic_services" field. + + + Field number for the "py_generic_services" field. + + + Field number for the "deprecated" field. + + + + Is this file deprecated? + Depending on the target platform, this can emit Deprecated annotations + for everything in the file, or it will be completely ignored; in the very + least, this is a formalization for deprecating files. + + + + Field number for the "cc_enable_arenas" field. + + + + Enables the use of arenas for the proto messages in this file. This applies + only to generated classes for C++. + + + + Field number for the "objc_class_prefix" field. + + + + Sets the objective c class prefix which is prepended to all objective c + generated classes from this .proto. There is no default. + + + + Field number for the "csharp_namespace" field. + + + + Namespace for generated classes; defaults to the package. + + + + Field number for the "swift_prefix" field. + + + + By default Swift generators will take the proto package and CamelCase it + replacing '.' with underscore and use that to prefix the types/symbols + defined. When this options is provided, they will use this value instead + to prefix the types/symbols defined. + + + + Field number for the "php_class_prefix" field. + + + + Sets the php class prefix which is prepended to all php generated classes + from this .proto. Default is empty. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Container for nested types declared in the FileOptions message type. + + + + Generated classes can be optimized for speed or code size. + + + + + Generate complete code for parsing, serialization, + + + + + etc. + + + + + Generate code using MessageLite and the lite runtime. + + + + Field number for the "message_set_wire_format" field. + + + + Set true to use the old proto1 MessageSet wire format for extensions. + This is provided for backwards-compatibility with the MessageSet wire + format. You should not use this for any other reason: It's less + efficient, has fewer features, and is more complicated. + + The message must be defined exactly as follows: + message Foo { + option message_set_wire_format = true; + extensions 4 to max; + } + Note that the message cannot have any defined fields; MessageSets only + have extensions. + + All extensions of your type must be singular messages; e.g. they cannot + be int32s, enums, or repeated messages. + + Because this is an option, the above two restrictions are not enforced by + the protocol compiler. + + + + Field number for the "no_standard_descriptor_accessor" field. + + + + Disables the generation of the standard "descriptor()" accessor, which can + conflict with a field of the same name. This is meant to make migration + from proto1 easier; new code should avoid fields named "descriptor". + + + + Field number for the "deprecated" field. + + + + Is this message deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the message, or it will be completely ignored; in the very least, + this is a formalization for deprecating messages. + + + + Field number for the "map_entry" field. + + + + Whether the message is an automatically generated map entry type for the + maps field. + + For maps fields: + map<KeyType, ValueType> map_field = 1; + The parsed descriptor looks like: + message MapFieldEntry { + option map_entry = true; + optional KeyType key = 1; + optional ValueType value = 2; + } + repeated MapFieldEntry map_field = 1; + + Implementations may choose not to generate the map_entry=true message, but + use a native map in the target language to hold the keys and values. + The reflection APIs in such implementions still need to work as + if the field is a repeated message field. + + NOTE: Do not set the option in .proto files. Always use the maps syntax + instead. The option should only be implicitly set by the proto compiler + parser. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "ctype" field. + + + + The ctype option instructs the C++ code generator to use a different + representation of the field than it normally would. See the specific + options below. This option is not yet implemented in the open source + release -- sorry, we'll try to include it in a future version! + + + + Field number for the "packed" field. + + + + The packed option can be enabled for repeated primitive fields to enable + a more efficient representation on the wire. Rather than repeatedly + writing the tag and type for each element, the entire array is encoded as + a single length-delimited blob. In proto3, only explicit setting it to + false will avoid using packed encoding. + + + + Field number for the "jstype" field. + + + + The jstype option determines the JavaScript type used for values of the + field. The option is permitted only for 64 bit integral and fixed types + (int64, uint64, sint64, fixed64, sfixed64). By default these types are + represented as JavaScript strings. This avoids loss of precision that can + happen when a large value is converted to a floating point JavaScript + numbers. Specifying JS_NUMBER for the jstype causes the generated + JavaScript code to use the JavaScript "number" type instead of strings. + This option is an enum to permit additional types to be added, + e.g. goog.math.Integer. + + + + Field number for the "lazy" field. + + + + Should this field be parsed lazily? Lazy applies only to message-type + fields. It means that when the outer message is initially parsed, the + inner message's contents will not be parsed but instead stored in encoded + form. The inner message will actually be parsed when it is first accessed. + + This is only a hint. Implementations are free to choose whether to use + eager or lazy parsing regardless of the value of this option. However, + setting this option true suggests that the protocol author believes that + using lazy parsing on this field is worth the additional bookkeeping + overhead typically needed to implement it. + + This option does not affect the public interface of any generated code; + all method signatures remain the same. Furthermore, thread-safety of the + interface is not affected by this option; const methods remain safe to + call from multiple threads concurrently, while non-const methods continue + to require exclusive access. + + Note that implementations may choose not to check required fields within + a lazy sub-message. That is, calling IsInitialized() on the outer message + may return true even if the inner message has missing required fields. + This is necessary because otherwise the inner message would have to be + parsed in order to perform the check, defeating the purpose of lazy + parsing. An implementation which chooses not to check required fields + must be consistent about it. That is, for any particular sub-message, the + implementation must either *always* check its required fields, or *never* + check its required fields, regardless of whether or not the message has + been parsed. + + + + Field number for the "deprecated" field. + + + + Is this field deprecated? + Depending on the target platform, this can emit Deprecated annotations + for accessors, or it will be completely ignored; in the very least, this + is a formalization for deprecating fields. + + + + Field number for the "weak" field. + + + + For Google-internal migration only. Do not use. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Container for nested types declared in the FieldOptions message type. + + + + Default mode. + + + + + Use the default type. + + + + + Use JavaScript strings. + + + + + Use JavaScript numbers. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "allow_alias" field. + + + + Set this option to true to allow mapping different tag names to the same + value. + + + + Field number for the "deprecated" field. + + + + Is this enum deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the enum, or it will be completely ignored; in the very least, this + is a formalization for deprecating enums. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "deprecated" field. + + + + Is this enum value deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the enum value, or it will be completely ignored; in the very least, + this is a formalization for deprecating enum values. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "deprecated" field. + + + + Is this service deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the service, or it will be completely ignored; in the very least, + this is a formalization for deprecating services. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "deprecated" field. + + + + Is this method deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the method, or it will be completely ignored; in the very least, + this is a formalization for deprecating methods. + + + + Field number for the "idempotency_level" field. + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Container for nested types declared in the MethodOptions message type. + + + + Is this method side-effect-free (or safe in HTTP parlance), or idempotent, + or neither? HTTP based RPC implementation may choose GET verb for safe + methods, and PUT verb for idempotent methods instead of the default POST. + + + + + implies idempotent + + + + + idempotent, but may have side effects + + + + + A message representing a option the parser does not recognize. This only + appears in options protos created by the compiler::Parser class. + DescriptorPool resolves these when building Descriptor objects. Therefore, + options protos in descriptor objects (e.g. returned by Descriptor::options(), + or produced by Descriptor::CopyTo()) will never have UninterpretedOptions + in them. + + + + Field number for the "name" field. + + + Field number for the "identifier_value" field. + + + + The value of the uninterpreted option, in whatever type the tokenizer + identified it as during parsing. Exactly one of these should be set. + + + + Field number for the "positive_int_value" field. + + + Field number for the "negative_int_value" field. + + + Field number for the "double_value" field. + + + Field number for the "string_value" field. + + + Field number for the "aggregate_value" field. + + + Container for nested types declared in the UninterpretedOption message type. + + + + The name of the uninterpreted option. Each string represents a segment in + a dot-separated name. is_extension is true iff a segment represents an + extension (denoted with parentheses in options specs in .proto files). + E.g.,{ ["foo", false], ["bar.baz", true], ["qux", false] } represents + "foo.(bar.baz).qux". + + + + Field number for the "name_part" field. + + + Field number for the "is_extension" field. + + + + Encapsulates information about the original source file from which a + FileDescriptorProto was generated. + + + + Field number for the "location" field. + + + + A Location identifies a piece of source code in a .proto file which + corresponds to a particular definition. This information is intended + to be useful to IDEs, code indexers, documentation generators, and similar + tools. + + For example, say we have a file like: + message Foo { + optional string foo = 1; + } + Let's look at just the field definition: + optional string foo = 1; + ^ ^^ ^^ ^ ^^^ + a bc de f ghi + We have the following locations: + span path represents + [a,i) [ 4, 0, 2, 0 ] The whole field definition. + [a,b) [ 4, 0, 2, 0, 4 ] The label (optional). + [c,d) [ 4, 0, 2, 0, 5 ] The type (string). + [e,f) [ 4, 0, 2, 0, 1 ] The name (foo). + [g,h) [ 4, 0, 2, 0, 3 ] The number (1). + + Notes: + - A location may refer to a repeated field itself (i.e. not to any + particular index within it). This is used whenever a set of elements are + logically enclosed in a single code segment. For example, an entire + extend block (possibly containing multiple extension definitions) will + have an outer location whose path refers to the "extensions" repeated + field without an index. + - Multiple locations may have the same path. This happens when a single + logical declaration is spread out across multiple places. The most + obvious example is the "extend" block again -- there may be multiple + extend blocks in the same scope, each of which will have the same path. + - A location's span is not always a subset of its parent's span. For + example, the "extendee" of an extension declaration appears at the + beginning of the "extend" block and is shared by all extensions within + the block. + - Just because a location's span is a subset of some other location's span + does not mean that it is a descendent. For example, a "group" defines + both a type and a field in a single declaration. Thus, the locations + corresponding to the type and field and their components will overlap. + - Code which tries to interpret locations should probably be designed to + ignore those that it doesn't understand, as more types of locations could + be recorded in the future. + + + + Container for nested types declared in the SourceCodeInfo message type. + + + Field number for the "path" field. + + + + Identifies which part of the FileDescriptorProto was defined at this + location. + + Each element is a field number or an index. They form a path from + the root FileDescriptorProto to the place where the definition. For + example, this path: + [ 4, 3, 2, 7, 1 ] + refers to: + file.message_type(3) // 4, 3 + .field(7) // 2, 7 + .name() // 1 + This is because FileDescriptorProto.message_type has field number 4: + repeated DescriptorProto message_type = 4; + and DescriptorProto.field has field number 2: + repeated FieldDescriptorProto field = 2; + and FieldDescriptorProto.name has field number 1: + optional string name = 1; + + Thus, the above path gives the location of a field name. If we removed + the last element: + [ 4, 3, 2, 7 ] + this path refers to the whole field declaration (from the beginning + of the label to the terminating semicolon). + + + + Field number for the "span" field. + + + + Always has exactly three or four elements: start line, start column, + end line (optional, otherwise assumed same as start line), end column. + These are packed into a single field for efficiency. Note that line + and column numbers are zero-based -- typically you will want to add + 1 to each before displaying to a user. + + + + Field number for the "leading_comments" field. + + + + If this SourceCodeInfo represents a complete declaration, these are any + comments appearing before and after the declaration which appear to be + attached to the declaration. + + A series of line comments appearing on consecutive lines, with no other + tokens appearing on those lines, will be treated as a single comment. + + leading_detached_comments will keep paragraphs of comments that appear + before (but not connected to) the current element. Each paragraph, + separated by empty lines, will be one comment element in the repeated + field. + + Only the comment content is provided; comment markers (e.g. //) are + stripped out. For block comments, leading whitespace and an asterisk + will be stripped from the beginning of each line other than the first. + Newlines are included in the output. + + Examples: + + optional int32 foo = 1; // Comment attached to foo. + // Comment attached to bar. + optional int32 bar = 2; + + optional string baz = 3; + // Comment attached to baz. + // Another line attached to baz. + + // Comment attached to qux. + // + // Another line attached to qux. + optional double qux = 4; + + // Detached comment for corge. This is not leading or trailing comments + // to qux or corge because there are blank lines separating it from + // both. + + // Detached comment for corge paragraph 2. + + optional string corge = 5; + /* Block comment attached + * to corge. Leading asterisks + * will be removed. */ + /* Block comment attached to + * grault. */ + optional int32 grault = 6; + + // ignored detached comments. + + + + Field number for the "trailing_comments" field. + + + Field number for the "leading_detached_comments" field. + + + + Describes the relationship between generated code and its original source + file. A GeneratedCodeInfo message is associated with only one generated + source file, but may contain references to different source .proto files. + + + + Field number for the "annotation" field. + + + + An Annotation connects some span of text in generated code to an element + of its generating .proto file. + + + + Container for nested types declared in the GeneratedCodeInfo message type. + + + Field number for the "path" field. + + + + Identifies the element in the original source .proto file. This field + is formatted the same as SourceCodeInfo.Location.path. + + + + Field number for the "source_file" field. + + + + Identifies the filesystem path to the original source .proto. + + + + Field number for the "begin" field. + + + + Identifies the starting offset in bytes in the generated code + that relates to the identified object. + + + + Field number for the "end" field. + + + + Identifies the ending offset in bytes in the generated code that + relates to the identified offset. The end offset should be one past + the last relevant byte (so the length of the text = end - begin). + + + + + Base class for nearly all descriptors, providing common functionality. + + + + + The index of this descriptor within its parent descriptor. + + + This returns the index of this descriptor within its parent, for + this descriptor's type. (There can be duplicate values for different + types, e.g. one enum type with index 0 and one message type with index 0.) + + + + + Returns the name of the entity (field, message etc) being described. + + + + + The fully qualified name of the descriptor's target. + + + + + The file this descriptor was declared in. + + + + + Contains lookup tables containing all the descriptors defined in a particular file. + + + + + Finds a symbol of the given name within the pool. + + The type of symbol to look for + Fully-qualified name to look up + The symbol with the given name and type, + or null if the symbol doesn't exist or has the wrong type + + + + Adds a package to the symbol tables. If a package by the same name + already exists, that is fine, but if some other kind of symbol + exists under the same name, an exception is thrown. If the package + has multiple components, this also adds the parent package(s). + + + + + Adds a symbol to the symbol table. + + The symbol already existed + in the symbol table. + + + + Verifies that the descriptor's name is valid (i.e. it contains + only letters, digits and underscores, and does not start with a digit). + + + + + + Returns the field with the given number in the given descriptor, + or null if it can't be found. + + + + + Adds a field to the fieldsByNumber table. + + A field with the same + containing type and number already exists. + + + + Adds an enum value to the enumValuesByNumber table. If an enum value + with the same type and number already exists, this method does nothing. + (This is allowed; the first value defined with the number takes precedence.) + + + + + Looks up a descriptor by name, relative to some other descriptor. + The name may be fully-qualified (with a leading '.'), partially-qualified, + or unqualified. C++-like name lookup semantics are used to search for the + matching descriptor. + + + This isn't heavily optimized, but it's only used during cross linking anyway. + If it starts being used more widely, we should look at performance more carefully. + + + + + Struct used to hold the keys for the fieldByNumber table. + + + + + Internal class containing utility methods when working with descriptors. + + + + + Equivalent to Func[TInput, int, TOutput] but usable in .NET 2.0. Only used to convert + arrays. + + + + + Converts the given array into a read-only list, applying the specified conversion to + each input element. + + + + + Thrown when building descriptors fails because the source DescriptorProtos + are not valid. + + + + + The full name of the descriptor where the error occurred. + + + + + A human-readable description of the error. (The Message property + is made up of the descriptor's name and this description.) + + + + + Descriptor for an enum type in a .proto file. + + + + + The brief name of the descriptor's target. + + + + + The CLR type for this enum. For generated code, this will be a CLR enum type. + + + + + If this is a nested type, get the outer descriptor, otherwise null. + + + + + An unmodifiable list of defined value descriptors for this enum. + + + + + Finds an enum value by number. If multiple enum values have the + same number, this returns the first defined value with that number. + If there is no value for the given number, this returns null. + + + + + Finds an enum value by name. + + The unqualified name of the value (e.g. "FOO"). + The value's descriptor, or null if not found. + + + + The (possibly empty) set of custom options for this enum. + + + + + Descriptor for a single enum value within an enum in a .proto file. + + + + + Returns the name of the enum value described by this object. + + + + + Returns the number associated with this enum value. + + + + + Returns the enum descriptor that this value is part of. + + + + + The (possibly empty) set of custom options for this enum value. + + + + + Base class for field accessors. + + + + + Descriptor for a field or extension within a message in a .proto file. + + + + + Get the field's containing message type. + + + + + Returns the oneof containing this field, or null if it is not part of a oneof. + + + + + The effective JSON name for this field. This is usually the lower-camel-cased form of the field name, + but can be overridden using the json_name option in the .proto file. + + + + + The brief name of the descriptor's target. + + + + + Returns the accessor for this field. + + + + While a describes the field, it does not provide + any way of obtaining or changing the value of the field within a specific message; + that is the responsibility of the accessor. + + + The value returned by this property will be non-null for all regular fields. However, + if a message containing a map field is introspected, the list of nested messages will include + an auto-generated nested key/value pair message for the field. This is not represented in any + generated type, and the value of the map field itself is represented by a dictionary in the + reflection API. There are never instances of those "hidden" messages, so no accessor is provided + and this property will return null. + + + + + + Maps a field type as included in the .proto file to a FieldType. + + + + + Returns true if this field is a repeated field; false otherwise. + + + + + Returns true if this field is a map field; false otherwise. + + + + + Returns true if this field is a packed, repeated field; false otherwise. + + + + + Returns the type of the field. + + + + + Returns the field number declared in the proto file. + + + + + Compares this descriptor with another one, ordering in "canonical" order + which simply means ascending order by field number. + must be a field of the same type, i.e. the of + both fields must be the same. + + + + + For enum fields, returns the field's type. + + + + + For embedded message and group fields, returns the field's type. + + + + + The (possibly empty) set of custom options for this field. + + + + + Look up and cross-link all field types etc. + + + + + Enumeration of all the possible field types. + + + + + The double field type. + + + + + The float field type. + + + + + The int64 field type. + + + + + The uint64 field type. + + + + + The int32 field type. + + + + + The fixed64 field type. + + + + + The fixed32 field type. + + + + + The bool field type. + + + + + The string field type. + + + + + The field type used for groups (not supported in this implementation). + + + + + The field type used for message fields. + + + + + The bytes field type. + + + + + The uint32 field type. + + + + + The sfixed32 field type. + + + + + The sfixed64 field type. + + + + + The sint32 field type. + + + + + The sint64 field type. + + + + + The field type used for enum fields. + + + + + Describes a .proto file, including everything defined within. + IDescriptor is implemented such that the File property returns this descriptor, + and the FullName is the same as the Name. + + + + + Computes the full name of a descriptor within this file, with an optional parent message. + + + + + Extracts public dependencies from direct dependencies. This is a static method despite its + first parameter, as the value we're in the middle of constructing is only used for exceptions. + + + + + The descriptor in its protocol message representation. + + + + + The file name. + + + + + The package as declared in the .proto file. This may or may not + be equivalent to the .NET namespace of the generated classes. + + + + + Unmodifiable list of top-level message types declared in this file. + + + + + Unmodifiable list of top-level enum types declared in this file. + + + + + Unmodifiable list of top-level services declared in this file. + + + + + Unmodifiable list of this file's dependencies (imports). + + + + + Unmodifiable list of this file's public dependencies (public imports). + + + + + The original serialized binary form of this descriptor. + + + + + Implementation of IDescriptor.FullName - just returns the same as Name. + + + + + Implementation of IDescriptor.File - just returns this descriptor. + + + + + Pool containing symbol descriptors. + + + + + Finds a type (message, enum, service or extension) in the file by name. Does not find nested types. + + The unqualified type name to look for. + The type of descriptor to look for + The type's descriptor, or null if not found. + + + + Builds a FileDescriptor from its protocol buffer representation. + + The original serialized descriptor data. + We have only limited proto2 support, so serializing FileDescriptorProto + would not necessarily give us this. + The protocol message form of the FileDescriptor. + FileDescriptors corresponding to all of the + file's dependencies, in the exact order listed in the .proto file. May be null, + in which case it is treated as an empty array. + Whether unknown dependencies are ignored (true) or cause an exception to be thrown (false). + Details about generated code, for the purposes of reflection. + If is not + a valid descriptor. This can occur for a number of reasons, such as a field + having an undefined type or because two messages were defined with the same name. + + + + Creates a descriptor for generated code. + + + This method is only designed to be used by the results of generating code with protoc, + which creates the appropriate dependencies etc. It has to be public because the generated + code is "external", but should not be called directly by end users. + + + + + Returns a that represents this instance. + + + A that represents this instance. + + + + + Returns the file descriptor for descriptor.proto. + + + This is used for protos which take a direct dependency on descriptor.proto, typically for + annotations. While descriptor.proto is a proto2 file, it is built into the Google.Protobuf + runtime for reflection purposes. The messages are internal to the runtime as they would require + proto2 semantics for full support, but the file descriptor is available via this property. The + C# codegen in protoc automatically uses this property when it detects a dependency on descriptor.proto. + + + The file descriptor for descriptor.proto. + + + + + The (possibly empty) set of custom options for this file. + + + + + Extra information provided by generated code when initializing a message or file descriptor. + These are constructed as required, and are not long-lived. Hand-written code should + never need to use this type. + + + + + Irrelevant for file descriptors; the CLR type for the message for message descriptors. + + + + + Irrelevant for file descriptors; the parser for message descriptors. + + + + + Irrelevant for file descriptors; the CLR property names (in message descriptor field order) + for fields in the message for message descriptors. + + + + + Irrelevant for file descriptors; the CLR property "base" names (in message descriptor oneof order) + for oneofs in the message for message descriptors. It is expected that for a oneof name of "Foo", + there will be a "FooCase" property and a "ClearFoo" method. + + + + + The reflection information for types within this file/message descriptor. Elements may be null + if there is no corresponding generated type, e.g. for map entry types. + + + + + The CLR types for enums within this file/message descriptor. + + + + + Creates a GeneratedClrTypeInfo for a message descriptor, with nested types, nested enums, the CLR type, property names and oneof names. + Each array parameter may be null, to indicate a lack of values. + The parameter order is designed to make it feasible to format the generated code readably. + + + + + Creates a GeneratedClrTypeInfo for a file descriptor, with only types and enums. + + + + + Interface implemented by all descriptor types. + + + + + Returns the name of the entity (message, field etc) being described. + + + + + Returns the fully-qualified name of the entity being described. + + + + + Returns the descriptor for the .proto file that this entity is part of. + + + + + Allows fields to be reflectively accessed. + + + + + Returns the descriptor associated with this field. + + + + + Clears the field in the specified message. (For repeated fields, + this clears the list.) + + + + + Fetches the field value. For repeated values, this will be an + implementation. For map values, this will be an + implementation. + + + + + Mutator for single "simple" fields only. + + + Repeated fields are mutated by fetching the value and manipulating it as a list. + Map fields are mutated by fetching the value and manipulating it as a dictionary. + + The field is not a "simple" field. + + + + Accessor for map fields. + + + + + Describes a message type. + + + + + The brief name of the descriptor's target. + + + + + The CLR type used to represent message instances from this descriptor. + + + + The value returned by this property will be non-null for all regular fields. However, + if a message containing a map field is introspected, the list of nested messages will include + an auto-generated nested key/value pair message for the field. This is not represented in any + generated type, so this property will return null in such cases. + + + For wrapper types ( and the like), the type returned here + will be the generated message type, not the native type used by reflection for fields of those types. Code + using reflection should call to determine whether a message descriptor represents + a wrapper type, and handle the result appropriately. + + + + + + A parser for this message type. + + + + As is not generic, this cannot be statically + typed to the relevant type, but it should produce objects of a type compatible with . + + + The value returned by this property will be non-null for all regular fields. However, + if a message containing a map field is introspected, the list of nested messages will include + an auto-generated nested key/value pair message for the field. No message parser object is created for + such messages, so this property will return null in such cases. + + + For wrapper types ( and the like), the parser returned here + will be the generated message type, not the native type used by reflection for fields of those types. Code + using reflection should call to determine whether a message descriptor represents + a wrapper type, and handle the result appropriately. + + + + + + Returns whether this message is one of the "well known types" which may have runtime/protoc support. + + + + + Returns whether this message is one of the "wrapper types" used for fields which represent primitive values + with the addition of presence. + + + + + If this is a nested type, get the outer descriptor, otherwise null. + + + + + A collection of fields, which can be retrieved by name or field number. + + + + + An unmodifiable list of this message type's nested types. + + + + + An unmodifiable list of this message type's enum types. + + + + + An unmodifiable list of the "oneof" field collections in this message type. + + + + + Finds a field by field name. + + The unqualified name of the field (e.g. "foo"). + The field's descriptor, or null if not found. + + + + Finds a field by field number. + + The field number within this message type. + The field's descriptor, or null if not found. + + + + Finds a nested descriptor by name. The is valid for fields, nested + message types, oneofs and enums. + + The unqualified name of the descriptor, e.g. "Foo" + The descriptor, or null if not found. + + + + The (possibly empty) set of custom options for this message. + + + + + Looks up and cross-links all fields and nested types. + + + + + A collection to simplify retrieving the field accessor for a particular field. + + + + + Returns the fields in the message as an immutable list, in the order in which they + are declared in the source .proto file. + + + + + Returns the fields in the message as an immutable list, in ascending field number + order. Field numbers need not be contiguous, so there is no direct mapping from the + index in the list to the field number; to retrieve a field by field number, it is better + to use the indexer. + + + + + Returns a read-only dictionary mapping the field names in this message as they're available + in the JSON representation to the field descriptors. For example, a field foo_bar + in the message would result two entries, one with a key fooBar and one with a key + foo_bar, both referring to the same field. + + + + + Retrieves the descriptor for the field with the given number. + + Number of the field to retrieve the descriptor for + The accessor for the given field + The message descriptor does not contain a field + with the given number + + + + Retrieves the descriptor for the field with the given name. + + Name of the field to retrieve the descriptor for + The descriptor for the given field + The message descriptor does not contain a field + with the given name + + + + Describes a single method in a service. + + + + + The service this method belongs to. + + + + + The method's input type. + + + + + The method's input type. + + + + + Indicates if client streams multiple requests. + + + + + Indicates if server streams multiple responses. + + + + + The (possibly empty) set of custom options for this method. + + + + + The brief name of the descriptor's target. + + + + + Reflection access for a oneof, allowing clear and "get case" actions. + + + + + Gets the descriptor for this oneof. + + + The descriptor of the oneof. + + + + + Clears the oneof in the specified message. + + + + + Indicates which field in the oneof is set for specified message + + + + + Describes a "oneof" field collection in a message type: a set of + fields of which at most one can be set in any particular message. + + + + + The brief name of the descriptor's target. + + + + + Gets the message type containing this oneof. + + + The message type containing this oneof. + + + + + Gets the fields within this oneof, in declaration order. + + + The fields within this oneof, in declaration order. + + + + + Gets an accessor for reflective access to the values associated with the oneof + in a particular message. + + + The accessor used for reflective access. + + + + + The (possibly empty) set of custom options for this oneof. + + + + + Specifies the original name (in the .proto file) of a named element, + such as an enum value. + + + + + The name of the element in the .proto file. + + + + + If the name is preferred in the .proto file. + + + + + Constructs a new attribute instance for the given name. + + The name of the element in the .proto file. + + + + Represents a package in the symbol table. We use PackageDescriptors + just as placeholders so that someone cannot define, say, a message type + that has the same name as an existing package. + + + + + The methods in this class are somewhat evil, and should not be tampered with lightly. + Basically they allow the creation of relatively weakly typed delegates from MethodInfos + which are more strongly typed. They do this by creating an appropriate strongly typed + delegate from the MethodInfo, and then calling that within an anonymous method. + Mind-bending stuff (at least to your humble narrator) but the resulting delegates are + very fast compared with calling Invoke later on. + + + + + Empty Type[] used when calling GetProperty to force property instead of indexer fetching. + + + + + Creates a delegate which will cast the argument to the appropriate method target type, + call the method on it, then convert the result to object. + + + + + Creates a delegate which will cast the argument to the appropriate method target type, + call the method on it, then convert the result to the specified type. + + + + + Creates a delegate which will execute the given method after casting the first argument to + the target type of the method, and the second argument to the first parameter type of the method. + + + + + Creates a delegate which will execute the given method after casting the first argument to + the target type of the method. + + + + + Accessor for repeated fields. + + + + + Describes a service type. + + + + + The brief name of the descriptor's target. + + + + + An unmodifiable list of methods in this service. + + + + + Finds a method by name. + + The unqualified name of the method (e.g. "Foo"). + The method's decsriptor, or null if not found. + + + + The (possibly empty) set of custom options for this service. + + + + + Accessor for single fields. + + + + + An immutable registry of types which can be looked up by their full name. + + + + + An empty type registry, containing no types. + + + + + Attempts to find a message descriptor by its full name. + + The full name of the message, which is the dot-separated + combination of package, containing messages and message name + The message descriptor corresponding to or null + if there is no such message descriptor. + + + + Creates a type registry from the specified set of file descriptors. + + + This is a convenience overload for + to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). + + The set of files to include in the registry. Must not contain null values. + A type registry for the given files. + + + + Creates a type registry from the specified set of file descriptors. + + + All message types within all the specified files are added to the registry, and + the dependencies of the specified files are also added, recursively. + + The set of files to include in the registry. Must not contain null values. + A type registry for the given files. + + + + Creates a type registry from the file descriptor parents of the specified set of message descriptors. + + + This is a convenience overload for + to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). + + The set of message descriptors to use to identify file descriptors to include in the registry. + Must not contain null values. + A type registry for the given files. + + + + Creates a type registry from the file descriptor parents of the specified set of message descriptors. + + + The specified message descriptors are only used to identify their file descriptors; the returned registry + contains all the types within the file descriptors which contain the specified message descriptors (and + the dependencies of those files), not just the specified messages. + + The set of message descriptors to use to identify file descriptors to include in the registry. + Must not contain null values. + A type registry for the given files. + + + + Builder class which isn't exposed, but acts as a convenient alternative to passing round two dictionaries in recursive calls. + + + + Holder for reflection information generated from google/protobuf/any.proto + + + File descriptor for google/protobuf/any.proto + + + + `Any` contains an arbitrary serialized protocol buffer message along with a + URL that describes the type of the serialized message. + + Protobuf library provides support to pack/unpack Any values in the form + of utility functions or additional generated methods of the Any type. + + Example 1: Pack and unpack a message in C++. + + Foo foo = ...; + Any any; + any.PackFrom(foo); + ... + if (any.UnpackTo(&foo)) { + ... + } + + Example 2: Pack and unpack a message in Java. + + Foo foo = ...; + Any any = Any.pack(foo); + ... + if (any.is(Foo.class)) { + foo = any.unpack(Foo.class); + } + + Example 3: Pack and unpack a message in Python. + + foo = Foo(...) + any = Any() + any.Pack(foo) + ... + if any.Is(Foo.DESCRIPTOR): + any.Unpack(foo) + ... + + The pack methods provided by protobuf library will by default use + 'type.googleapis.com/full.type.name' as the type URL and the unpack + methods only use the fully qualified type name after the last '/' + in the type URL, for example "foo.bar.com/x/y.z" will yield type + name "y.z". + + JSON + ==== + The JSON representation of an `Any` value uses the regular + representation of the deserialized, embedded message, with an + additional field `@type` which contains the type URL. Example: + + package google.profile; + message Person { + string first_name = 1; + string last_name = 2; + } + + { + "@type": "type.googleapis.com/google.profile.Person", + "firstName": <string>, + "lastName": <string> + } + + If the embedded message type is well-known and has a custom JSON + representation, that representation will be embedded adding a field + `value` which holds the custom JSON in addition to the `@type` + field. Example (for message [google.protobuf.Duration][]): + + { + "@type": "type.googleapis.com/google.protobuf.Duration", + "value": "1.212s" + } + + + + Field number for the "type_url" field. + + + + A URL/resource name whose content describes the type of the + serialized protocol buffer message. + + For URLs which use the scheme `http`, `https`, or no scheme, the + following restrictions and interpretations apply: + + * If no scheme is provided, `https` is assumed. + * The last segment of the URL's path must represent the fully + qualified name of the type (as in `path/google.protobuf.Duration`). + The name should be in a canonical form (e.g., leading "." is + not accepted). + * An HTTP GET on the URL must yield a [google.protobuf.Type][] + value in binary format, or produce an error. + * Applications are allowed to cache lookup results based on the + URL, or have them precompiled into a binary to avoid any + lookup. Therefore, binary compatibility needs to be preserved + on changes to types. (Use versioned type names to manage + breaking changes.) + + Schemes other than `http`, `https` (or the empty scheme) might be + used with implementation specific semantics. + + + + Field number for the "value" field. + + + + Must be a valid serialized protocol buffer of the above specified type. + + + + + Retrieves the type name for a type URL. This is always just the last part of the URL, + after the trailing slash. No validation of anything before the trailing slash is performed. + If the type URL does not include a slash, an empty string is returned rather than an exception + being thrown; this won't match any types, and the calling code is probably in a better position + to give a meaningful error. + There is no handling of fragments or queries at the moment. + + The URL to extract the type name from + The type name + + + + Unpacks the content of this Any message into the target message type, + which must match the type URL within this Any message. + + The type of message to unpack the content into. + The unpacked message. + The target message type doesn't match the type URL in this message + + + + Packs the specified message into an Any message using a type URL prefix of "type.googleapis.com". + + The message to pack. + An Any message with the content and type URL of . + + + + Packs the specified message into an Any message using the specified type URL prefix. + + The message to pack. + The prefix for the type URL. + An Any message with the content and type URL of . + + + Holder for reflection information generated from google/protobuf/api.proto + + + File descriptor for google/protobuf/api.proto + + + + Api is a light-weight descriptor for a protocol buffer service. + + + + Field number for the "name" field. + + + + The fully qualified name of this api, including package name + followed by the api's simple name. + + + + Field number for the "methods" field. + + + + The methods of this api, in unspecified order. + + + + Field number for the "options" field. + + + + Any metadata attached to the API. + + + + Field number for the "version" field. + + + + A version string for this api. If specified, must have the form + `major-version.minor-version`, as in `1.10`. If the minor version + is omitted, it defaults to zero. If the entire version field is + empty, the major version is derived from the package name, as + outlined below. If the field is not empty, the version in the + package name will be verified to be consistent with what is + provided here. + + The versioning schema uses [semantic + versioning](http://semver.org) where the major version number + indicates a breaking change and the minor version an additive, + non-breaking change. Both version numbers are signals to users + what to expect from different versions, and should be carefully + chosen based on the product plan. + + The major version is also reflected in the package name of the + API, which must end in `v<major-version>`, as in + `google.feature.v1`. For major versions 0 and 1, the suffix can + be omitted. Zero major versions must only be used for + experimental, none-GA apis. + + + + Field number for the "source_context" field. + + + + Source context for the protocol buffer service represented by this + message. + + + + Field number for the "mixins" field. + + + + Included APIs. See [Mixin][]. + + + + Field number for the "syntax" field. + + + + The source syntax of the service. + + + + + Method represents a method of an api. + + + + Field number for the "name" field. + + + + The simple name of this method. + + + + Field number for the "request_type_url" field. + + + + A URL of the input message type. + + + + Field number for the "request_streaming" field. + + + + If true, the request is streamed. + + + + Field number for the "response_type_url" field. + + + + The URL of the output message type. + + + + Field number for the "response_streaming" field. + + + + If true, the response is streamed. + + + + Field number for the "options" field. + + + + Any metadata attached to the method. + + + + Field number for the "syntax" field. + + + + The source syntax of this method. + + + + + Declares an API to be included in this API. The including API must + redeclare all the methods from the included API, but documentation + and options are inherited as follows: + + - If after comment and whitespace stripping, the documentation + string of the redeclared method is empty, it will be inherited + from the original method. + + - Each annotation belonging to the service config (http, + visibility) which is not set in the redeclared method will be + inherited. + + - If an http annotation is inherited, the path pattern will be + modified as follows. Any version prefix will be replaced by the + version of the including API plus the [root][] path if specified. + + Example of a simple mixin: + + package google.acl.v1; + service AccessControl { + // Get the underlying ACL object. + rpc GetAcl(GetAclRequest) returns (Acl) { + option (google.api.http).get = "/v1/{resource=**}:getAcl"; + } + } + + package google.storage.v2; + service Storage { + rpc GetAcl(GetAclRequest) returns (Acl); + + // Get a data record. + rpc GetData(GetDataRequest) returns (Data) { + option (google.api.http).get = "/v2/{resource=**}"; + } + } + + Example of a mixin configuration: + + apis: + - name: google.storage.v2.Storage + mixins: + - name: google.acl.v1.AccessControl + + The mixin construct implies that all methods in `AccessControl` are + also declared with same name and request/response types in + `Storage`. A documentation generator or annotation processor will + see the effective `Storage.GetAcl` method after inherting + documentation and annotations as follows: + + service Storage { + // Get the underlying ACL object. + rpc GetAcl(GetAclRequest) returns (Acl) { + option (google.api.http).get = "/v2/{resource=**}:getAcl"; + } + ... + } + + Note how the version in the path pattern changed from `v1` to `v2`. + + If the `root` field in the mixin is specified, it should be a + relative path under which inherited HTTP paths are placed. Example: + + apis: + - name: google.storage.v2.Storage + mixins: + - name: google.acl.v1.AccessControl + root: acls + + This implies the following inherited HTTP annotation: + + service Storage { + // Get the underlying ACL object. + rpc GetAcl(GetAclRequest) returns (Acl) { + option (google.api.http).get = "/v2/acls/{resource=**}:getAcl"; + } + ... + } + + + + Field number for the "name" field. + + + + The fully qualified name of the API which is included. + + + + Field number for the "root" field. + + + + If non-empty specifies a path under which inherited HTTP paths + are rooted. + + + + Holder for reflection information generated from google/protobuf/duration.proto + + + File descriptor for google/protobuf/duration.proto + + + + A Duration represents a signed, fixed-length span of time represented + as a count of seconds and fractions of seconds at nanosecond + resolution. It is independent of any calendar and concepts like "day" + or "month". It is related to Timestamp in that the difference between + two Timestamp values is a Duration and it can be added or subtracted + from a Timestamp. Range is approximately +-10,000 years. + + # Examples + + Example 1: Compute Duration from two Timestamps in pseudo code. + + Timestamp start = ...; + Timestamp end = ...; + Duration duration = ...; + + duration.seconds = end.seconds - start.seconds; + duration.nanos = end.nanos - start.nanos; + + if (duration.seconds < 0 && duration.nanos > 0) { + duration.seconds += 1; + duration.nanos -= 1000000000; + } else if (durations.seconds > 0 && duration.nanos < 0) { + duration.seconds -= 1; + duration.nanos += 1000000000; + } + + Example 2: Compute Timestamp from Timestamp + Duration in pseudo code. + + Timestamp start = ...; + Duration duration = ...; + Timestamp end = ...; + + end.seconds = start.seconds + duration.seconds; + end.nanos = start.nanos + duration.nanos; + + if (end.nanos < 0) { + end.seconds -= 1; + end.nanos += 1000000000; + } else if (end.nanos >= 1000000000) { + end.seconds += 1; + end.nanos -= 1000000000; + } + + Example 3: Compute Duration from datetime.timedelta in Python. + + td = datetime.timedelta(days=3, minutes=10) + duration = Duration() + duration.FromTimedelta(td) + + # JSON Mapping + + In JSON format, the Duration type is encoded as a string rather than an + object, where the string ends in the suffix "s" (indicating seconds) and + is preceded by the number of seconds, with nanoseconds expressed as + fractional seconds. For example, 3 seconds with 0 nanoseconds should be + encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should + be expressed in JSON format as "3.000000001s", and 3 seconds and 1 + microsecond should be expressed in JSON format as "3.000001s". + + + + Field number for the "seconds" field. + + + + Signed seconds of the span of time. Must be from -315,576,000,000 + to +315,576,000,000 inclusive. Note: these bounds are computed from: + 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years + + + + Field number for the "nanos" field. + + + + Signed fractions of a second at nanosecond resolution of the span + of time. Durations less than one second are represented with a 0 + `seconds` field and a positive or negative `nanos` field. For durations + of one second or more, a non-zero value for the `nanos` field must be + of the same sign as the `seconds` field. Must be from -999,999,999 + to +999,999,999 inclusive. + + + + + The number of nanoseconds in a second. + + + + + The number of nanoseconds in a BCL tick (as used by and ). + + + + + The maximum permitted number of seconds. + + + + + The minimum permitted number of seconds. + + + + + Converts this to a . + + If the duration is not a precise number of ticks, it is truncated towards 0. + The value of this duration, as a TimeSpan. + This value isn't a valid normalized duration, as + described in the documentation. + + + + Converts the given to a . + + The TimeSpan to convert. + The value of the given TimeSpan, as a Duration. + + + + Returns the result of negating the duration. For example, the negation of 5 minutes is -5 minutes. + + The duration to negate. Must not be null. + The negated value of this duration. + + + + Adds the two specified values together. + + The first value to add. Must not be null. + The second value to add. Must not be null. + + + + + Subtracts one from another. + + The duration to subtract from. Must not be null. + The duration to subtract. Must not be null. + The difference between the two specified durations. + + + + Creates a duration with the normalized values from the given number of seconds and + nanoseconds, conforming with the description in the proto file. + + + + + Converts a duration specified in seconds/nanoseconds to a string. + + + If the value is a normalized duration in the range described in duration.proto, + is ignored. Otherwise, if the parameter is true, + a JSON object with a warning is returned; if it is false, an is thrown. + + Seconds portion of the duration. + Nanoseconds portion of the duration. + Determines the handling of non-normalized values + The represented duration is invalid, and is false. + + + + Returns a string representation of this for diagnostic purposes. + + + Normally the returned value will be a JSON string value (including leading and trailing quotes) but + when the value is non-normalized or out of range, a JSON object representation will be returned + instead, including a warning. This is to avoid exceptions being thrown when trying to + diagnose problems - the regular JSON formatter will still throw an exception for non-normalized + values. + + A string representation of this value. + + + + Appends a number of nanoseconds to a StringBuilder. Either 0 digits are added (in which + case no "." is appended), or 3 6 or 9 digits. This is internal for use in Timestamp as well + as Duration. + + + + Holder for reflection information generated from google/protobuf/empty.proto + + + File descriptor for google/protobuf/empty.proto + + + + A generic empty message that you can re-use to avoid defining duplicated + empty messages in your APIs. A typical example is to use it as the request + or the response type of an API method. For instance: + + service Foo { + rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); + } + + The JSON representation for `Empty` is empty JSON object `{}`. + + + + Holder for reflection information generated from google/protobuf/field_mask.proto + + + File descriptor for google/protobuf/field_mask.proto + + + + `FieldMask` represents a set of symbolic field paths, for example: + + paths: "f.a" + paths: "f.b.d" + + Here `f` represents a field in some root message, `a` and `b` + fields in the message found in `f`, and `d` a field found in the + message in `f.b`. + + Field masks are used to specify a subset of fields that should be + returned by a get operation or modified by an update operation. + Field masks also have a custom JSON encoding (see below). + + # Field Masks in Projections + + When used in the context of a projection, a response message or + sub-message is filtered by the API to only contain those fields as + specified in the mask. For example, if the mask in the previous + example is applied to a response message as follows: + + f { + a : 22 + b { + d : 1 + x : 2 + } + y : 13 + } + z: 8 + + The result will not contain specific values for fields x,y and z + (their value will be set to the default, and omitted in proto text + output): + + f { + a : 22 + b { + d : 1 + } + } + + A repeated field is not allowed except at the last position of a + paths string. + + If a FieldMask object is not present in a get operation, the + operation applies to all fields (as if a FieldMask of all fields + had been specified). + + Note that a field mask does not necessarily apply to the + top-level response message. In case of a REST get operation, the + field mask applies directly to the response, but in case of a REST + list operation, the mask instead applies to each individual message + in the returned resource list. In case of a REST custom method, + other definitions may be used. Where the mask applies will be + clearly documented together with its declaration in the API. In + any case, the effect on the returned resource/resources is required + behavior for APIs. + + # Field Masks in Update Operations + + A field mask in update operations specifies which fields of the + targeted resource are going to be updated. The API is required + to only change the values of the fields as specified in the mask + and leave the others untouched. If a resource is passed in to + describe the updated values, the API ignores the values of all + fields not covered by the mask. + + If a repeated field is specified for an update operation, the existing + repeated values in the target resource will be overwritten by the new values. + Note that a repeated field is only allowed in the last position of a `paths` + string. + + If a sub-message is specified in the last position of the field mask for an + update operation, then the existing sub-message in the target resource is + overwritten. Given the target message: + + f { + b { + d : 1 + x : 2 + } + c : 1 + } + + And an update message: + + f { + b { + d : 10 + } + } + + then if the field mask is: + + paths: "f.b" + + then the result will be: + + f { + b { + d : 10 + } + c : 1 + } + + However, if the update mask was: + + paths: "f.b.d" + + then the result would be: + + f { + b { + d : 10 + x : 2 + } + c : 1 + } + + In order to reset a field's value to the default, the field must + be in the mask and set to the default value in the provided resource. + Hence, in order to reset all fields of a resource, provide a default + instance of the resource and set all fields in the mask, or do + not provide a mask as described below. + + If a field mask is not present on update, the operation applies to + all fields (as if a field mask of all fields has been specified). + Note that in the presence of schema evolution, this may mean that + fields the client does not know and has therefore not filled into + the request will be reset to their default. If this is unwanted + behavior, a specific service may require a client to always specify + a field mask, producing an error if not. + + As with get operations, the location of the resource which + describes the updated values in the request message depends on the + operation kind. In any case, the effect of the field mask is + required to be honored by the API. + + ## Considerations for HTTP REST + + The HTTP kind of an update operation which uses a field mask must + be set to PATCH instead of PUT in order to satisfy HTTP semantics + (PUT must only be used for full updates). + + # JSON Encoding of Field Masks + + In JSON, a field mask is encoded as a single string where paths are + separated by a comma. Fields name in each path are converted + to/from lower-camel naming conventions. + + As an example, consider the following message declarations: + + message Profile { + User user = 1; + Photo photo = 2; + } + message User { + string display_name = 1; + string address = 2; + } + + In proto a field mask for `Profile` may look as such: + + mask { + paths: "user.display_name" + paths: "photo" + } + + In JSON, the same mask is represented as below: + + { + mask: "user.displayName,photo" + } + + # Field Masks and Oneof Fields + + Field masks treat fields in oneofs just as regular fields. Consider the + following message: + + message SampleMessage { + oneof test_oneof { + string name = 4; + SubMessage sub_message = 9; + } + } + + The field mask can be: + + mask { + paths: "name" + } + + Or: + + mask { + paths: "sub_message" + } + + Note that oneof type names ("test_oneof" in this case) cannot be used in + paths. + + + + Field number for the "paths" field. + + + + The set of field mask paths. + + + + + Converts a timestamp specified in seconds/nanoseconds to a string. + + + If the value is a normalized duration in the range described in field_mask.proto, + is ignored. Otherwise, if the parameter is true, + a JSON object with a warning is returned; if it is false, an is thrown. + + Paths in the field mask + Determines the handling of non-normalized values + The represented field mask is invalid, and is false. + + + + Checks whether the given path is valid for a field mask. + + true if the path is valid; false otherwise + + + + Returns a string representation of this for diagnostic purposes. + + + Normally the returned value will be a JSON string value (including leading and trailing quotes) but + when the value is non-normalized or out of range, a JSON object representation will be returned + instead, including a warning. This is to avoid exceptions being thrown when trying to + diagnose problems - the regular JSON formatter will still throw an exception for non-normalized + values. + + A string representation of this value. + + + Holder for reflection information generated from google/protobuf/source_context.proto + + + File descriptor for google/protobuf/source_context.proto + + + + `SourceContext` represents information about the source of a + protobuf element, like the file in which it is defined. + + + + Field number for the "file_name" field. + + + + The path-qualified name of the .proto file that contained the associated + protobuf element. For example: `"google/protobuf/source_context.proto"`. + + + + Holder for reflection information generated from google/protobuf/struct.proto + + + File descriptor for google/protobuf/struct.proto + + + + `NullValue` is a singleton enumeration to represent the null value for the + `Value` type union. + + The JSON representation for `NullValue` is JSON `null`. + + + + + Null value. + + + + + `Struct` represents a structured data value, consisting of fields + which map to dynamically typed values. In some languages, `Struct` + might be supported by a native representation. For example, in + scripting languages like JS a struct is represented as an + object. The details of that representation are described together + with the proto support for the language. + + The JSON representation for `Struct` is JSON object. + + + + Field number for the "fields" field. + + + + Unordered map of dynamically typed values. + + + + + `Value` represents a dynamically typed value which can be either + null, a number, a string, a boolean, a recursive struct value, or a + list of values. A producer of value is expected to set one of that + variants, absence of any variant indicates an error. + + The JSON representation for `Value` is JSON value. + + + + Field number for the "null_value" field. + + + + Represents a null value. + + + + Field number for the "number_value" field. + + + + Represents a double value. + + + + Field number for the "string_value" field. + + + + Represents a string value. + + + + Field number for the "bool_value" field. + + + + Represents a boolean value. + + + + Field number for the "struct_value" field. + + + + Represents a structured value. + + + + Field number for the "list_value" field. + + + + Represents a repeated `Value`. + + + + Enum of possible cases for the "kind" oneof. + + + + Convenience method to create a Value message with a string value. + + Value to set for the StringValue property. + A newly-created Value message with the given value. + + + + Convenience method to create a Value message with a number value. + + Value to set for the NumberValue property. + A newly-created Value message with the given value. + + + + Convenience method to create a Value message with a Boolean value. + + Value to set for the BoolValue property. + A newly-created Value message with the given value. + + + + Convenience method to create a Value message with a null initial value. + + A newly-created Value message a null initial value. + + + + Convenience method to create a Value message with an initial list of values. + + The values provided are not cloned; the references are copied directly. + A newly-created Value message an initial list value. + + + + Convenience method to create a Value message with an initial struct value + + The value provided is not cloned; the reference is copied directly. + A newly-created Value message an initial struct value. + + + + `ListValue` is a wrapper around a repeated field of values. + + The JSON representation for `ListValue` is JSON array. + + + + Field number for the "values" field. + + + + Repeated field of dynamically typed values. + + + + + Extension methods on BCL time-related types, converting to protobuf types. + + + + + Converts the given to a . + + The date and time to convert to a timestamp. + The value has a other than Utc. + The converted timestamp. + + + + Converts the given to a + + The offset is taken into consideration when converting the value (so the same instant in time + is represented) but is not a separate part of the resulting value. In other words, there is no + roundtrip operation to retrieve the original DateTimeOffset. + The date and time (with UTC offset) to convert to a timestamp. + The converted timestamp. + + + + Converts the given to a . + + The time span to convert. + The converted duration. + + + Holder for reflection information generated from google/protobuf/timestamp.proto + + + File descriptor for google/protobuf/timestamp.proto + + + + A Timestamp represents a point in time independent of any time zone + or calendar, represented as seconds and fractions of seconds at + nanosecond resolution in UTC Epoch time. It is encoded using the + Proleptic Gregorian Calendar which extends the Gregorian calendar + backwards to year one. It is encoded assuming all minutes are 60 + seconds long, i.e. leap seconds are "smeared" so that no leap second + table is needed for interpretation. Range is from + 0001-01-01T00:00:00Z to 9999-12-31T23:59:59.999999999Z. + By restricting to that range, we ensure that we can convert to + and from RFC 3339 date strings. + See [https://www.ietf.org/rfc/rfc3339.txt](https://www.ietf.org/rfc/rfc3339.txt). + + # Examples + + Example 1: Compute Timestamp from POSIX `time()`. + + Timestamp timestamp; + timestamp.set_seconds(time(NULL)); + timestamp.set_nanos(0); + + Example 2: Compute Timestamp from POSIX `gettimeofday()`. + + struct timeval tv; + gettimeofday(&tv, NULL); + + Timestamp timestamp; + timestamp.set_seconds(tv.tv_sec); + timestamp.set_nanos(tv.tv_usec * 1000); + + Example 3: Compute Timestamp from Win32 `GetSystemTimeAsFileTime()`. + + FILETIME ft; + GetSystemTimeAsFileTime(&ft); + UINT64 ticks = (((UINT64)ft.dwHighDateTime) << 32) | ft.dwLowDateTime; + + // A Windows tick is 100 nanoseconds. Windows epoch 1601-01-01T00:00:00Z + // is 11644473600 seconds before Unix epoch 1970-01-01T00:00:00Z. + Timestamp timestamp; + timestamp.set_seconds((INT64) ((ticks / 10000000) - 11644473600LL)); + timestamp.set_nanos((INT32) ((ticks % 10000000) * 100)); + + Example 4: Compute Timestamp from Java `System.currentTimeMillis()`. + + long millis = System.currentTimeMillis(); + + Timestamp timestamp = Timestamp.newBuilder().setSeconds(millis / 1000) + .setNanos((int) ((millis % 1000) * 1000000)).build(); + + Example 5: Compute Timestamp from current time in Python. + + timestamp = Timestamp() + timestamp.GetCurrentTime() + + # JSON Mapping + + In JSON format, the Timestamp type is encoded as a string in the + [RFC 3339](https://www.ietf.org/rfc/rfc3339.txt) format. That is, the + format is "{year}-{month}-{day}T{hour}:{min}:{sec}[.{frac_sec}]Z" + where {year} is always expressed using four digits while {month}, {day}, + {hour}, {min}, and {sec} are zero-padded to two digits each. The fractional + seconds, which can go up to 9 digits (i.e. up to 1 nanosecond resolution), + are optional. The "Z" suffix indicates the timezone ("UTC"); the timezone + is required, though only UTC (as indicated by "Z") is presently supported. + + For example, "2017-01-15T01:30:15.01Z" encodes 15.01 seconds past + 01:30 UTC on January 15, 2017. + + In JavaScript, one can convert a Date object to this format using the + standard [toISOString()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString] + method. In Python, a standard `datetime.datetime` object can be converted + to this format using [`strftime`](https://docs.python.org/2/library/time.html#time.strftime) + with the time format spec '%Y-%m-%dT%H:%M:%S.%fZ'. Likewise, in Java, one + can use the Joda Time's [`ISODateTimeFormat.dateTime()`]( + http://joda-time.sourceforge.net/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime()) + to obtain a formatter capable of generating timestamps in this format. + + + + Field number for the "seconds" field. + + + + Represents seconds of UTC time since Unix epoch + 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to + 9999-12-31T23:59:59Z inclusive. + + + + Field number for the "nanos" field. + + + + Non-negative fractions of a second at nanosecond resolution. Negative + second values with fractions must still have non-negative nanos values + that count forward in time. Must be from 0 to 999,999,999 + inclusive. + + + + + Returns the difference between one and another, as a . + + The timestamp to subtract from. Must not be null. + The timestamp to subtract. Must not be null. + The difference between the two specified timestamps. + + + + Adds a to a , to obtain another Timestamp. + + The timestamp to add the duration to. Must not be null. + The duration to add. Must not be null. + The result of adding the duration to the timestamp. + + + + Subtracts a from a , to obtain another Timestamp. + + The timestamp to subtract the duration from. Must not be null. + The duration to subtract. + The result of subtracting the duration from the timestamp. + + + + Converts this timestamp into a . + + + The resulting DateTime will always have a Kind of Utc. + If the timestamp is not a precise number of ticks, it will be truncated towards the start + of time. For example, a timestamp with a value of 99 will result in a + value precisely on a second. + + This timestamp as a DateTime. + The timestamp contains invalid values; either it is + incorrectly normalized or is outside the valid range. + + + + Converts this timestamp into a . + + + The resulting DateTimeOffset will always have an Offset of zero. + If the timestamp is not a precise number of ticks, it will be truncated towards the start + of time. For example, a timestamp with a value of 99 will result in a + value precisely on a second. + + This timestamp as a DateTimeOffset. + The timestamp contains invalid values; either it is + incorrectly normalized or is outside the valid range. + + + + Converts the specified to a . + + + The Kind of is not DateTimeKind.Utc. + The converted timestamp. + + + + Converts the given to a + + The offset is taken into consideration when converting the value (so the same instant in time + is represented) but is not a separate part of the resulting value. In other words, there is no + roundtrip operation to retrieve the original DateTimeOffset. + The date and time (with UTC offset) to convert to a timestamp. + The converted timestamp. + + + + Converts a timestamp specified in seconds/nanoseconds to a string. + + + If the value is a normalized duration in the range described in timestamp.proto, + is ignored. Otherwise, if the parameter is true, + a JSON object with a warning is returned; if it is false, an is thrown. + + Seconds portion of the duration. + Nanoseconds portion of the duration. + Determines the handling of non-normalized values + The represented duration is invalid, and is false. + + + + Returns a string representation of this for diagnostic purposes. + + + Normally the returned value will be a JSON string value (including leading and trailing quotes) but + when the value is non-normalized or out of range, a JSON object representation will be returned + instead, including a warning. This is to avoid exceptions being thrown when trying to + diagnose problems - the regular JSON formatter will still throw an exception for non-normalized + values. + + A string representation of this value. + + + Holder for reflection information generated from google/protobuf/type.proto + + + File descriptor for google/protobuf/type.proto + + + + The syntax in which a protocol buffer element is defined. + + + + + Syntax `proto2`. + + + + + Syntax `proto3`. + + + + + A protocol buffer message type. + + + + Field number for the "name" field. + + + + The fully qualified message name. + + + + Field number for the "fields" field. + + + + The list of fields. + + + + Field number for the "oneofs" field. + + + + The list of types appearing in `oneof` definitions in this type. + + + + Field number for the "options" field. + + + + The protocol buffer options. + + + + Field number for the "source_context" field. + + + + The source context. + + + + Field number for the "syntax" field. + + + + The source syntax. + + + + + A single field of a message type. + + + + Field number for the "kind" field. + + + + The field type. + + + + Field number for the "cardinality" field. + + + + The field cardinality. + + + + Field number for the "number" field. + + + + The field number. + + + + Field number for the "name" field. + + + + The field name. + + + + Field number for the "type_url" field. + + + + The field type URL, without the scheme, for message or enumeration + types. Example: `"type.googleapis.com/google.protobuf.Timestamp"`. + + + + Field number for the "oneof_index" field. + + + + The index of the field type in `Type.oneofs`, for message or enumeration + types. The first type has index 1; zero means the type is not in the list. + + + + Field number for the "packed" field. + + + + Whether to use alternative packed wire representation. + + + + Field number for the "options" field. + + + + The protocol buffer options. + + + + Field number for the "json_name" field. + + + + The field JSON name. + + + + Field number for the "default_value" field. + + + + The string value of the default value of this field. Proto2 syntax only. + + + + Container for nested types declared in the Field message type. + + + + Basic field types. + + + + + Field type unknown. + + + + + Field type double. + + + + + Field type float. + + + + + Field type int64. + + + + + Field type uint64. + + + + + Field type int32. + + + + + Field type fixed64. + + + + + Field type fixed32. + + + + + Field type bool. + + + + + Field type string. + + + + + Field type group. Proto2 syntax only, and deprecated. + + + + + Field type message. + + + + + Field type bytes. + + + + + Field type uint32. + + + + + Field type enum. + + + + + Field type sfixed32. + + + + + Field type sfixed64. + + + + + Field type sint32. + + + + + Field type sint64. + + + + + Whether a field is optional, required, or repeated. + + + + + For fields with unknown cardinality. + + + + + For optional fields. + + + + + For required fields. Proto2 syntax only. + + + + + For repeated fields. + + + + + Enum type definition. + + + + Field number for the "name" field. + + + + Enum type name. + + + + Field number for the "enumvalue" field. + + + + Enum value definitions. + + + + Field number for the "options" field. + + + + Protocol buffer options. + + + + Field number for the "source_context" field. + + + + The source context. + + + + Field number for the "syntax" field. + + + + The source syntax. + + + + + Enum value definition. + + + + Field number for the "name" field. + + + + Enum value name. + + + + Field number for the "number" field. + + + + Enum value number. + + + + Field number for the "options" field. + + + + Protocol buffer options. + + + + + A protocol buffer option, which can be attached to a message, field, + enumeration, etc. + + + + Field number for the "name" field. + + + + The option's name. For protobuf built-in options (options defined in + descriptor.proto), this is the short name. For example, `"map_entry"`. + For custom options, it should be the fully-qualified name. For example, + `"google.api.http"`. + + + + Field number for the "value" field. + + + + The option's value packed in an Any message. If the value is a primitive, + the corresponding wrapper type defined in google/protobuf/wrappers.proto + should be used. If the value is an enum, it should be stored as an int32 + value using the google.protobuf.Int32Value type. + + + + Holder for reflection information generated from google/protobuf/wrappers.proto + + + File descriptor for google/protobuf/wrappers.proto + + + + Field number for the single "value" field in all wrapper types. + + + + + Wrapper message for `double`. + + The JSON representation for `DoubleValue` is JSON number. + + + + Field number for the "value" field. + + + + The double value. + + + + + Wrapper message for `float`. + + The JSON representation for `FloatValue` is JSON number. + + + + Field number for the "value" field. + + + + The float value. + + + + + Wrapper message for `int64`. + + The JSON representation for `Int64Value` is JSON string. + + + + Field number for the "value" field. + + + + The int64 value. + + + + + Wrapper message for `uint64`. + + The JSON representation for `UInt64Value` is JSON string. + + + + Field number for the "value" field. + + + + The uint64 value. + + + + + Wrapper message for `int32`. + + The JSON representation for `Int32Value` is JSON number. + + + + Field number for the "value" field. + + + + The int32 value. + + + + + Wrapper message for `uint32`. + + The JSON representation for `UInt32Value` is JSON number. + + + + Field number for the "value" field. + + + + The uint32 value. + + + + + Wrapper message for `bool`. + + The JSON representation for `BoolValue` is JSON `true` and `false`. + + + + Field number for the "value" field. + + + + The bool value. + + + + + Wrapper message for `string`. + + The JSON representation for `StringValue` is JSON string. + + + + Field number for the "value" field. + + + + The string value. + + + + + Wrapper message for `bytes`. + + The JSON representation for `BytesValue` is JSON string. + + + + Field number for the "value" field. + + + + The bytes value. + + + + + This class is used internally by the Protocol Buffer Library and generated + message implementations. It is public only for the sake of those generated + messages. Others should not use this class directly. + + This class contains constants and helper functions useful for dealing with + the Protocol Buffer wire format. + + + + + + Wire types within protobuf encoding. + + + + + Variable-length integer. + + + + + A fixed-length 64-bit value. + + + + + A length-delimited value, i.e. a length followed by that many bytes of data. + + + + + A "start group" value - not supported by this implementation. + + + + + An "end group" value - not supported by this implementation. + + + + + A fixed-length 32-bit value. + + + + + Given a tag value, determines the wire type (lower 3 bits). + + + + + Given a tag value, determines the field number (the upper 29 bits). + + + + + Makes a tag value given a field number and wire type. + + +
+
diff --git a/Assets/Plugins/Protobuf/Google.Protobuf.xml.meta b/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta similarity index 78% rename from Assets/Plugins/Protobuf/Google.Protobuf.xml.meta rename to Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta index d608d62c..aedb2691 100644 --- a/Assets/Plugins/Protobuf/Google.Protobuf.xml.meta +++ b/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 36eeb53d747694f42bb3467e59b6f016 +guid: 32e98c3d38e34d14ea431c91eae90058 timeCreated: 1496624518 licenseType: Free TextScriptImporter: diff --git a/Assets/RegionMap.cs b/Runtime/RegionMap.cs similarity index 100% rename from Assets/RegionMap.cs rename to Runtime/RegionMap.cs diff --git a/Assets/RegionMap.cs.meta b/Runtime/RegionMap.cs.meta similarity index 85% rename from Assets/RegionMap.cs.meta rename to Runtime/RegionMap.cs.meta index a91c7868..32605745 100644 --- a/Assets/RegionMap.cs.meta +++ b/Runtime/RegionMap.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 673da631ad95c423cbdabfdc9202e581 +guid: b5e442167aa42384d8e82f603f95d6b1 timeCreated: 1511908288 licenseType: Free MonoImporter: diff --git a/Assets/Scenes.meta b/Runtime/Scenes.meta similarity index 79% rename from Assets/Scenes.meta rename to Runtime/Scenes.meta index 46ef6c57..bcf90bc7 100644 --- a/Assets/Scenes.meta +++ b/Runtime/Scenes.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 45d6014b849ab4464bb27d7310bbd91c +guid: 8e1dbc83df351604daaec5a56e892c78 folderAsset: yes timeCreated: 1504122324 licenseType: Free diff --git a/Assets/Scenes/Blue.mat b/Runtime/Scenes/Blue.mat similarity index 100% rename from Assets/Scenes/Blue.mat rename to Runtime/Scenes/Blue.mat diff --git a/Assets/Scenes/Blue.mat.meta b/Runtime/Scenes/Blue.mat.meta similarity index 81% rename from Assets/Scenes/Blue.mat.meta rename to Runtime/Scenes/Blue.mat.meta index 5f70af9c..be436f33 100644 --- a/Assets/Scenes/Blue.mat.meta +++ b/Runtime/Scenes/Blue.mat.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: bb0267789bf4345c7916b57b125fc6ca +guid: 7c920dc8a88d4d64e8ec831a30134ab4 timeCreated: 1501859409 licenseType: Free NativeFormatImporter: diff --git a/Assets/Scenes/ExampleMapStyle.asset b/Runtime/Scenes/ExampleMapStyle.asset similarity index 100% rename from Assets/Scenes/ExampleMapStyle.asset rename to Runtime/Scenes/ExampleMapStyle.asset diff --git a/Assets/Scenes/ExampleMapStyle.asset.meta b/Runtime/Scenes/ExampleMapStyle.asset.meta similarity index 81% rename from Assets/Scenes/ExampleMapStyle.asset.meta rename to Runtime/Scenes/ExampleMapStyle.asset.meta index f0b09acd..2aef4980 100644 --- a/Assets/Scenes/ExampleMapStyle.asset.meta +++ b/Runtime/Scenes/ExampleMapStyle.asset.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 55b6d5ee799474205b5745d930cce11d +guid: 27f810fabc7e3d747b7ec85e9c805920 timeCreated: 1511919197 licenseType: Free NativeFormatImporter: diff --git a/Assets/Scenes/Green Lighter.mat b/Runtime/Scenes/Green Lighter.mat similarity index 100% rename from Assets/Scenes/Green Lighter.mat rename to Runtime/Scenes/Green Lighter.mat diff --git a/Assets/Scenes/Green Lighter.mat.meta b/Runtime/Scenes/Green Lighter.mat.meta similarity index 81% rename from Assets/Scenes/Green Lighter.mat.meta rename to Runtime/Scenes/Green Lighter.mat.meta index 0a19f72e..ca8a5451 100644 --- a/Assets/Scenes/Green Lighter.mat.meta +++ b/Runtime/Scenes/Green Lighter.mat.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 65006d96c145043e4a6c4eff651e5c83 +guid: 9c42607607e625748add66f3b9261db1 timeCreated: 1513038735 licenseType: Free NativeFormatImporter: diff --git a/Assets/Scenes/Green.mat b/Runtime/Scenes/Green.mat similarity index 100% rename from Assets/Scenes/Green.mat rename to Runtime/Scenes/Green.mat diff --git a/Assets/Scenes/Green.mat.meta b/Runtime/Scenes/Green.mat.meta similarity index 81% rename from Assets/Scenes/Green.mat.meta rename to Runtime/Scenes/Green.mat.meta index bd417850..2a1e3564 100644 --- a/Assets/Scenes/Green.mat.meta +++ b/Runtime/Scenes/Green.mat.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 0cdfce05273914dd4823f77af6b71663 +guid: 5e4249b71a649b9498f36807aafc1d2c timeCreated: 1502218196 licenseType: Free NativeFormatImporter: diff --git a/Assets/Scenes/Red Lighter.mat b/Runtime/Scenes/Red Lighter.mat similarity index 100% rename from Assets/Scenes/Red Lighter.mat rename to Runtime/Scenes/Red Lighter.mat diff --git a/Assets/Scenes/Red Lighter.mat.meta b/Runtime/Scenes/Red Lighter.mat.meta similarity index 81% rename from Assets/Scenes/Red Lighter.mat.meta rename to Runtime/Scenes/Red Lighter.mat.meta index fcdfbd3b..6f6e59da 100644 --- a/Assets/Scenes/Red Lighter.mat.meta +++ b/Runtime/Scenes/Red Lighter.mat.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 59eea86d9d6ad439697c739214cbd3bf +guid: be1f2368a3ceaba48803bc59d3263f6b timeCreated: 1513047062 licenseType: Free NativeFormatImporter: diff --git a/Assets/Scenes/Red.mat b/Runtime/Scenes/Red.mat similarity index 100% rename from Assets/Scenes/Red.mat rename to Runtime/Scenes/Red.mat diff --git a/Assets/Scenes/Red.mat.meta b/Runtime/Scenes/Red.mat.meta similarity index 81% rename from Assets/Scenes/Red.mat.meta rename to Runtime/Scenes/Red.mat.meta index 26c43ca8..b639f314 100644 --- a/Assets/Scenes/Red.mat.meta +++ b/Runtime/Scenes/Red.mat.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: ca945bef7446a48c3a7e6c2241195361 +guid: b6a3d14954889e0449dd68d5fc5c2055 timeCreated: 1507562910 licenseType: Free NativeFormatImporter: diff --git a/Assets/Scenes/RegionMapExample.unity b/Runtime/Scenes/RegionMapExample.unity similarity index 100% rename from Assets/Scenes/RegionMapExample.unity rename to Runtime/Scenes/RegionMapExample.unity diff --git a/Assets/Scenes/RegionMapExample.unity.meta b/Runtime/Scenes/RegionMapExample.unity.meta similarity index 77% rename from Assets/Scenes/RegionMapExample.unity.meta rename to Runtime/Scenes/RegionMapExample.unity.meta index c3032e7c..61e84aca 100644 --- a/Assets/Scenes/RegionMapExample.unity.meta +++ b/Runtime/Scenes/RegionMapExample.unity.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: e1030ce9fa8804eae9a841d9a604d7bc +guid: 108b694fd88804940a392e644dbdc5ab timeCreated: 1489516005 licenseType: Free DefaultImporter: diff --git a/Assets/Scenes/UVGrid.mat b/Runtime/Scenes/UVGrid.mat similarity index 100% rename from Assets/Scenes/UVGrid.mat rename to Runtime/Scenes/UVGrid.mat diff --git a/Assets/Scenes/UVGrid.mat.meta b/Runtime/Scenes/UVGrid.mat.meta similarity index 81% rename from Assets/Scenes/UVGrid.mat.meta rename to Runtime/Scenes/UVGrid.mat.meta index 2eadd3bb..c5b60e2a 100644 --- a/Assets/Scenes/UVGrid.mat.meta +++ b/Runtime/Scenes/UVGrid.mat.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 7f88baed2a0f94bb3a42f7bc45b5fcf8 +guid: a0be8d710c96bb34aaffe6d460de84af timeCreated: 1504123345 licenseType: Free NativeFormatImporter: diff --git a/Runtime/tangram-unity.asmdef b/Runtime/tangram-unity.asmdef new file mode 100644 index 00000000..39c89b69 --- /dev/null +++ b/Runtime/tangram-unity.asmdef @@ -0,0 +1,3 @@ +{ + "name": "tangram-unity" +} diff --git a/Runtime/tangram-unity.asmdef.meta b/Runtime/tangram-unity.asmdef.meta new file mode 100644 index 00000000..e8d5de4b --- /dev/null +++ b/Runtime/tangram-unity.asmdef.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 5ce4dc18b8ca59f4ba4334e4b0154ee2 +AssemblyDefinitionImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/UserSettings/EditorUserSettings.asset b/UserSettings/EditorUserSettings.asset deleted file mode 100644 index d1ecbdff..00000000 --- a/UserSettings/EditorUserSettings.asset +++ /dev/null @@ -1,25 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!162 &1 -EditorUserSettings: - m_ObjectHideFlags: 0 - serializedVersion: 4 - m_ConfigSettings: - vcSharedLogLevel: - value: 0d5e400f0650 - flags: 0 - m_VCAutomaticAdd: 1 - m_VCDebugCom: 0 - m_VCDebugCmd: 0 - m_VCDebugOut: 0 - m_SemanticMergeMode: 2 - m_DesiredImportWorkerCount: 1 - m_StandbyImportWorkerCount: 1 - m_IdleImportWorkerShutdownDelay: 60000 - m_VCShowFailedCheckout: 1 - m_VCOverwriteFailedCheckoutAssets: 1 - m_VCProjectOverlayIcons: 1 - m_VCHierarchyOverlayIcons: 1 - m_VCOtherOverlayIcons: 1 - m_VCAllowAsyncUpdate: 1 - m_ArtifactGarbageCollection: 1 diff --git a/UserSettings/Layouts/default-2021.dwlt b/UserSettings/Layouts/default-2021.dwlt deleted file mode 100644 index 6a0b8ede..00000000 --- a/UserSettings/Layouts/default-2021.dwlt +++ /dev/null @@ -1,746 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!114 &1 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12004, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_PixelRect: - serializedVersion: 2 - x: 2249 - y: 302.5 - width: 1206 - height: 715 - m_ShowMode: 4 - m_Title: - m_RootView: {fileID: 6} - m_MinSize: {x: 875, y: 300} - m_MaxSize: {x: 10000, y: 10000} - m_Maximized: 0 ---- !u!114 &2 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12010, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: - - {fileID: 9} - - {fileID: 3} - m_Position: - serializedVersion: 2 - x: 0 - y: 30 - width: 1206 - height: 665 - m_MinSize: {x: 679, y: 492} - m_MaxSize: {x: 14002, y: 14042} - vertical: 0 - controlID: 119 ---- !u!114 &3 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: [] - m_Position: - serializedVersion: 2 - x: 921 - y: 0 - width: 285 - height: 665 - m_MinSize: {x: 276, y: 71} - m_MaxSize: {x: 4001, y: 4021} - m_ActualView: {fileID: 13} - m_Panes: - - {fileID: 13} - m_Selected: 0 - m_LastSelected: 0 ---- !u!114 &4 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: [] - m_Position: - serializedVersion: 2 - x: 0 - y: 0 - width: 228 - height: 394 - m_MinSize: {x: 201, y: 221} - m_MaxSize: {x: 4001, y: 4021} - m_ActualView: {fileID: 14} - m_Panes: - - {fileID: 14} - m_Selected: 0 - m_LastSelected: 0 ---- !u!114 &5 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} - m_Name: ProjectBrowser - m_EditorClassIdentifier: - m_Children: [] - m_Position: - serializedVersion: 2 - x: 0 - y: 394 - width: 921 - height: 271 - m_MinSize: {x: 231, y: 271} - m_MaxSize: {x: 10001, y: 10021} - m_ActualView: {fileID: 12} - m_Panes: - - {fileID: 12} - - {fileID: 17} - m_Selected: 0 - m_LastSelected: 1 ---- !u!114 &6 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12008, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: - - {fileID: 7} - - {fileID: 2} - - {fileID: 8} - m_Position: - serializedVersion: 2 - x: 0 - y: 0 - width: 1206 - height: 715 - m_MinSize: {x: 875, y: 300} - m_MaxSize: {x: 10000, y: 10000} ---- !u!114 &7 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12011, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: [] - m_Position: - serializedVersion: 2 - x: 0 - y: 0 - width: 1206 - height: 30 - m_MinSize: {x: 0, y: 0} - m_MaxSize: {x: 0, y: 0} - m_LoadedToolbars: [] - m_MainToolbar: {fileID: 18} - m_LastLoadedLayoutName: Default ---- !u!114 &8 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12042, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: [] - m_Position: - serializedVersion: 2 - x: 0 - y: 695 - width: 1206 - height: 20 - m_MinSize: {x: 0, y: 0} - m_MaxSize: {x: 0, y: 0} ---- !u!114 &9 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12010, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: - - {fileID: 10} - - {fileID: 5} - m_Position: - serializedVersion: 2 - x: 0 - y: 0 - width: 921 - height: 665 - m_MinSize: {x: 403, y: 492} - m_MaxSize: {x: 10001, y: 14042} - vertical: 1 - controlID: 92 ---- !u!114 &10 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12010, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: - - {fileID: 4} - - {fileID: 11} - m_Position: - serializedVersion: 2 - x: 0 - y: 0 - width: 921 - height: 394 - m_MinSize: {x: 403, y: 221} - m_MaxSize: {x: 8003, y: 4021} - vertical: 0 - controlID: 93 ---- !u!114 &11 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12006, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_Children: [] - m_Position: - serializedVersion: 2 - x: 228 - y: 0 - width: 693 - height: 394 - m_MinSize: {x: 202, y: 221} - m_MaxSize: {x: 4002, y: 4021} - m_ActualView: {fileID: 15} - m_Panes: - - {fileID: 15} - - {fileID: 16} - m_Selected: 0 - m_LastSelected: 1 ---- !u!114 &12 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12014, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_MinSize: {x: 230, y: 250} - m_MaxSize: {x: 10000, y: 10000} - m_TitleContent: - m_Text: Project - m_Image: {fileID: -5467254957812901981, guid: 0000000000000000d000000000000000, type: 0} - m_Tooltip: - m_Pos: - serializedVersion: 2 - x: 2249 - y: 726.5 - width: 920 - height: 250 - m_ViewDataDictionary: {fileID: 0} - m_SearchFilter: - m_NameFilter: - m_ClassNames: [] - m_AssetLabels: [] - m_AssetBundleNames: [] - m_VersionControlStates: [] - m_SoftLockControlStates: [] - m_ReferencingInstanceIDs: - m_SceneHandles: - m_ShowAllHits: 0 - m_SkipHidden: 0 - m_SearchArea: 1 - m_Folders: - - Assets - m_Globs: [] - m_ViewMode: 1 - m_StartGridSize: 64 - m_LastFolders: - - Assets - m_LastFoldersGridSize: -1 - m_LastProjectPath: U:\layout - m_LockTracker: - m_IsLocked: 0 - m_FolderTreeState: - scrollPos: {x: 0, y: 0} - m_SelectedIDs: f4350000 - m_LastClickedID: 13812 - m_ExpandedIDs: 00000000f435000000ca9a3b - m_RenameOverlay: - m_UserAcceptedRename: 0 - m_Name: - m_OriginalName: - m_EditFieldRect: - serializedVersion: 2 - x: 0 - y: 0 - width: 0 - height: 0 - m_UserData: 0 - m_IsWaitingForDelay: 0 - m_IsRenaming: 0 - m_OriginalEventType: 11 - m_IsRenamingFilename: 1 - m_ClientGUIView: {fileID: 0} - m_SearchString: - m_CreateAssetUtility: - m_EndAction: {fileID: 0} - m_InstanceID: 0 - m_Path: - m_Icon: {fileID: 0} - m_ResourceFile: - m_AssetTreeState: - scrollPos: {x: 0, y: 0} - m_SelectedIDs: - m_LastClickedID: 0 - m_ExpandedIDs: 00000000f4350000 - m_RenameOverlay: - m_UserAcceptedRename: 0 - m_Name: - m_OriginalName: - m_EditFieldRect: - serializedVersion: 2 - x: 0 - y: 0 - width: 0 - height: 0 - m_UserData: 0 - m_IsWaitingForDelay: 0 - m_IsRenaming: 0 - m_OriginalEventType: 11 - m_IsRenamingFilename: 1 - m_ClientGUIView: {fileID: 0} - m_SearchString: - m_CreateAssetUtility: - m_EndAction: {fileID: 0} - m_InstanceID: 0 - m_Path: - m_Icon: {fileID: 0} - m_ResourceFile: - m_ListAreaState: - m_SelectedInstanceIDs: - m_LastClickedInstanceID: 0 - m_HadKeyboardFocusLastEvent: 0 - m_ExpandedInstanceIDs: c6230000 - m_RenameOverlay: - m_UserAcceptedRename: 0 - m_Name: - m_OriginalName: - m_EditFieldRect: - serializedVersion: 2 - x: 0 - y: 0 - width: 0 - height: 0 - m_UserData: 0 - m_IsWaitingForDelay: 0 - m_IsRenaming: 0 - m_OriginalEventType: 11 - m_IsRenamingFilename: 1 - m_ClientGUIView: {fileID: 0} - m_CreateAssetUtility: - m_EndAction: {fileID: 0} - m_InstanceID: 0 - m_Path: - m_Icon: {fileID: 0} - m_ResourceFile: - m_NewAssetIndexInList: -1 - m_ScrollPosition: {x: 0, y: 0} - m_GridSize: 64 - m_SkipHiddenPackages: 0 - m_DirectoriesAreaWidth: 207 ---- !u!114 &13 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12019, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_MinSize: {x: 275, y: 50} - m_MaxSize: {x: 4000, y: 4000} - m_TitleContent: - m_Text: Inspector - m_Image: {fileID: -2667387946076563598, guid: 0000000000000000d000000000000000, type: 0} - m_Tooltip: - m_Pos: - serializedVersion: 2 - x: 3170 - y: 332.5 - width: 284 - height: 644 - m_ViewDataDictionary: {fileID: 0} - m_ObjectsLockedBeforeSerialization: [] - m_InstanceIDsLockedBeforeSerialization: - m_PreviewResizer: - m_CachedPref: 160 - m_ControlHash: -371814159 - m_PrefName: Preview_InspectorPreview - m_LastInspectedObjectInstanceID: -1 - m_LastVerticalScrollValue: 0 - m_AssetGUID: - m_InstanceID: 0 - m_LockTracker: - m_IsLocked: 0 - m_PreviewWindow: {fileID: 0} ---- !u!114 &14 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12061, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_MinSize: {x: 200, y: 200} - m_MaxSize: {x: 4000, y: 4000} - m_TitleContent: - m_Text: Hierarchy - m_Image: {fileID: 7966133145522015247, guid: 0000000000000000d000000000000000, type: 0} - m_Tooltip: - m_Pos: - serializedVersion: 2 - x: 2249 - y: 332.5 - width: 227 - height: 373 - m_ViewDataDictionary: {fileID: 0} - m_SceneHierarchy: - m_TreeViewState: - scrollPos: {x: 0, y: 0} - m_SelectedIDs: - m_LastClickedID: 0 - m_ExpandedIDs: 42fbffff - m_RenameOverlay: - m_UserAcceptedRename: 0 - m_Name: - m_OriginalName: - m_EditFieldRect: - serializedVersion: 2 - x: 0 - y: 0 - width: 0 - height: 0 - m_UserData: 0 - m_IsWaitingForDelay: 0 - m_IsRenaming: 0 - m_OriginalEventType: 11 - m_IsRenamingFilename: 0 - m_ClientGUIView: {fileID: 0} - m_SearchString: - m_ExpandedScenes: [] - m_CurrenRootInstanceID: 0 - m_LockTracker: - m_IsLocked: 0 - m_CurrentSortingName: TransformSorting - m_WindowGUID: 4c969a2b90040154d917609493e03593 ---- !u!114 &15 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12013, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_MinSize: {x: 200, y: 200} - m_MaxSize: {x: 4000, y: 4000} - m_TitleContent: - m_Text: Scene - m_Image: {fileID: 2593428753322112591, guid: 0000000000000000d000000000000000, type: 0} - m_Tooltip: - m_Pos: - serializedVersion: 2 - x: 2477 - y: 332.5 - width: 691 - height: 373 - m_ViewDataDictionary: {fileID: 0} - m_ShowContextualTools: 0 - m_WindowGUID: cc27987af1a868c49b0894db9c0f5429 - m_Gizmos: 1 - m_OverrideSceneCullingMask: 6917529027641081856 - m_SceneIsLit: 1 - m_SceneLighting: 1 - m_2DMode: 0 - m_isRotationLocked: 0 - m_PlayAudio: 0 - m_AudioPlay: 0 - m_Position: - m_Target: {x: 0, y: 0, z: 0} - speed: 2 - m_Value: {x: 0, y: 0, z: 0} - m_RenderMode: 0 - m_CameraMode: - drawMode: 0 - name: Shaded - section: Shading Mode - m_ValidateTrueMetals: 0 - m_DoValidateTrueMetals: 0 - m_ExposureSliderValue: 0 - m_SceneViewState: - showFog: 1 - showMaterialUpdate: 0 - showSkybox: 1 - showFlares: 1 - showImageEffects: 1 - showParticleSystems: 1 - showVisualEffectGraphs: 1 - m_Grid: - xGrid: - m_Fade: - m_Target: 0 - speed: 2 - m_Value: 0 - m_Color: {r: 0.5, g: 0.5, b: 0.5, a: 0.4} - m_Pivot: {x: 0, y: 0, z: 0} - m_Size: {x: 0, y: 0} - yGrid: - m_Fade: - m_Target: 1 - speed: 2 - m_Value: 1 - m_Color: {r: 0.5, g: 0.5, b: 0.5, a: 0.4} - m_Pivot: {x: 0, y: 0, z: 0} - m_Size: {x: 1, y: 1} - zGrid: - m_Fade: - m_Target: 0 - speed: 2 - m_Value: 0 - m_Color: {r: 0.5, g: 0.5, b: 0.5, a: 0.4} - m_Pivot: {x: 0, y: 0, z: 0} - m_Size: {x: 0, y: 0} - m_ShowGrid: 1 - m_GridAxis: 1 - m_gridOpacity: 0.5 - m_Rotation: - m_Target: {x: -0.08717229, y: 0.89959055, z: -0.21045254, w: -0.3726226} - speed: 2 - m_Value: {x: -0.08717229, y: 0.89959055, z: -0.21045254, w: -0.3726226} - m_Size: - m_Target: 10 - speed: 2 - m_Value: 10 - m_Ortho: - m_Target: 0 - speed: 2 - m_Value: 0 - m_CameraSettings: - m_Speed: 1 - m_SpeedNormalized: 0.5 - m_SpeedMin: 0.001 - m_SpeedMax: 2 - m_EasingEnabled: 1 - m_EasingDuration: 0.4 - m_AccelerationEnabled: 1 - m_FieldOfView: 90 - m_NearClip: 0.03 - m_FarClip: 10000 - m_DynamicClip: 1 - m_OcclusionCulling: 0 - m_LastSceneViewRotation: {x: 0, y: 0, z: 0, w: 0} - m_LastSceneViewOrtho: 0 - m_ReplacementShader: {fileID: 0} - m_ReplacementString: - m_SceneVisActive: 1 - m_LastLockedObject: {fileID: 0} - m_ViewIsLockedToObject: 0 ---- !u!114 &16 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12015, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_MinSize: {x: 200, y: 200} - m_MaxSize: {x: 4000, y: 4000} - m_TitleContent: - m_Text: Game - m_Image: {fileID: -6423792434712278376, guid: 0000000000000000d000000000000000, type: 0} - m_Tooltip: - m_Pos: - serializedVersion: 2 - x: 507 - y: 94 - width: 1532 - height: 790 - m_ViewDataDictionary: {fileID: 0} - m_SerializedViewsNames: [] - m_SerializedViewsValues: [] - m_PlayModeViewName: GameView - m_ShowGizmos: 0 - m_TargetDisplay: 0 - m_ClearColor: {r: 0, g: 0, b: 0, a: 0} - m_TargetSize: {x: 640, y: 480} - m_TextureFilterMode: 0 - m_TextureHideFlags: 61 - m_RenderIMGUI: 0 - m_MaximizeOnPlay: 0 - m_UseMipMap: 0 - m_VSyncEnabled: 0 - m_Gizmos: 0 - m_Stats: 0 - m_SelectedSizes: 00000000000000000000000000000000000000000000000000000000000000000000000000000000 - m_ZoomArea: - m_HRangeLocked: 0 - m_VRangeLocked: 0 - hZoomLockedByDefault: 0 - vZoomLockedByDefault: 0 - m_HBaseRangeMin: -766 - m_HBaseRangeMax: 766 - m_VBaseRangeMin: -395 - m_VBaseRangeMax: 395 - m_HAllowExceedBaseRangeMin: 1 - m_HAllowExceedBaseRangeMax: 1 - m_VAllowExceedBaseRangeMin: 1 - m_VAllowExceedBaseRangeMax: 1 - m_ScaleWithWindow: 0 - m_HSlider: 0 - m_VSlider: 0 - m_IgnoreScrollWheelUntilClicked: 0 - m_EnableMouseInput: 1 - m_EnableSliderZoomHorizontal: 0 - m_EnableSliderZoomVertical: 0 - m_UniformScale: 1 - m_UpDirection: 1 - m_DrawArea: - serializedVersion: 2 - x: 0 - y: 0 - width: 1532 - height: 790 - m_Scale: {x: 1, y: 1} - m_Translation: {x: 766, y: 395} - m_MarginLeft: 0 - m_MarginRight: 0 - m_MarginTop: 0 - m_MarginBottom: 0 - m_LastShownAreaInsideMargins: - serializedVersion: 2 - x: -766 - y: -395 - width: 1532 - height: 790 - m_MinimalGUI: 1 - m_defaultScale: 1 - m_LastWindowPixelSize: {x: 1532, y: 790} - m_ClearInEditMode: 1 - m_NoCameraWarning: 1 - m_LowResolutionForAspectRatios: 01000000000000000000 - m_XRRenderMode: 0 - m_RenderTexture: {fileID: 0} ---- !u!114 &17 -MonoBehaviour: - m_ObjectHideFlags: 52 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 1 - m_Script: {fileID: 12003, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_MinSize: {x: 100, y: 100} - m_MaxSize: {x: 4000, y: 4000} - m_TitleContent: - m_Text: Console - m_Image: {fileID: -4327648978806127646, guid: 0000000000000000d000000000000000, type: 0} - m_Tooltip: - m_Pos: - serializedVersion: 2 - x: 2249 - y: 726.5 - width: 920 - height: 250 - m_ViewDataDictionary: {fileID: 0} ---- !u!114 &18 -MonoBehaviour: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 0 - m_Script: {fileID: 13963, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_DontSaveToLayout: 0 diff --git a/circle.yml b/circle.yml deleted file mode 100644 index a0ca3590..00000000 --- a/circle.yml +++ /dev/null @@ -1,13 +0,0 @@ -machine: - xcode: - version: 8.1 - environment: - XCODE_PROJECT: dummy.xcodeproj - XCODE_SCHEME: phony - pre: - # grab a current link from: http://unity3d.com/get-unity/download/archive - - curl -o Unity.pkg https://netstorage.unity3d.com/unity/5d30cf096e79/MacEditorInstaller/Unity-2017.1.1f1.pkg - - sudo installer -dumplog -package Unity.pkg -target / -test: - override: - - /Applications/Unity/Unity.app/Contents/MacOS/Unity -batchmode -nographics -silent-crashes -logFile $(pwd)/unity.log -projectpath $(pwd) -buildOSXUniversalPlayer "$(pwd)/tangram-unity.app" -quit diff --git a/package.json b/package.json new file mode 100644 index 00000000..f3d3f219 --- /dev/null +++ b/package.json @@ -0,0 +1,19 @@ +{ + "name": "tangram-unity", + "version": "1.0.0", + "displayName": "Tangram Unity", + "description": "Tangram Unity is a library of tools for using OpenStreetMap data in the Unity3D game engine. This repository contains the code and GUI tools along with an example scene that demonstrates how to use them.", + "unity": "2021.3", + "unityRelease": "22f1", + "documentationUrl": "https://github.com/tangrams/tangram-unity", + "keywords": [ + "nextzen", + "mapzen", + "tangrams", + "tangram-unity" + ], + "author": { + "name": "tangrams", + "url": "https://github.com/tangrams/tangram-unity" + } +} \ No newline at end of file diff --git a/package.json.meta b/package.json.meta new file mode 100644 index 00000000..3a3d7522 --- /dev/null +++ b/package.json.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 085a07ced94059c4eb7cd5ea01dead2b +PackageManifestImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/tangram-unity.png.meta b/tangram-unity.png.meta new file mode 100644 index 00000000..75522232 --- /dev/null +++ b/tangram-unity.png.meta @@ -0,0 +1,114 @@ +fileFormatVersion: 2 +guid: 9ce6c229b25dc91439a49757b513e21d +TextureImporter: + internalIDToNameTable: [] + externalObjects: {} + serializedVersion: 13 + mipmaps: + mipMapMode: 0 + enableMipMap: 1 + sRGBTexture: 1 + linearTexture: 0 + fadeOut: 0 + borderMipMap: 0 + mipMapsPreserveCoverage: 0 + alphaTestReferenceValue: 0.5 + mipMapFadeDistanceStart: 1 + mipMapFadeDistanceEnd: 3 + bumpmap: + convertToNormalMap: 0 + externalNormalMap: 0 + heightScale: 0.25 + normalMapFilter: 0 + flipGreenChannel: 0 + isReadable: 0 + streamingMipmaps: 0 + streamingMipmapsPriority: 0 + vTOnly: 0 + ignoreMipmapLimit: 0 + grayScaleToAlpha: 0 + generateCubemap: 6 + cubemapConvolution: 0 + seamlessCubemap: 0 + textureFormat: 1 + maxTextureSize: 2048 + textureSettings: + serializedVersion: 2 + filterMode: 1 + aniso: 1 + mipBias: 0 + wrapU: 0 + wrapV: 0 + wrapW: 0 + nPOTScale: 1 + lightmap: 0 + compressionQuality: 50 + spriteMode: 0 + spriteExtrude: 1 + spriteMeshType: 1 + alignment: 0 + spritePivot: {x: 0.5, y: 0.5} + spritePixelsToUnits: 100 + spriteBorder: {x: 0, y: 0, z: 0, w: 0} + spriteGenerateFallbackPhysicsShape: 1 + alphaUsage: 1 + alphaIsTransparency: 0 + spriteTessellationDetail: -1 + textureType: 0 + textureShape: 1 + singleChannelComponent: 0 + flipbookRows: 1 + flipbookColumns: 1 + maxTextureSizeSet: 0 + compressionQualitySet: 0 + textureFormatSet: 0 + ignorePngGamma: 0 + applyGammaDecoding: 0 + swizzle: 50462976 + cookieLightType: 0 + platformSettings: + - serializedVersion: 3 + buildTarget: DefaultTexturePlatform + maxTextureSize: 2048 + resizeAlgorithm: 0 + textureFormat: -1 + textureCompression: 1 + compressionQuality: 50 + crunchedCompression: 0 + allowsAlphaSplitting: 0 + overridden: 0 + ignorePlatformSupport: 0 + androidETC2FallbackOverride: 0 + forceMaximumCompressionQuality_BC6H_BC7: 0 + - serializedVersion: 3 + buildTarget: Standalone + maxTextureSize: 2048 + resizeAlgorithm: 0 + textureFormat: -1 + textureCompression: 1 + compressionQuality: 50 + crunchedCompression: 0 + allowsAlphaSplitting: 0 + overridden: 0 + ignorePlatformSupport: 0 + androidETC2FallbackOverride: 0 + forceMaximumCompressionQuality_BC6H_BC7: 0 + spriteSheet: + serializedVersion: 2 + sprites: [] + outline: [] + physicsShape: [] + bones: [] + spriteID: + internalID: 0 + vertices: [] + indices: + edges: [] + weights: [] + secondaryTextures: [] + nameFileIdTable: {} + mipmapLimitGroupName: + pSDRemoveMatte: 0 + userData: + assetBundleName: + assetBundleVariant: diff --git a/tangram-unity.sln.DotSettings b/tangram-unity.sln.DotSettings deleted file mode 100644 index 5db575cf..00000000 --- a/tangram-unity.sln.DotSettings +++ /dev/null @@ -1,2 +0,0 @@ - - True \ No newline at end of file From 76e9783cb86c7aeb9131ed3b7b1fa55bedfa5b18 Mon Sep 17 00:00:00 2001 From: Dewald Bodenstein Date: Thu, 8 Feb 2024 05:53:12 +0200 Subject: [PATCH 3/4] rename Plugins --- Runtime/Plugins/Protobuf.meta | 9 - .../Plugins/Protobuf/Google.Protobuf.dll.meta | 34 - Runtime/Plugins/Protobuf/Google.Protobuf.xml | 7028 ----------------- .../Plugins/Protobuf/Google.Protobuf.xml.meta | 8 - 4 files changed, 7079 deletions(-) delete mode 100644 Runtime/Plugins/Protobuf.meta delete mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta delete mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.xml delete mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta diff --git a/Runtime/Plugins/Protobuf.meta b/Runtime/Plugins/Protobuf.meta deleted file mode 100644 index 2443298a..00000000 --- a/Runtime/Plugins/Protobuf.meta +++ /dev/null @@ -1,9 +0,0 @@ -fileFormatVersion: 2 -guid: fd3426b2e741b4f49a615bd7a48c16f4 -folderAsset: yes -timeCreated: 1496624517 -licenseType: Free -DefaultImporter: - userData: - assetBundleName: - assetBundleVariant: diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta b/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta deleted file mode 100644 index 43672dc3..00000000 --- a/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta +++ /dev/null @@ -1,34 +0,0 @@ -fileFormatVersion: 2 -guid: 5ad31ad7e29cad14e933a09c5c84d9c4 -timeCreated: 1496624518 -licenseType: Free -PluginImporter: - serializedVersion: 2 - iconMap: {} - executionOrder: {} - isPreloaded: 0 - isOverridable: 0 - platformData: - data: - first: - Any: - second: - enabled: 1 - settings: {} - data: - first: - Editor: Editor - second: - enabled: 0 - settings: - DefaultValueInitialized: true - data: - first: - Windows Store Apps: WindowsStoreApps - second: - enabled: 0 - settings: - CPU: AnyCPU - userData: - assetBundleName: - assetBundleVariant: diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.xml b/Runtime/Plugins/Protobuf/Google.Protobuf.xml deleted file mode 100644 index 1a7bbd4b..00000000 --- a/Runtime/Plugins/Protobuf/Google.Protobuf.xml +++ /dev/null @@ -1,7028 +0,0 @@ - - - - Google.Protobuf - - - - - Provides a utility routine to copy small arrays much more quickly than Buffer.BlockCopy - - - - - The threshold above which you should use Buffer.BlockCopy rather than ByteArray.Copy - - - - - Determines which copy routine to use based on the number of bytes to be copied. - - - - - Reverses the order of bytes in the array - - - - - Immutable array of bytes. - - - - - Unsafe operations that can cause IO Failure and/or other catestrophic side-effects. - - - - - Constructs a new ByteString from the given byte array. The array is - *not* copied, and must not be modified after this constructor is called. - - - - - Provides direct, unrestricted access to the bytes contained in this instance. - You must not modify or resize the byte array returned by this method. - - - - - Internal use only. Ensure that the provided array is not mutated and belongs to this instance. - - - - - Constructs a new ByteString from the given byte array. The array is - *not* copied, and must not be modified after this constructor is called. - - - - - Returns an empty ByteString. - - - - - Returns the length of this ByteString in bytes. - - - - - Returns true if this byte string is empty, false otherwise. - - - - - Converts this into a byte array. - - The data is copied - changes to the returned array will not be reflected in this ByteString. - A byte array with the same data as this ByteString. - - - - Converts this into a standard base64 representation. - - A base64 representation of this ByteString. - - - - Constructs a from the Base64 Encoded String. - - - - - Constructs a from data in the given stream, synchronously. - - If successful, will be read completely, from the position - at the start of the call. - The stream to copy into a ByteString. - A ByteString with content read from the given stream. - - - - Constructs a from the given array. The contents - are copied, so further modifications to the array will not - be reflected in the returned ByteString. - This method can also be invoked in ByteString.CopyFrom(0xaa, 0xbb, ...) form - which is primarily useful for testing. - - - - - Constructs a from a portion of a byte array. - - - - - Creates a new by encoding the specified text with - the given encoding. - - - - - Creates a new by encoding the specified text in UTF-8. - - - - - Retuns the byte at the given index. - - - - - Converts this into a string by applying the given encoding. - - - This method should only be used to convert binary data which was the result of encoding - text with the given encoding. - - The encoding to use to decode the binary data into text. - The result of decoding the binary data with the given decoding. - - - - Converts this into a string by applying the UTF-8 encoding. - - - This method should only be used to convert binary data which was the result of encoding - text with UTF-8. - - The result of decoding the binary data with the given decoding. - - - - Returns an iterator over the bytes in this . - - An iterator over the bytes in this object. - - - - Returns an iterator over the bytes in this . - - An iterator over the bytes in this object. - - - - Creates a CodedInputStream from this ByteString's data. - - - - - Compares two byte strings for equality. - - The first byte string to compare. - The second byte string to compare. - true if the byte strings are equal; false otherwise. - - - - Compares two byte strings for inequality. - - The first byte string to compare. - The second byte string to compare. - false if the byte strings are equal; true otherwise. - - - - Compares this byte string with another object. - - The object to compare this with. - true if refers to an equal ; false otherwise. - - - - Returns a hash code for this object. Two equal byte strings - will return the same hash code. - - A hash code for this object. - - - - Compares this byte string with another. - - The to compare this with. - true if refers to an equal byte string; false otherwise. - - - - Used internally by CodedOutputStream to avoid creating a copy for the write - - - - - Copies the entire byte array to the destination array provided at the offset specified. - - - - - Writes the entire byte array to the provided stream - - - - - Reads and decodes protocol message fields. - - - - This class is generally used by generated code to read appropriate - primitives from the stream. It effectively encapsulates the lowest - levels of protocol buffer format. - - - Repeated fields and map fields are not handled by this class; use - and to serialize such fields. - - - - - - Whether to leave the underlying stream open when disposing of this stream. - This is always true when there's no stream. - - - - - Buffer of data read from the stream or provided at construction time. - - - - - The index of the buffer at which we need to refill from the stream (if there is one). - - - - - The position within the current buffer (i.e. the next byte to read) - - - - - The stream to read further input from, or null if the byte array buffer was provided - directly on construction, with no further data available. - - - - - The last tag we read. 0 indicates we've read to the end of the stream - (or haven't read anything yet). - - - - - The next tag, used to store the value read by PeekTag. - - - - - The total number of bytes read before the current buffer. The - total bytes read up to the current position can be computed as - totalBytesRetired + bufferPos. - - - - - The absolute position of the end of the current message. - - - - - Creates a new CodedInputStream reading data from the given byte array. - - - - - Creates a new that reads from the given byte array slice. - - - - - Creates a new reading data from the given stream, which will be disposed - when the returned object is disposed. - - The stream to read from. - - - - Creates a new reading data from the given stream. - - The stream to read from. - true to leave open when the returned - is disposed; false to dispose of the given stream when the - returned object is disposed. - - - - Creates a new CodedInputStream reading data from the given - stream and buffer, using the default limits. - - - - - Creates a new CodedInputStream reading data from the given - stream and buffer, using the specified limits. - - - This chains to the version with the default limits instead of vice versa to avoid - having to check that the default values are valid every time. - - - - - Creates a with the specified size and recursion limits, reading - from an input stream. - - - This method exists separately from the constructor to reduce the number of constructor overloads. - It is likely to be used considerably less frequently than the constructors, as the default limits - are suitable for most use cases. - - The input stream to read from - The total limit of data to read from the stream. - The maximum recursion depth to allow while reading. - A CodedInputStream reading from with the specified size - and recursion limits. - - - - Returns the current position in the input stream, or the position in the input buffer - - - - - Returns the last tag read, or 0 if no tags have been read or we've read beyond - the end of the stream. - - - - - Returns the size limit for this stream. - - - This limit is applied when reading from the underlying stream, as a sanity check. It is - not applied when reading from a byte array data source without an underlying stream. - The default value is 64MB. - - - The size limit. - - - - - Returns the recursion limit for this stream. This limit is applied whilst reading messages, - to avoid maliciously-recursive data. - - - The default limit is 64. - - - The recursion limit for this stream. - - - - - Disposes of this instance, potentially closing any underlying stream. - - - As there is no flushing to perform here, disposing of a which - was constructed with the leaveOpen option parameter set to true (or one which - was constructed to read from a byte array) has no effect. - - - - - Verifies that the last call to ReadTag() returned tag 0 - in other words, - we've reached the end of the stream when we expected to. - - The - tag read was not the one specified - - - - Peeks at the next field tag. This is like calling , but the - tag is not consumed. (So a subsequent call to will return the - same value.) - - - - - Reads a field tag, returning the tag of 0 for "end of stream". - - - If this method returns 0, it doesn't necessarily mean the end of all - the data in this CodedInputStream; it may be the end of the logical stream - for an embedded message, for example. - - The next field tag, or 0 for end of stream. (0 is never a valid tag.) - - - - Skips the data for the field with the tag we've just read. - This should be called directly after , when - the caller wishes to skip an unknown field. - - - This method throws if the last-read tag was an end-group tag. - If a caller wishes to skip a group, they should skip the whole group, by calling this method after reading the - start-group tag. This behavior allows callers to call this method on any field they don't understand, correctly - resulting in an error if an end-group tag has not been paired with an earlier start-group tag. - - The last tag was an end-group tag - The last read operation read to the end of the logical stream - - - - Reads a double field from the stream. - - - - - Reads a float field from the stream. - - - - - Reads a uint64 field from the stream. - - - - - Reads an int64 field from the stream. - - - - - Reads an int32 field from the stream. - - - - - Reads a fixed64 field from the stream. - - - - - Reads a fixed32 field from the stream. - - - - - Reads a bool field from the stream. - - - - - Reads a string field from the stream. - - - - - Reads an embedded message field value from the stream. - - - - - Reads a bytes field value from the stream. - - - - - Reads a uint32 field value from the stream. - - - - - Reads an enum field value from the stream. - - - - - Reads an sfixed32 field value from the stream. - - - - - Reads an sfixed64 field value from the stream. - - - - - Reads an sint32 field value from the stream. - - - - - Reads an sint64 field value from the stream. - - - - - Reads a length for length-delimited data. - - - This is internally just reading a varint, but this method exists - to make the calling code clearer. - - - - - Peeks at the next tag in the stream. If it matches , - the tag is consumed and the method returns true; otherwise, the - stream is left in the original position and the method returns false. - - - - - Same code as ReadRawVarint32, but read each byte individually, checking for - buffer overflow. - - - - - Reads a raw Varint from the stream. If larger than 32 bits, discard the upper bits. - This method is optimised for the case where we've got lots of data in the buffer. - That means we can check the size just once, then just read directly from the buffer - without constant rechecking of the buffer length. - - - - - Reads a varint from the input one byte at a time, so that it does not - read any bytes after the end of the varint. If you simply wrapped the - stream in a CodedInputStream and used ReadRawVarint32(Stream) - then you would probably end up reading past the end of the varint since - CodedInputStream buffers its input. - - - - - - - Reads a raw varint from the stream. - - - - - Reads a 32-bit little-endian integer from the stream. - - - - - Reads a 64-bit little-endian integer from the stream. - - - - - Decode a 32-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Decode a 32-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Sets currentLimit to (current position) + byteLimit. This is called - when descending into a length-delimited embedded message. The previous - limit is returned. - - The old limit. - - - - Discards the current limit, returning the previous limit. - - - - - Returns whether or not all the data before the limit has been read. - - - - - - Returns true if the stream has reached the end of the input. This is the - case if either the end of the underlying input source has been reached or - the stream has reached a limit created using PushLimit. - - - - - Called when buffer is empty to read more bytes from the - input. If is true, RefillBuffer() gurantees that - either there will be at least one byte in the buffer when it returns - or it will throw an exception. If is false, - RefillBuffer() returns false if no more bytes were available. - - - - - - - Read one byte from the input. - - - the end of the stream or the current limit was reached - - - - - Reads a fixed size of bytes from the input. - - - the end of the stream or the current limit was reached - - - - - Reads and discards bytes. - - the end of the stream - or the current limit was reached - - - - Abstraction of skipping to cope with streams which can't really skip. - - - - - Encodes and writes protocol message fields. - - - - This class is generally used by generated code to write appropriate - primitives to the stream. It effectively encapsulates the lowest - levels of protocol buffer format. Unlike some other implementations, - this does not include combined "write tag and value" methods. Generated - code knows the exact byte representations of the tags they're going to write, - so there's no need to re-encode them each time. Manually-written code calling - this class should just call one of the WriteTag overloads before each value. - - - Repeated fields and map fields are not handled by this class; use RepeatedField<T> - and MapField<TKey, TValue> to serialize such fields. - - - - - - Computes the number of bytes that would be needed to encode a - double field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - float field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - uint64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - int64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - int32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - fixed64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - fixed32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - bool field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - string field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - group field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - embedded message field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - bytes field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - uint32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a - enum field, including the tag. The caller is responsible for - converting the enum value to its numeric value. - - - - - Computes the number of bytes that would be needed to encode an - sfixed32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - sfixed64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - sint32 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode an - sint64 field, including the tag. - - - - - Computes the number of bytes that would be needed to encode a length, - as written by . - - - - - Computes the number of bytes that would be needed to encode a varint. - - - - - Computes the number of bytes that would be needed to encode a varint. - - - - - Computes the number of bytes that would be needed to encode a tag. - - - - - The buffer size used by CreateInstance(Stream). - - - - - Creates a new CodedOutputStream that writes directly to the given - byte array. If more bytes are written than fit in the array, - OutOfSpaceException will be thrown. - - - - - Creates a new CodedOutputStream that writes directly to the given - byte array slice. If more bytes are written than fit in the array, - OutOfSpaceException will be thrown. - - - - - Creates a new which write to the given stream, and disposes of that - stream when the returned CodedOutputStream is disposed. - - The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. - - - - Creates a new CodedOutputStream which write to the given stream and uses - the specified buffer size. - - The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. - The size of buffer to use internally. - - - - Creates a new CodedOutputStream which write to the given stream. - - The stream to write to. - If true, is left open when the returned CodedOutputStream is disposed; - if false, the provided stream is disposed as well. - - - - Creates a new CodedOutputStream which write to the given stream and uses - the specified buffer size. - - The stream to write to. - The size of buffer to use internally. - If true, is left open when the returned CodedOutputStream is disposed; - if false, the provided stream is disposed as well. - - - - Returns the current position in the stream, or the position in the output buffer - - - - - Writes a double field value, without a tag, to the stream. - - The value to write - - - - Writes a float field value, without a tag, to the stream. - - The value to write - - - - Writes a uint64 field value, without a tag, to the stream. - - The value to write - - - - Writes an int64 field value, without a tag, to the stream. - - The value to write - - - - Writes an int32 field value, without a tag, to the stream. - - The value to write - - - - Writes a fixed64 field value, without a tag, to the stream. - - The value to write - - - - Writes a fixed32 field value, without a tag, to the stream. - - The value to write - - - - Writes a bool field value, without a tag, to the stream. - - The value to write - - - - Writes a string field value, without a tag, to the stream. - The data is length-prefixed. - - The value to write - - - - Writes a message, without a tag, to the stream. - The data is length-prefixed. - - The value to write - - - - Write a byte string, without a tag, to the stream. - The data is length-prefixed. - - The value to write - - - - Writes a uint32 value, without a tag, to the stream. - - The value to write - - - - Writes an enum value, without a tag, to the stream. - - The value to write - - - - Writes an sfixed32 value, without a tag, to the stream. - - The value to write. - - - - Writes an sfixed64 value, without a tag, to the stream. - - The value to write - - - - Writes an sint32 value, without a tag, to the stream. - - The value to write - - - - Writes an sint64 value, without a tag, to the stream. - - The value to write - - - - Writes a length (in bytes) for length-delimited data. - - - This method simply writes a rawint, but exists for clarity in calling code. - - Length value, in bytes. - - - - Encodes and writes a tag. - - The number of the field to write the tag for - The wire format type of the tag to write - - - - Writes an already-encoded tag. - - The encoded tag - - - - Writes the given single-byte tag directly to the stream. - - The encoded tag - - - - Writes the given two-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - - - - Writes the given three-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - The third byte of the encoded tag - - - - Writes the given four-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - The third byte of the encoded tag - The fourth byte of the encoded tag - - - - Writes the given five-byte tag directly to the stream. - - The first byte of the encoded tag - The second byte of the encoded tag - The third byte of the encoded tag - The fourth byte of the encoded tag - The fifth byte of the encoded tag - - - - Writes a 32 bit value as a varint. The fast route is taken when - there's enough buffer space left to whizz through without checking - for each byte; otherwise, we resort to calling WriteRawByte each time. - - - - - Writes out an array of bytes. - - - - - Writes out part of an array of bytes. - - - - - Encode a 32-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Encode a 64-bit value with ZigZag encoding. - - - ZigZag encodes signed integers into values that can be efficiently - encoded with varint. (Otherwise, negative values must be - sign-extended to 64 bits to be varint encoded, thus always taking - 10 bytes on the wire.) - - - - - Indicates that a CodedOutputStream wrapping a flat byte array - ran out of space. - - - - - Flushes any buffered data and optionally closes the underlying stream, if any. - - - - By default, any underlying stream is closed by this method. To configure this behaviour, - use a constructor overload with a leaveOpen parameter. If this instance does not - have an underlying stream, this method does nothing. - - - For the sake of efficiency, calling this method does not prevent future write calls - but - if a later write ends up writing to a stream which has been disposed, that is likely to - fail. It is recommend that you not call any other methods after this. - - - - - - Flushes any buffered data to the underlying stream (if there is one). - - - - - Verifies that SpaceLeft returns zero. It's common to create a byte array - that is exactly big enough to hold a message, then write to it with - a CodedOutputStream. Calling CheckNoSpaceLeft after writing verifies that - the message was actually as big as expected, which can help bugs. - - - - - If writing to a flat array, returns the space left in the array. Otherwise, - throws an InvalidOperationException. - - - - - Representation of a map field in a Protocol Buffer message. - - Key type in the map. Must be a type supported by Protocol Buffer map keys. - Value type in the map. Must be a type supported by Protocol Buffers. - - - For string keys, the equality comparison is provided by . - - - Null values are not permitted in the map, either for wrapper types or regular messages. - If a map is deserialized from a data stream and the value is missing from an entry, a default value - is created instead. For primitive types, that is the regular default value (0, the empty string and so - on); for message types, an empty instance of the message is created, as if the map entry contained a 0-length - encoded value for the field. - - - This implementation does not generally prohibit the use of key/value types which are not - supported by Protocol Buffers (e.g. using a key type of byte) but nor does it guarantee - that all operations will work in such cases. - - - The order in which entries are returned when iterating over this object is undefined, and may change - in future versions. - - - - - - Creates a deep clone of this object. - - - A deep clone of this object. - - - - - Adds the specified key/value pair to the map. - - - This operation fails if the key already exists in the map. To replace an existing entry, use the indexer. - - The key to add - The value to add. - The given key already exists in map. - - - - Determines whether the specified key is present in the map. - - The key to check. - true if the map contains the given key; false otherwise. - - - - Removes the entry identified by the given key from the map. - - The key indicating the entry to remove from the map. - true if the map contained the given key before the entry was removed; false otherwise. - - - - Gets the value associated with the specified key. - - The key whose value to get. - When this method returns, the value associated with the specified key, if the key is found; - otherwise, the default value for the type of the parameter. - This parameter is passed uninitialized. - true if the map contains an element with the specified key; otherwise, false. - - - - Gets or sets the value associated with the specified key. - - The key of the value to get or set. - The property is retrieved and key does not exist in the collection. - The value associated with the specified key. If the specified key is not found, - a get operation throws a , and a set operation creates a new element with the specified key. - - - - Gets a collection containing the keys in the map. - - - - - Gets a collection containing the values in the map. - - - - - Adds the specified entries to the map. The keys and values are not automatically cloned. - - The entries to add to the map. - - - - Returns an enumerator that iterates through the collection. - - - An enumerator that can be used to iterate through the collection. - - - - - Returns an enumerator that iterates through a collection. - - - An object that can be used to iterate through the collection. - - - - - Adds the specified item to the map. - - The item to add to the map. - - - - Removes all items from the map. - - - - - Determines whether map contains an entry equivalent to the given key/value pair. - - The key/value pair to find. - - - - - Copies the key/value pairs in this map to an array. - - The array to copy the entries into. - The index of the array at which to start copying values. - - - - Removes the specified key/value pair from the map. - - Both the key and the value must be found for the entry to be removed. - The key/value pair to remove. - true if the key/value pair was found and removed; false otherwise. - - - - Gets the number of elements contained in the map. - - - - - Gets a value indicating whether the map is read-only. - - - - - Determines whether the specified , is equal to this instance. - - The to compare with this instance. - - true if the specified is equal to this instance; otherwise, false. - - - - - Returns a hash code for this instance. - - - A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. - - - - - Compares this map with another for equality. - - - The order of the key/value pairs in the maps is not deemed significant in this comparison. - - The map to compare this with. - true if refers to an equal map; false otherwise. - - - - Adds entries to the map from the given stream. - - - It is assumed that the stream is initially positioned after the tag specified by the codec. - This method will continue reading entries from the stream until the end is reached, or - a different tag is encountered. - - Stream to read from - Codec describing how the key/value pairs are encoded - - - - Writes the contents of this map to the given coded output stream, using the specified codec - to encode each entry. - - The output stream to write to. - The codec to use for each entry. - - - - Calculates the size of this map based on the given entry codec. - - The codec to use to encode each entry. - - - - - Returns a string representation of this repeated field, in the same - way as it would be represented by the default JSON formatter. - - - - - A codec for a specific map field. This contains all the information required to encode and - decode the nested messages. - - - - - Creates a new entry codec based on a separate key codec and value codec, - and the tag to use for each map entry. - - The key codec. - The value codec. - The map tag to use to introduce each map entry. - - - - The tag used in the enclosing message to indicate map entries. - - - - - A mutable message class, used for parsing and serializing. This - delegates the work to a codec, but implements the interface - for interop with and . - This is nested inside Codec as it's tightly coupled to the associated codec, - and it's simpler if it has direct access to all its fields. - - - - - Read-only wrapper around another dictionary. - - - - - The contents of a repeated field: essentially, a collection with some extra - restrictions (no null values) and capabilities (deep cloning). - - - This implementation does not generally prohibit the use of types which are not - supported by Protocol Buffers but nor does it guarantee that all operations will work in such cases. - - The element type of the repeated field. - - - - Creates a deep clone of this repeated field. - - - If the field type is - a message type, each element is also cloned; otherwise, it is - assumed that the field type is primitive (including string and - bytes, both of which are immutable) and so a simple copy is - equivalent to a deep clone. - - A deep clone of this repeated field. - - - - Adds the entries from the given input stream, decoding them with the specified codec. - - The input stream to read from. - The codec to use in order to read each entry. - - - - Calculates the size of this collection based on the given codec. - - The codec to use when encoding each field. - The number of bytes that would be written to a by , - using the same codec. - - - - Writes the contents of this collection to the given , - encoding each value using the specified codec. - - The output stream to write to. - The codec to use when encoding each value. - - - - Adds the specified item to the collection. - - The item to add. - - - - Removes all items from the collection. - - - - - Determines whether this collection contains the given item. - - The item to find. - true if this collection contains the given item; false otherwise. - - - - Copies this collection to the given array. - - The array to copy to. - The first index of the array to copy to. - - - - Removes the specified item from the collection - - The item to remove. - true if the item was found and removed; false otherwise. - - - - Gets the number of elements contained in the collection. - - - - - Gets a value indicating whether the collection is read-only. - - - - - Adds all of the specified values into this collection. - - The values to add to this collection. - - - - Adds all of the specified values into this collection. This method is present to - allow repeated fields to be constructed from queries within collection initializers. - Within non-collection-initializer code, consider using the equivalent - method instead for clarity. - - The values to add to this collection. - - - - Returns an enumerator that iterates through the collection. - - - An enumerator that can be used to iterate through the collection. - - - - - Determines whether the specified , is equal to this instance. - - The to compare with this instance. - - true if the specified is equal to this instance; otherwise, false. - - - - - Returns an enumerator that iterates through a collection. - - - An object that can be used to iterate through the collection. - - - - - Returns a hash code for this instance. - - - A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. - - - - - Compares this repeated field with another for equality. - - The repeated field to compare this with. - true if refers to an equal repeated field; false otherwise. - - - - Returns the index of the given item within the collection, or -1 if the item is not - present. - - The item to find in the collection. - The zero-based index of the item, or -1 if it is not found. - - - - Inserts the given item at the specified index. - - The index at which to insert the item. - The item to insert. - - - - Removes the item at the given index. - - The zero-based index of the item to remove. - - - - Returns a string representation of this repeated field, in the same - way as it would be represented by the default JSON formatter. - - - - - Gets or sets the item at the specified index. - - - The element at the specified index. - - The zero-based index of the element to get or set. - The item at the specified index. - - - - Extension methods for , effectively providing - the familiar members from previous desktop framework versions while - targeting the newer releases, .NET Core etc. - - - - - Returns the public getter of a property, or null if there is no such getter - (either because it's read-only, or the getter isn't public). - - - - - Returns the public setter of a property, or null if there is no such setter - (either because it's write-only, or the setter isn't public). - - - - - Extension methods for in order to provide - backwards compatibility with .NET 3.5 - - - - - Write the contents of the current stream to the destination stream - - - - - Factory methods for . - - - - - Retrieves a codec suitable for a string field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a bytes field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a bool field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an int32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sint32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a fixed32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sfixed32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a uint32 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an int64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sint64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a fixed64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an sfixed64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a uint64 field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a float field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for a double field with the given tag. - - The tag. - A codec for the given tag. - - - - Retrieves a codec suitable for an enum field with the given tag. - - The tag. - A conversion function from to the enum type. - A conversion function from the enum type to . - A codec for the given tag. - - - - Retrieves a codec suitable for a message field with the given tag. - - The tag. - A parser to use for the message type. - A codec for the given tag. - - - - Creates a codec for a wrapper type of a class - which must be string or ByteString. - - - - - Creates a codec for a wrapper type of a struct - which must be Int32, Int64, UInt32, UInt64, - Bool, Single or Double. - - - - - Helper code to create codecs for wrapper types. - - - Somewhat ugly with all the static methods, but the conversions involved to/from nullable types make it - slightly tricky to improve. So long as we keep the public API (ForClassWrapper, ForStructWrapper) in place, - we can refactor later if we come up with something cleaner. - - - - - Returns a field codec which effectively wraps a value of type T in a message. - - - - - - - An encode/decode pair for a single field. This effectively encapsulates - all the information needed to read or write the field value from/to a coded - stream. - - - This class is public and has to be as it is used by generated code, but its public - API is very limited - just what the generated code needs to call directly. - - - - This never writes default values to the stream, and does not address "packedness" - in repeated fields itself, other than to know whether or not the field *should* be packed. - - - - - Returns a delegate to write a value (unconditionally) to a coded output stream. - - - - - Returns the size calculator for just a value. - - - - - Returns a delegate to read a value from a coded input stream. It is assumed that - the stream is already positioned on the appropriate tag. - - - - - Returns the fixed size for an entry, or 0 if sizes vary. - - - - - Gets the tag of the codec. - - - The tag of the codec. - - - - - Default value for this codec. Usually the same for every instance of the same type, but - for string/ByteString wrapper fields the codec's default value is null, whereas for - other string/ByteString fields it's "" or ByteString.Empty. - - - The default value of the codec's type. - - - - - Write a tag and the given value, *if* the value is not the default. - - - - - Reads a value of the codec type from the given . - - The input stream to read from. - The value read from the stream. - - - - Calculates the size required to write the given value, with a tag, - if the value is not the default. - - - - - Class containing helpful workarounds for various platform compatibility - - - - - A message type that has a custom string format for diagnostic purposes. - - - - Calling on a generated message type normally - returns the JSON representation. If a message type implements this interface, - then the method will be called instead of the regular - JSON formatting code, but only when ToString() is called either on the message itself - or on another message which contains it. This does not affect the normal JSON formatting of - the message. - - - For example, if you create a proto message representing a GUID, the internal - representation may be a bytes field or four fixed32 fields. However, when debugging - it may be more convenient to see a result in the same format as provides. - - This interface extends to avoid it accidentally being implemented - on types other than messages, where it would not be used by anything in the framework. - - - - - Returns a string representation of this object, for diagnostic purposes. - - - This method is called when a message is formatted as part of a - call. It does not affect the JSON representation used by other than - in calls to . While it is recommended - that the result is valid JSON, this is never assumed by the Protobuf library. - - A string representation of this object, for diagnostic purposes. - - - - Generic interface for a deeply cloneable type. - - - - All generated messages implement this interface, but so do some non-message types. - Additionally, due to the type constraint on T in , - it is simpler to keep this as a separate interface. - - - The type itself, returned by the method. - - - - Creates a deep clone of this object. - - A deep clone of this object. - - - - Interface for a Protocol Buffers message, supporting - basic operations required for serialization. - - - - - Merges the data from the specified coded input stream with the current message. - - See the user guide for precise merge semantics. - - - - - Writes the data to the given coded output stream. - - Coded output stream to write the data to. Must not be null. - - - - Calculates the size of this message in Protocol Buffer wire format, in bytes. - - The number of bytes required to write this message - to a coded output stream. - - - - Descriptor for this message. All instances are expected to return the same descriptor, - and for generated types this will be an explicitly-implemented member, returning the - same value as the static property declared on the type. - - - - - Generic interface for a Protocol Buffers message, - where the type parameter is expected to be the same type as - the implementation class. - - The message type. - - - - Merges the given message into this one. - - See the user guide for precise merge semantics. - The message to merge with this one. Must not be null. - - - - Thrown when an attempt is made to parse invalid JSON, e.g. using - a non-string property key, or including a redundant comma. Parsing a protocol buffer - message represented in JSON using can throw both this - exception and depending on the situation. This - exception is only thrown for "pure JSON" errors, whereas InvalidProtocolBufferException - is thrown when the JSON may be valid in and of itself, but cannot be parsed as a protocol buffer - message. - - - - - Thrown when a protocol message being parsed is invalid in some way, - e.g. it contains a malformed varint or a negative byte length. - - - - - Creates an exception for an error condition of an invalid tag being encountered. - - - - - Reflection-based converter from messages to JSON. - - - - Instances of this class are thread-safe, with no mutable state. - - - This is a simple start to get JSON formatting working. As it's reflection-based, - it's not as quick as baking calls into generated messages - but is a simpler implementation. - (This code is generally not heavily optimized.) - - - - - - Returns a formatter using the default settings. - - - - - The JSON representation of the first 160 characters of Unicode. - Empty strings are replaced by the static constructor. - - - - - Creates a new formatted with the given settings. - - The settings. - - - - Formats the specified message as JSON. - - The message to format. - The formatted message. - - - - Formats the specified message as JSON. - - The message to format. - The TextWriter to write the formatted message to. - The formatted message. - - - - Converts a message to JSON for diagnostic purposes with no extra context. - - - - This differs from calling on the default JSON - formatter in its handling of . As no type registry is available - in calls, the normal way of resolving the type of - an Any message cannot be applied. Instead, a JSON property named @value - is included with the base64 data from the property of the message. - - The value returned by this method is only designed to be used for diagnostic - purposes. It may not be parsable by , and may not be parsable - by other Protocol Buffer implementations. - - The message to format for diagnostic purposes. - The diagnostic-only JSON representation of the message - - - - Writes a single value to the given writer as JSON. Only types understood by - Protocol Buffers can be written in this way. This method is only exposed for - advanced use cases; most users should be using - or . - - The writer to write the value to. Must not be null. - The value to write. May be null. - - - - Central interception point for well-known type formatting. Any well-known types which - don't need special handling can fall back to WriteMessage. We avoid assuming that the - values are using the embedded well-known types, in order to allow for dynamic messages - in the future. - - - - - Writes a string (including leading and trailing double quotes) to a builder, escaping as required. - - - Other than surrogate pair handling, this code is mostly taken from src/google/protobuf/util/internal/json_escaping.cc. - - - - - Settings controlling JSON formatting. - - - - - Default settings, as used by - - - - - Whether fields whose values are the default for the field type (e.g. 0 for integers) - should be formatted (true) or omitted (false). - - - - - The type registry used to format messages. - - - - - Whether to format enums as ints. Defaults to false. - - - - - Creates a new object with the specified formatting of default values - and an empty type registry. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - - - - Creates a new object with the specified formatting of default values - and type registry. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - The to use when formatting messages. - - - - Creates a new object with the specified parameters. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - The to use when formatting messages. TypeRegistry.Empty will be used if it is null. - true to format the enums as integers; false to format enums as enum names. - - - - Creates a new object with the specified formatting of default values and the current settings. - - true if default values (0, empty strings etc) should be formatted; false otherwise. - - - - Creates a new object with the specified type registry and the current settings. - - The to use when formatting messages. - - - - Creates a new object with the specified enums formatting option and the current settings. - - true to format the enums as integers; false to format enums as enum names. - - - - Reflection-based converter from JSON to messages. - - - - Instances of this class are thread-safe, with no mutable state. - - - This is a simple start to get JSON parsing working. As it's reflection-based, - it's not as quick as baking calls into generated messages - but is a simpler implementation. - (This code is generally not heavily optimized.) - - - - - - Returns a formatter using the default settings. - - - - - Creates a new formatted with the given settings. - - The settings. - - - - Parses and merges the information into the given message. - - The message to merge the JSON information into. - The JSON to parse. - - - - Parses JSON read from and merges the information into the given message. - - The message to merge the JSON information into. - Reader providing the JSON to parse. - - - - Merges the given message using data from the given tokenizer. In most cases, the next - token should be a "start object" token, but wrapper types and nullity can invalidate - that assumption. This is implemented as an LL(1) recursive descent parser over the stream - of tokens provided by the tokenizer. This token stream is assumed to be valid JSON, with the - tokenizer performing that validation - but not every token stream is valid "protobuf JSON". - - - - - Parses into a new message. - - The type of message to create. - The JSON to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Parses JSON read from into a new message. - - The type of message to create. - Reader providing the JSON to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Parses into a new message. - - The JSON to parse. - Descriptor of message type to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Parses JSON read from into a new message. - - Reader providing the JSON to parse. - Descriptor of message type to parse. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Creates a new instance of the message type for the given field. - - - - - Checks that any infinite/NaN values originated from the correct text. - This corrects the lenient whitespace handling of double.Parse/float.Parse, as well as the - way that Mono parses out-of-range values as infinity. - - - - - Settings controlling JSON parsing. - - - - - Default settings, as used by . This has the same default - recursion limit as , and an empty type registry. - - - - - The maximum depth of messages to parse. Note that this limit only applies to parsing - messages, not collections - so a message within a collection within a message only counts as - depth 2, not 3. - - - - - The type registry used to parse messages. - - - - - Creates a new object with the specified recursion limit. - - The maximum depth of messages to parse - - - - Creates a new object with the specified recursion limit and type registry. - - The maximum depth of messages to parse - The type registry used to parse messages - - - - Simple but strict JSON tokenizer, rigidly following RFC 7159. - - - - This tokenizer is stateful, and only returns "useful" tokens - names, values etc. - It does not create tokens for the separator between names and values, or for the comma - between values. It validates the token stream as it goes - so callers can assume that the - tokens it produces are appropriate. For example, it would never produce "start object, end array." - - Implementation details: the base class handles single token push-back and - Not thread-safe. - - - - - Creates a tokenizer that reads from the given text reader. - - - - - Creates a tokenizer that first replays the given list of tokens, then continues reading - from another tokenizer. Note that if the returned tokenizer is "pushed back", that does not push back - on the continuation tokenizer, or vice versa. Care should be taken when using this method - it was - created for the sake of Any parsing. - - - - - Returns the depth of the stack, purely in objects (not collections). - Informally, this is the number of remaining unclosed '{' characters we have. - - - - - Returns the next JSON token in the stream. An EndDocument token is returned to indicate the end of the stream, - after which point Next() should not be called again. - - This implementation provides single-token buffering, and calls if there is no buffered token. - The next token in the stream. This is never null. - This method is called after an EndDocument token has been returned - The input text does not comply with RFC 7159 - - - - Returns the next JSON token in the stream, when requested by the base class. (The method delegates - to this if it doesn't have a buffered token.) - - This method is called after an EndDocument token has been returned - The input text does not comply with RFC 7159 - - - - Tokenizer which first exhausts a list of tokens, then consults another tokenizer. - - - - - Tokenizer which does all the *real* work of parsing JSON. - - - - - This method essentially just loops through characters skipping whitespace, validating and - changing state (e.g. from ObjectBeforeColon to ObjectAfterColon) - until it reaches something which will be a genuine token (e.g. a start object, or a value) at which point - it returns the token. Although the method is large, it would be relatively hard to break down further... most - of it is the large switch statement, which sometimes returns and sometimes doesn't. - - - - - Reads a string token. It is assumed that the opening " has already been read. - - - - - Reads an escaped character. It is assumed that the leading backslash has already been read. - - - - - Reads an escaped Unicode 4-nybble hex sequence. It is assumed that the leading \u has already been read. - - - - - Consumes a text-only literal, throwing an exception if the read text doesn't match it. - It is assumed that the first letter of the literal has already been read. - - - - - Validates that we're in a valid state to read a value (using the given error prefix if necessary) - and changes the state to the appropriate one, e.g. ObjectAfterColon to ObjectAfterProperty. - - - - - Pops the top-most container, and sets the state to the appropriate one for the end of a value - in the parent container. - - - - - Possible states of the tokenizer. - - - This is a flags enum purely so we can simply and efficiently represent a set of valid states - for checking. - - Each is documented with an example, - where ^ represents the current position within the text stream. The examples all use string values, - but could be any value, including nested objects/arrays. - The complete state of the tokenizer also includes a stack to indicate the contexts (arrays/objects). - Any additional notional state of "AfterValue" indicates that a value has been completed, at which - point there's an immediate transition to ExpectedEndOfDocument, ObjectAfterProperty or ArrayAfterValue. - - - These states were derived manually by reading RFC 7159 carefully. - - - - - - ^ { "foo": "bar" } - Before the value in a document. Next states: ObjectStart, ArrayStart, "AfterValue" - - - - - { "foo": "bar" } ^ - After the value in a document. Next states: ReaderExhausted - - - - - { "foo": "bar" } ^ (and already read to the end of the reader) - Terminal state. - - - - - { ^ "foo": "bar" } - Before the *first* property in an object. - Next states: - "AfterValue" (empty object) - ObjectBeforeColon (read a name) - - - - - { "foo" ^ : "bar", "x": "y" } - Next state: ObjectAfterColon - - - - - { "foo" : ^ "bar", "x": "y" } - Before any property other than the first in an object. - (Equivalently: after any property in an object) - Next states: - "AfterValue" (value is simple) - ObjectStart (value is object) - ArrayStart (value is array) - - - - - { "foo" : "bar" ^ , "x" : "y" } - At the end of a property, so expecting either a comma or end-of-object - Next states: ObjectAfterComma or "AfterValue" - - - - - { "foo":"bar", ^ "x":"y" } - Read the comma after the previous property, so expecting another property. - This is like ObjectStart, but closing brace isn't valid here - Next state: ObjectBeforeColon. - - - - - [ ^ "foo", "bar" ] - Before the *first* value in an array. - Next states: - "AfterValue" (read a value) - "AfterValue" (end of array; will pop stack) - - - - - [ "foo" ^ , "bar" ] - After any value in an array, so expecting either a comma or end-of-array - Next states: ArrayAfterComma or "AfterValue" - - - - - [ "foo", ^ "bar" ] - After a comma in an array, so there *must* be another value (simple or complex). - Next states: "AfterValue" (simple value), StartObject, StartArray - - - - - Wrapper around a text reader allowing small amounts of buffering and location handling. - - - - - The buffered next character, if we have one. - - - - - Returns the next character in the stream, or null if we have reached the end. - - - - - - Creates a new exception appropriate for the current state of the reader. - - - - - Stream implementation which proxies another stream, only allowing a certain amount - of data to be read. Note that this is only used to read delimited streams, so it - doesn't attempt to implement everything. - - - - - Extension methods on and . - - - - - Merges data from the given byte array into an existing message. - - The message to merge the data into. - The data to merge, which must be protobuf-encoded binary data. - - - - Merges data from the given byte string into an existing message. - - The message to merge the data into. - The data to merge, which must be protobuf-encoded binary data. - - - - Merges data from the given stream into an existing message. - - The message to merge the data into. - Stream containing the data to merge, which must be protobuf-encoded binary data. - - - - Merges length-delimited data from the given stream into an existing message. - - - The stream is expected to contain a length and then the data. Only the amount of data - specified by the length will be consumed. - - The message to merge the data into. - Stream containing the data to merge, which must be protobuf-encoded binary data. - - - - Converts the given message into a byte array in protobuf encoding. - - The message to convert. - The message data as a byte array. - - - - Writes the given message data to the given stream in protobuf encoding. - - The message to write to the stream. - The stream to write to. - - - - Writes the length and then data of the given message to a stream. - - The message to write. - The output stream to write to. - - - - Converts the given message into a byte string in protobuf encoding. - - The message to convert. - The message data as a byte string. - - - - A general message parser, typically used by reflection-based code as all the methods - return simple . - - - - - Creates a template instance ready for population. - - An empty message. - - - - Parses a message from a byte array. - - The byte array containing the message. Must not be null. - The newly parsed message. - - - - Parses a message from the given byte string. - - The data to parse. - The parsed message. - - - - Parses a message from the given stream. - - The stream to parse. - The parsed message. - - - - Parses a length-delimited message from the given stream. - - - The stream is expected to contain a length and then the data. Only the amount of data - specified by the length will be consumed. - - The stream to parse. - The parsed message. - - - - Parses a message from the given coded input stream. - - The stream to parse. - The parsed message. - - - - Parses a message from the given JSON. - - The JSON to parse. - The parsed message. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - A parser for a specific message type. - - -

- This delegates most behavior to the - implementation within the original type, but - provides convenient overloads to parse from a variety of sources. -

-

- Most applications will never need to create their own instances of this type; - instead, use the static Parser property of a generated message type to obtain a - parser for that type. -

-
- The type of message to be parsed. -
- - - Creates a new parser. - - - The factory method is effectively an optimization over using a generic constraint - to require a parameterless constructor: delegates are significantly faster to execute. - - Function to invoke when a new, empty message is required. - - - - Creates a template instance ready for population. - - An empty message. - - - - Parses a message from a byte array. - - The byte array containing the message. Must not be null. - The newly parsed message. - - - - Parses a message from the given byte string. - - The data to parse. - The parsed message. - - - - Parses a message from the given stream. - - The stream to parse. - The parsed message. - - - - Parses a length-delimited message from the given stream. - - - The stream is expected to contain a length and then the data. Only the amount of data - specified by the length will be consumed. - - The stream to parse. - The parsed message. - - - - Parses a message from the given coded input stream. - - The stream to parse. - The parsed message. - - - - Parses a message from the given JSON. - - The JSON to parse. - The parsed message. - The JSON does not comply with RFC 7159 - The JSON does not represent a Protocol Buffers message correctly - - - - Helper methods for throwing exceptions when preconditions are not met. - - - This class is used internally and by generated code; it is not particularly - expected to be used from application code, although nothing prevents it - from being used that way. - - - - - Throws an ArgumentNullException if the given value is null, otherwise - return the value to the caller. - - - - - Throws an ArgumentNullException if the given value is null, otherwise - return the value to the caller. - - - This is equivalent to but without the type parameter - constraint. In most cases, the constraint is useful to prevent you from calling CheckNotNull - with a value type - but it gets in the way if either you want to use it with a nullable - value type, or you want to use it with an unconstrained type parameter. - - - - - Container for a set of custom options specified within a message, field etc. - - - - This type is publicly immutable, but internally mutable. It is only populated - by the descriptor parsing code - by the time any user code is able to see an instance, - it will be fully initialized. - - - If an option is requested using the incorrect method, an answer may still be returned: all - of the numeric types are represented internally using 64-bit integers, for example. It is up to - the caller to ensure that they make the appropriate method call for the option they're interested in. - Note that enum options are simply stored as integers, so the value should be fetched using - and then cast appropriately. - - - Repeated options are currently not supported. Asking for a single value of an option - which was actually repeated will return the last value, except for message types where - all the set values are merged together. - - - - - - Singleton for all descriptors with an empty set of options. - - - - - A sequence of values per field. This needs to be per field rather than per tag to allow correct deserialization - of repeated fields which could be "int, ByteString, int" - unlikely as that is. The fact that values are boxed - is unfortunate; we might be able to use a struct instead, and we could combine uint and ulong values. - - - - - Retrieves a Boolean value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 32-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 64-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 32-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 64-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 32-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 64-bit integer value for the specified option field, - assuming a fixed-length representation. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 32-bit integer value for the specified option field, - assuming a zigzag encoding. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a signed 64-bit integer value for the specified option field, - assuming a zigzag encoding. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 32-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves an unsigned 64-bit integer value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a 32-bit floating point value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a 64-bit floating point value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a string value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a bytes value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Retrieves a message value for the specified option field. - - The field to fetch the value for. - The output variable to populate. - true if a suitable value for the field was found; false otherwise. - - - - Reads an unknown field, either parsing it and storing it or skipping it. - - - If the current set of options is empty and we manage to read a field, a new set of options - will be created and returned. Otherwise, the return value is this. This allows - us to start with a singleton empty set of options and just create new ones where necessary. - - Input stream to read from. - The resulting set of custom options, either this or a new set. - - - - All field values can be stored as a byte string or a 64-bit integer. - This struct avoids unnecessary boxing. - - - - Holder for reflection information generated from google/protobuf/descriptor.proto - - - File descriptor for google/protobuf/descriptor.proto - - - - The protocol compiler can output a FileDescriptorSet containing the .proto - files it parses. - - - - Field number for the "file" field. - - - - Describes a complete .proto file. - - - - Field number for the "name" field. - - - - file name, relative to root of source tree - - - - Field number for the "package" field. - - - - e.g. "foo", "foo.bar", etc. - - - - Field number for the "dependency" field. - - - - Names of files imported by this file. - - - - Field number for the "public_dependency" field. - - - - Indexes of the public imported files in the dependency list above. - - - - Field number for the "weak_dependency" field. - - - - Indexes of the weak imported files in the dependency list. - For Google-internal migration only. Do not use. - - - - Field number for the "message_type" field. - - - - All top-level definitions in this file. - - - - Field number for the "enum_type" field. - - - Field number for the "service" field. - - - Field number for the "extension" field. - - - Field number for the "options" field. - - - Field number for the "source_code_info" field. - - - - This field contains optional information about the original source code. - You may safely remove this entire field without harming runtime - functionality of the descriptors -- the information is needed only by - development tools. - - - - Field number for the "syntax" field. - - - - The syntax of the proto file. - The supported values are "proto2" and "proto3". - - - - - Describes a message type. - - - - Field number for the "name" field. - - - Field number for the "field" field. - - - Field number for the "extension" field. - - - Field number for the "nested_type" field. - - - Field number for the "enum_type" field. - - - Field number for the "extension_range" field. - - - Field number for the "oneof_decl" field. - - - Field number for the "options" field. - - - Field number for the "reserved_range" field. - - - Field number for the "reserved_name" field. - - - - Reserved field names, which may not be used by fields in the same message. - A given name may only be reserved once. - - - - Container for nested types declared in the DescriptorProto message type. - - - Field number for the "start" field. - - - Field number for the "end" field. - - - - Range of reserved tag numbers. Reserved tag numbers may not be used by - fields or extension ranges in the same message. Reserved ranges may - not overlap. - - - - Field number for the "start" field. - - - - Inclusive. - - - - Field number for the "end" field. - - - - Exclusive. - - - - - Describes a field within a message. - - - - Field number for the "name" field. - - - Field number for the "number" field. - - - Field number for the "label" field. - - - Field number for the "type" field. - - - - If type_name is set, this need not be set. If both this and type_name - are set, this must be one of TYPE_ENUM, TYPE_MESSAGE or TYPE_GROUP. - - - - Field number for the "type_name" field. - - - - For message and enum types, this is the name of the type. If the name - starts with a '.', it is fully-qualified. Otherwise, C++-like scoping - rules are used to find the type (i.e. first the nested types within this - message are searched, then within the parent, on up to the root - namespace). - - - - Field number for the "extendee" field. - - - - For extensions, this is the name of the type being extended. It is - resolved in the same manner as type_name. - - - - Field number for the "default_value" field. - - - - For numeric types, contains the original text representation of the value. - For booleans, "true" or "false". - For strings, contains the default text contents (not escaped in any way). - For bytes, contains the C escaped value. All bytes >= 128 are escaped. - TODO(kenton): Base-64 encode? - - - - Field number for the "oneof_index" field. - - - - If set, gives the index of a oneof in the containing type's oneof_decl - list. This field is a member of that oneof. - - - - Field number for the "json_name" field. - - - - JSON name of this field. The value is set by protocol compiler. If the - user has set a "json_name" option on this field, that option's value - will be used. Otherwise, it's deduced from the field's name by converting - it to camelCase. - - - - Field number for the "options" field. - - - Container for nested types declared in the FieldDescriptorProto message type. - - - - 0 is reserved for errors. - Order is weird for historical reasons. - - - - - Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT64 if - negative values are likely. - - - - - Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT32 if - negative values are likely. - - - - - Tag-delimited aggregate. - Group type is deprecated and not supported in proto3. However, Proto3 - implementations should still be able to parse the group wire format and - treat group fields as unknown fields. - - - - - Length-delimited aggregate. - - - - - New in version 2. - - - - - Uses ZigZag encoding. - - - - - Uses ZigZag encoding. - - - - - 0 is reserved for errors - - - - - Describes a oneof. - - - - Field number for the "name" field. - - - Field number for the "options" field. - - - - Describes an enum type. - - - - Field number for the "name" field. - - - Field number for the "value" field. - - - Field number for the "options" field. - - - - Describes a value within an enum. - - - - Field number for the "name" field. - - - Field number for the "number" field. - - - Field number for the "options" field. - - - - Describes a service. - - - - Field number for the "name" field. - - - Field number for the "method" field. - - - Field number for the "options" field. - - - - Describes a method of a service. - - - - Field number for the "name" field. - - - Field number for the "input_type" field. - - - - Input and output type names. These are resolved in the same way as - FieldDescriptorProto.type_name, but must refer to a message type. - - - - Field number for the "output_type" field. - - - Field number for the "options" field. - - - Field number for the "client_streaming" field. - - - - Identifies if client streams multiple client messages - - - - Field number for the "server_streaming" field. - - - - Identifies if server streams multiple server messages - - - - Field number for the "java_package" field. - - - - Sets the Java package where classes generated from this .proto will be - placed. By default, the proto package is used, but this is often - inappropriate because proto packages do not normally start with backwards - domain names. - - - - Field number for the "java_outer_classname" field. - - - - If set, all the classes from the .proto file are wrapped in a single - outer class with the given name. This applies to both Proto1 - (equivalent to the old "--one_java_file" option) and Proto2 (where - a .proto always translates to a single class, but you may want to - explicitly choose the class name). - - - - Field number for the "java_multiple_files" field. - - - - If set true, then the Java code generator will generate a separate .java - file for each top-level message, enum, and service defined in the .proto - file. Thus, these types will *not* be nested inside the outer class - named by java_outer_classname. However, the outer class will still be - generated to contain the file's getDescriptor() method as well as any - top-level extensions defined in the file. - - - - Field number for the "java_generate_equals_and_hash" field. - - - - This option does nothing. - - - - Field number for the "java_string_check_utf8" field. - - - - If set true, then the Java2 code generator will generate code that - throws an exception whenever an attempt is made to assign a non-UTF-8 - byte sequence to a string field. - Message reflection will do the same. - However, an extension field still accepts non-UTF-8 byte sequences. - This option has no effect on when used with the lite runtime. - - - - Field number for the "optimize_for" field. - - - Field number for the "go_package" field. - - - - Sets the Go package where structs generated from this .proto will be - placed. If omitted, the Go package will be derived from the following: - - The basename of the package import path, if provided. - - Otherwise, the package statement in the .proto file, if present. - - Otherwise, the basename of the .proto file, without extension. - - - - Field number for the "cc_generic_services" field. - - - - Should generic services be generated in each language? "Generic" services - are not specific to any particular RPC system. They are generated by the - main code generators in each language (without additional plugins). - Generic services were the only kind of service generation supported by - early versions of google.protobuf. - - Generic services are now considered deprecated in favor of using plugins - that generate code specific to your particular RPC system. Therefore, - these default to false. Old code which depends on generic services should - explicitly set them to true. - - - - Field number for the "java_generic_services" field. - - - Field number for the "py_generic_services" field. - - - Field number for the "deprecated" field. - - - - Is this file deprecated? - Depending on the target platform, this can emit Deprecated annotations - for everything in the file, or it will be completely ignored; in the very - least, this is a formalization for deprecating files. - - - - Field number for the "cc_enable_arenas" field. - - - - Enables the use of arenas for the proto messages in this file. This applies - only to generated classes for C++. - - - - Field number for the "objc_class_prefix" field. - - - - Sets the objective c class prefix which is prepended to all objective c - generated classes from this .proto. There is no default. - - - - Field number for the "csharp_namespace" field. - - - - Namespace for generated classes; defaults to the package. - - - - Field number for the "swift_prefix" field. - - - - By default Swift generators will take the proto package and CamelCase it - replacing '.' with underscore and use that to prefix the types/symbols - defined. When this options is provided, they will use this value instead - to prefix the types/symbols defined. - - - - Field number for the "php_class_prefix" field. - - - - Sets the php class prefix which is prepended to all php generated classes - from this .proto. Default is empty. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Container for nested types declared in the FileOptions message type. - - - - Generated classes can be optimized for speed or code size. - - - - - Generate complete code for parsing, serialization, - - - - - etc. - - - - - Generate code using MessageLite and the lite runtime. - - - - Field number for the "message_set_wire_format" field. - - - - Set true to use the old proto1 MessageSet wire format for extensions. - This is provided for backwards-compatibility with the MessageSet wire - format. You should not use this for any other reason: It's less - efficient, has fewer features, and is more complicated. - - The message must be defined exactly as follows: - message Foo { - option message_set_wire_format = true; - extensions 4 to max; - } - Note that the message cannot have any defined fields; MessageSets only - have extensions. - - All extensions of your type must be singular messages; e.g. they cannot - be int32s, enums, or repeated messages. - - Because this is an option, the above two restrictions are not enforced by - the protocol compiler. - - - - Field number for the "no_standard_descriptor_accessor" field. - - - - Disables the generation of the standard "descriptor()" accessor, which can - conflict with a field of the same name. This is meant to make migration - from proto1 easier; new code should avoid fields named "descriptor". - - - - Field number for the "deprecated" field. - - - - Is this message deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the message, or it will be completely ignored; in the very least, - this is a formalization for deprecating messages. - - - - Field number for the "map_entry" field. - - - - Whether the message is an automatically generated map entry type for the - maps field. - - For maps fields: - map<KeyType, ValueType> map_field = 1; - The parsed descriptor looks like: - message MapFieldEntry { - option map_entry = true; - optional KeyType key = 1; - optional ValueType value = 2; - } - repeated MapFieldEntry map_field = 1; - - Implementations may choose not to generate the map_entry=true message, but - use a native map in the target language to hold the keys and values. - The reflection APIs in such implementions still need to work as - if the field is a repeated message field. - - NOTE: Do not set the option in .proto files. Always use the maps syntax - instead. The option should only be implicitly set by the proto compiler - parser. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "ctype" field. - - - - The ctype option instructs the C++ code generator to use a different - representation of the field than it normally would. See the specific - options below. This option is not yet implemented in the open source - release -- sorry, we'll try to include it in a future version! - - - - Field number for the "packed" field. - - - - The packed option can be enabled for repeated primitive fields to enable - a more efficient representation on the wire. Rather than repeatedly - writing the tag and type for each element, the entire array is encoded as - a single length-delimited blob. In proto3, only explicit setting it to - false will avoid using packed encoding. - - - - Field number for the "jstype" field. - - - - The jstype option determines the JavaScript type used for values of the - field. The option is permitted only for 64 bit integral and fixed types - (int64, uint64, sint64, fixed64, sfixed64). By default these types are - represented as JavaScript strings. This avoids loss of precision that can - happen when a large value is converted to a floating point JavaScript - numbers. Specifying JS_NUMBER for the jstype causes the generated - JavaScript code to use the JavaScript "number" type instead of strings. - This option is an enum to permit additional types to be added, - e.g. goog.math.Integer. - - - - Field number for the "lazy" field. - - - - Should this field be parsed lazily? Lazy applies only to message-type - fields. It means that when the outer message is initially parsed, the - inner message's contents will not be parsed but instead stored in encoded - form. The inner message will actually be parsed when it is first accessed. - - This is only a hint. Implementations are free to choose whether to use - eager or lazy parsing regardless of the value of this option. However, - setting this option true suggests that the protocol author believes that - using lazy parsing on this field is worth the additional bookkeeping - overhead typically needed to implement it. - - This option does not affect the public interface of any generated code; - all method signatures remain the same. Furthermore, thread-safety of the - interface is not affected by this option; const methods remain safe to - call from multiple threads concurrently, while non-const methods continue - to require exclusive access. - - Note that implementations may choose not to check required fields within - a lazy sub-message. That is, calling IsInitialized() on the outer message - may return true even if the inner message has missing required fields. - This is necessary because otherwise the inner message would have to be - parsed in order to perform the check, defeating the purpose of lazy - parsing. An implementation which chooses not to check required fields - must be consistent about it. That is, for any particular sub-message, the - implementation must either *always* check its required fields, or *never* - check its required fields, regardless of whether or not the message has - been parsed. - - - - Field number for the "deprecated" field. - - - - Is this field deprecated? - Depending on the target platform, this can emit Deprecated annotations - for accessors, or it will be completely ignored; in the very least, this - is a formalization for deprecating fields. - - - - Field number for the "weak" field. - - - - For Google-internal migration only. Do not use. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Container for nested types declared in the FieldOptions message type. - - - - Default mode. - - - - - Use the default type. - - - - - Use JavaScript strings. - - - - - Use JavaScript numbers. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "allow_alias" field. - - - - Set this option to true to allow mapping different tag names to the same - value. - - - - Field number for the "deprecated" field. - - - - Is this enum deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the enum, or it will be completely ignored; in the very least, this - is a formalization for deprecating enums. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "deprecated" field. - - - - Is this enum value deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the enum value, or it will be completely ignored; in the very least, - this is a formalization for deprecating enum values. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "deprecated" field. - - - - Is this service deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the service, or it will be completely ignored; in the very least, - this is a formalization for deprecating services. - - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Field number for the "deprecated" field. - - - - Is this method deprecated? - Depending on the target platform, this can emit Deprecated annotations - for the method, or it will be completely ignored; in the very least, - this is a formalization for deprecating methods. - - - - Field number for the "idempotency_level" field. - - - Field number for the "uninterpreted_option" field. - - - - The parser stores options it doesn't recognize here. See above. - - - - Container for nested types declared in the MethodOptions message type. - - - - Is this method side-effect-free (or safe in HTTP parlance), or idempotent, - or neither? HTTP based RPC implementation may choose GET verb for safe - methods, and PUT verb for idempotent methods instead of the default POST. - - - - - implies idempotent - - - - - idempotent, but may have side effects - - - - - A message representing a option the parser does not recognize. This only - appears in options protos created by the compiler::Parser class. - DescriptorPool resolves these when building Descriptor objects. Therefore, - options protos in descriptor objects (e.g. returned by Descriptor::options(), - or produced by Descriptor::CopyTo()) will never have UninterpretedOptions - in them. - - - - Field number for the "name" field. - - - Field number for the "identifier_value" field. - - - - The value of the uninterpreted option, in whatever type the tokenizer - identified it as during parsing. Exactly one of these should be set. - - - - Field number for the "positive_int_value" field. - - - Field number for the "negative_int_value" field. - - - Field number for the "double_value" field. - - - Field number for the "string_value" field. - - - Field number for the "aggregate_value" field. - - - Container for nested types declared in the UninterpretedOption message type. - - - - The name of the uninterpreted option. Each string represents a segment in - a dot-separated name. is_extension is true iff a segment represents an - extension (denoted with parentheses in options specs in .proto files). - E.g.,{ ["foo", false], ["bar.baz", true], ["qux", false] } represents - "foo.(bar.baz).qux". - - - - Field number for the "name_part" field. - - - Field number for the "is_extension" field. - - - - Encapsulates information about the original source file from which a - FileDescriptorProto was generated. - - - - Field number for the "location" field. - - - - A Location identifies a piece of source code in a .proto file which - corresponds to a particular definition. This information is intended - to be useful to IDEs, code indexers, documentation generators, and similar - tools. - - For example, say we have a file like: - message Foo { - optional string foo = 1; - } - Let's look at just the field definition: - optional string foo = 1; - ^ ^^ ^^ ^ ^^^ - a bc de f ghi - We have the following locations: - span path represents - [a,i) [ 4, 0, 2, 0 ] The whole field definition. - [a,b) [ 4, 0, 2, 0, 4 ] The label (optional). - [c,d) [ 4, 0, 2, 0, 5 ] The type (string). - [e,f) [ 4, 0, 2, 0, 1 ] The name (foo). - [g,h) [ 4, 0, 2, 0, 3 ] The number (1). - - Notes: - - A location may refer to a repeated field itself (i.e. not to any - particular index within it). This is used whenever a set of elements are - logically enclosed in a single code segment. For example, an entire - extend block (possibly containing multiple extension definitions) will - have an outer location whose path refers to the "extensions" repeated - field without an index. - - Multiple locations may have the same path. This happens when a single - logical declaration is spread out across multiple places. The most - obvious example is the "extend" block again -- there may be multiple - extend blocks in the same scope, each of which will have the same path. - - A location's span is not always a subset of its parent's span. For - example, the "extendee" of an extension declaration appears at the - beginning of the "extend" block and is shared by all extensions within - the block. - - Just because a location's span is a subset of some other location's span - does not mean that it is a descendent. For example, a "group" defines - both a type and a field in a single declaration. Thus, the locations - corresponding to the type and field and their components will overlap. - - Code which tries to interpret locations should probably be designed to - ignore those that it doesn't understand, as more types of locations could - be recorded in the future. - - - - Container for nested types declared in the SourceCodeInfo message type. - - - Field number for the "path" field. - - - - Identifies which part of the FileDescriptorProto was defined at this - location. - - Each element is a field number or an index. They form a path from - the root FileDescriptorProto to the place where the definition. For - example, this path: - [ 4, 3, 2, 7, 1 ] - refers to: - file.message_type(3) // 4, 3 - .field(7) // 2, 7 - .name() // 1 - This is because FileDescriptorProto.message_type has field number 4: - repeated DescriptorProto message_type = 4; - and DescriptorProto.field has field number 2: - repeated FieldDescriptorProto field = 2; - and FieldDescriptorProto.name has field number 1: - optional string name = 1; - - Thus, the above path gives the location of a field name. If we removed - the last element: - [ 4, 3, 2, 7 ] - this path refers to the whole field declaration (from the beginning - of the label to the terminating semicolon). - - - - Field number for the "span" field. - - - - Always has exactly three or four elements: start line, start column, - end line (optional, otherwise assumed same as start line), end column. - These are packed into a single field for efficiency. Note that line - and column numbers are zero-based -- typically you will want to add - 1 to each before displaying to a user. - - - - Field number for the "leading_comments" field. - - - - If this SourceCodeInfo represents a complete declaration, these are any - comments appearing before and after the declaration which appear to be - attached to the declaration. - - A series of line comments appearing on consecutive lines, with no other - tokens appearing on those lines, will be treated as a single comment. - - leading_detached_comments will keep paragraphs of comments that appear - before (but not connected to) the current element. Each paragraph, - separated by empty lines, will be one comment element in the repeated - field. - - Only the comment content is provided; comment markers (e.g. //) are - stripped out. For block comments, leading whitespace and an asterisk - will be stripped from the beginning of each line other than the first. - Newlines are included in the output. - - Examples: - - optional int32 foo = 1; // Comment attached to foo. - // Comment attached to bar. - optional int32 bar = 2; - - optional string baz = 3; - // Comment attached to baz. - // Another line attached to baz. - - // Comment attached to qux. - // - // Another line attached to qux. - optional double qux = 4; - - // Detached comment for corge. This is not leading or trailing comments - // to qux or corge because there are blank lines separating it from - // both. - - // Detached comment for corge paragraph 2. - - optional string corge = 5; - /* Block comment attached - * to corge. Leading asterisks - * will be removed. */ - /* Block comment attached to - * grault. */ - optional int32 grault = 6; - - // ignored detached comments. - - - - Field number for the "trailing_comments" field. - - - Field number for the "leading_detached_comments" field. - - - - Describes the relationship between generated code and its original source - file. A GeneratedCodeInfo message is associated with only one generated - source file, but may contain references to different source .proto files. - - - - Field number for the "annotation" field. - - - - An Annotation connects some span of text in generated code to an element - of its generating .proto file. - - - - Container for nested types declared in the GeneratedCodeInfo message type. - - - Field number for the "path" field. - - - - Identifies the element in the original source .proto file. This field - is formatted the same as SourceCodeInfo.Location.path. - - - - Field number for the "source_file" field. - - - - Identifies the filesystem path to the original source .proto. - - - - Field number for the "begin" field. - - - - Identifies the starting offset in bytes in the generated code - that relates to the identified object. - - - - Field number for the "end" field. - - - - Identifies the ending offset in bytes in the generated code that - relates to the identified offset. The end offset should be one past - the last relevant byte (so the length of the text = end - begin). - - - - - Base class for nearly all descriptors, providing common functionality. - - - - - The index of this descriptor within its parent descriptor. - - - This returns the index of this descriptor within its parent, for - this descriptor's type. (There can be duplicate values for different - types, e.g. one enum type with index 0 and one message type with index 0.) - - - - - Returns the name of the entity (field, message etc) being described. - - - - - The fully qualified name of the descriptor's target. - - - - - The file this descriptor was declared in. - - - - - Contains lookup tables containing all the descriptors defined in a particular file. - - - - - Finds a symbol of the given name within the pool. - - The type of symbol to look for - Fully-qualified name to look up - The symbol with the given name and type, - or null if the symbol doesn't exist or has the wrong type - - - - Adds a package to the symbol tables. If a package by the same name - already exists, that is fine, but if some other kind of symbol - exists under the same name, an exception is thrown. If the package - has multiple components, this also adds the parent package(s). - - - - - Adds a symbol to the symbol table. - - The symbol already existed - in the symbol table. - - - - Verifies that the descriptor's name is valid (i.e. it contains - only letters, digits and underscores, and does not start with a digit). - - - - - - Returns the field with the given number in the given descriptor, - or null if it can't be found. - - - - - Adds a field to the fieldsByNumber table. - - A field with the same - containing type and number already exists. - - - - Adds an enum value to the enumValuesByNumber table. If an enum value - with the same type and number already exists, this method does nothing. - (This is allowed; the first value defined with the number takes precedence.) - - - - - Looks up a descriptor by name, relative to some other descriptor. - The name may be fully-qualified (with a leading '.'), partially-qualified, - or unqualified. C++-like name lookup semantics are used to search for the - matching descriptor. - - - This isn't heavily optimized, but it's only used during cross linking anyway. - If it starts being used more widely, we should look at performance more carefully. - - - - - Struct used to hold the keys for the fieldByNumber table. - - - - - Internal class containing utility methods when working with descriptors. - - - - - Equivalent to Func[TInput, int, TOutput] but usable in .NET 2.0. Only used to convert - arrays. - - - - - Converts the given array into a read-only list, applying the specified conversion to - each input element. - - - - - Thrown when building descriptors fails because the source DescriptorProtos - are not valid. - - - - - The full name of the descriptor where the error occurred. - - - - - A human-readable description of the error. (The Message property - is made up of the descriptor's name and this description.) - - - - - Descriptor for an enum type in a .proto file. - - - - - The brief name of the descriptor's target. - - - - - The CLR type for this enum. For generated code, this will be a CLR enum type. - - - - - If this is a nested type, get the outer descriptor, otherwise null. - - - - - An unmodifiable list of defined value descriptors for this enum. - - - - - Finds an enum value by number. If multiple enum values have the - same number, this returns the first defined value with that number. - If there is no value for the given number, this returns null. - - - - - Finds an enum value by name. - - The unqualified name of the value (e.g. "FOO"). - The value's descriptor, or null if not found. - - - - The (possibly empty) set of custom options for this enum. - - - - - Descriptor for a single enum value within an enum in a .proto file. - - - - - Returns the name of the enum value described by this object. - - - - - Returns the number associated with this enum value. - - - - - Returns the enum descriptor that this value is part of. - - - - - The (possibly empty) set of custom options for this enum value. - - - - - Base class for field accessors. - - - - - Descriptor for a field or extension within a message in a .proto file. - - - - - Get the field's containing message type. - - - - - Returns the oneof containing this field, or null if it is not part of a oneof. - - - - - The effective JSON name for this field. This is usually the lower-camel-cased form of the field name, - but can be overridden using the json_name option in the .proto file. - - - - - The brief name of the descriptor's target. - - - - - Returns the accessor for this field. - - - - While a describes the field, it does not provide - any way of obtaining or changing the value of the field within a specific message; - that is the responsibility of the accessor. - - - The value returned by this property will be non-null for all regular fields. However, - if a message containing a map field is introspected, the list of nested messages will include - an auto-generated nested key/value pair message for the field. This is not represented in any - generated type, and the value of the map field itself is represented by a dictionary in the - reflection API. There are never instances of those "hidden" messages, so no accessor is provided - and this property will return null. - - - - - - Maps a field type as included in the .proto file to a FieldType. - - - - - Returns true if this field is a repeated field; false otherwise. - - - - - Returns true if this field is a map field; false otherwise. - - - - - Returns true if this field is a packed, repeated field; false otherwise. - - - - - Returns the type of the field. - - - - - Returns the field number declared in the proto file. - - - - - Compares this descriptor with another one, ordering in "canonical" order - which simply means ascending order by field number. - must be a field of the same type, i.e. the of - both fields must be the same. - - - - - For enum fields, returns the field's type. - - - - - For embedded message and group fields, returns the field's type. - - - - - The (possibly empty) set of custom options for this field. - - - - - Look up and cross-link all field types etc. - - - - - Enumeration of all the possible field types. - - - - - The double field type. - - - - - The float field type. - - - - - The int64 field type. - - - - - The uint64 field type. - - - - - The int32 field type. - - - - - The fixed64 field type. - - - - - The fixed32 field type. - - - - - The bool field type. - - - - - The string field type. - - - - - The field type used for groups (not supported in this implementation). - - - - - The field type used for message fields. - - - - - The bytes field type. - - - - - The uint32 field type. - - - - - The sfixed32 field type. - - - - - The sfixed64 field type. - - - - - The sint32 field type. - - - - - The sint64 field type. - - - - - The field type used for enum fields. - - - - - Describes a .proto file, including everything defined within. - IDescriptor is implemented such that the File property returns this descriptor, - and the FullName is the same as the Name. - - - - - Computes the full name of a descriptor within this file, with an optional parent message. - - - - - Extracts public dependencies from direct dependencies. This is a static method despite its - first parameter, as the value we're in the middle of constructing is only used for exceptions. - - - - - The descriptor in its protocol message representation. - - - - - The file name. - - - - - The package as declared in the .proto file. This may or may not - be equivalent to the .NET namespace of the generated classes. - - - - - Unmodifiable list of top-level message types declared in this file. - - - - - Unmodifiable list of top-level enum types declared in this file. - - - - - Unmodifiable list of top-level services declared in this file. - - - - - Unmodifiable list of this file's dependencies (imports). - - - - - Unmodifiable list of this file's public dependencies (public imports). - - - - - The original serialized binary form of this descriptor. - - - - - Implementation of IDescriptor.FullName - just returns the same as Name. - - - - - Implementation of IDescriptor.File - just returns this descriptor. - - - - - Pool containing symbol descriptors. - - - - - Finds a type (message, enum, service or extension) in the file by name. Does not find nested types. - - The unqualified type name to look for. - The type of descriptor to look for - The type's descriptor, or null if not found. - - - - Builds a FileDescriptor from its protocol buffer representation. - - The original serialized descriptor data. - We have only limited proto2 support, so serializing FileDescriptorProto - would not necessarily give us this. - The protocol message form of the FileDescriptor. - FileDescriptors corresponding to all of the - file's dependencies, in the exact order listed in the .proto file. May be null, - in which case it is treated as an empty array. - Whether unknown dependencies are ignored (true) or cause an exception to be thrown (false). - Details about generated code, for the purposes of reflection. - If is not - a valid descriptor. This can occur for a number of reasons, such as a field - having an undefined type or because two messages were defined with the same name. - - - - Creates a descriptor for generated code. - - - This method is only designed to be used by the results of generating code with protoc, - which creates the appropriate dependencies etc. It has to be public because the generated - code is "external", but should not be called directly by end users. - - - - - Returns a that represents this instance. - - - A that represents this instance. - - - - - Returns the file descriptor for descriptor.proto. - - - This is used for protos which take a direct dependency on descriptor.proto, typically for - annotations. While descriptor.proto is a proto2 file, it is built into the Google.Protobuf - runtime for reflection purposes. The messages are internal to the runtime as they would require - proto2 semantics for full support, but the file descriptor is available via this property. The - C# codegen in protoc automatically uses this property when it detects a dependency on descriptor.proto. - - - The file descriptor for descriptor.proto. - - - - - The (possibly empty) set of custom options for this file. - - - - - Extra information provided by generated code when initializing a message or file descriptor. - These are constructed as required, and are not long-lived. Hand-written code should - never need to use this type. - - - - - Irrelevant for file descriptors; the CLR type for the message for message descriptors. - - - - - Irrelevant for file descriptors; the parser for message descriptors. - - - - - Irrelevant for file descriptors; the CLR property names (in message descriptor field order) - for fields in the message for message descriptors. - - - - - Irrelevant for file descriptors; the CLR property "base" names (in message descriptor oneof order) - for oneofs in the message for message descriptors. It is expected that for a oneof name of "Foo", - there will be a "FooCase" property and a "ClearFoo" method. - - - - - The reflection information for types within this file/message descriptor. Elements may be null - if there is no corresponding generated type, e.g. for map entry types. - - - - - The CLR types for enums within this file/message descriptor. - - - - - Creates a GeneratedClrTypeInfo for a message descriptor, with nested types, nested enums, the CLR type, property names and oneof names. - Each array parameter may be null, to indicate a lack of values. - The parameter order is designed to make it feasible to format the generated code readably. - - - - - Creates a GeneratedClrTypeInfo for a file descriptor, with only types and enums. - - - - - Interface implemented by all descriptor types. - - - - - Returns the name of the entity (message, field etc) being described. - - - - - Returns the fully-qualified name of the entity being described. - - - - - Returns the descriptor for the .proto file that this entity is part of. - - - - - Allows fields to be reflectively accessed. - - - - - Returns the descriptor associated with this field. - - - - - Clears the field in the specified message. (For repeated fields, - this clears the list.) - - - - - Fetches the field value. For repeated values, this will be an - implementation. For map values, this will be an - implementation. - - - - - Mutator for single "simple" fields only. - - - Repeated fields are mutated by fetching the value and manipulating it as a list. - Map fields are mutated by fetching the value and manipulating it as a dictionary. - - The field is not a "simple" field. - - - - Accessor for map fields. - - - - - Describes a message type. - - - - - The brief name of the descriptor's target. - - - - - The CLR type used to represent message instances from this descriptor. - - - - The value returned by this property will be non-null for all regular fields. However, - if a message containing a map field is introspected, the list of nested messages will include - an auto-generated nested key/value pair message for the field. This is not represented in any - generated type, so this property will return null in such cases. - - - For wrapper types ( and the like), the type returned here - will be the generated message type, not the native type used by reflection for fields of those types. Code - using reflection should call to determine whether a message descriptor represents - a wrapper type, and handle the result appropriately. - - - - - - A parser for this message type. - - - - As is not generic, this cannot be statically - typed to the relevant type, but it should produce objects of a type compatible with . - - - The value returned by this property will be non-null for all regular fields. However, - if a message containing a map field is introspected, the list of nested messages will include - an auto-generated nested key/value pair message for the field. No message parser object is created for - such messages, so this property will return null in such cases. - - - For wrapper types ( and the like), the parser returned here - will be the generated message type, not the native type used by reflection for fields of those types. Code - using reflection should call to determine whether a message descriptor represents - a wrapper type, and handle the result appropriately. - - - - - - Returns whether this message is one of the "well known types" which may have runtime/protoc support. - - - - - Returns whether this message is one of the "wrapper types" used for fields which represent primitive values - with the addition of presence. - - - - - If this is a nested type, get the outer descriptor, otherwise null. - - - - - A collection of fields, which can be retrieved by name or field number. - - - - - An unmodifiable list of this message type's nested types. - - - - - An unmodifiable list of this message type's enum types. - - - - - An unmodifiable list of the "oneof" field collections in this message type. - - - - - Finds a field by field name. - - The unqualified name of the field (e.g. "foo"). - The field's descriptor, or null if not found. - - - - Finds a field by field number. - - The field number within this message type. - The field's descriptor, or null if not found. - - - - Finds a nested descriptor by name. The is valid for fields, nested - message types, oneofs and enums. - - The unqualified name of the descriptor, e.g. "Foo" - The descriptor, or null if not found. - - - - The (possibly empty) set of custom options for this message. - - - - - Looks up and cross-links all fields and nested types. - - - - - A collection to simplify retrieving the field accessor for a particular field. - - - - - Returns the fields in the message as an immutable list, in the order in which they - are declared in the source .proto file. - - - - - Returns the fields in the message as an immutable list, in ascending field number - order. Field numbers need not be contiguous, so there is no direct mapping from the - index in the list to the field number; to retrieve a field by field number, it is better - to use the indexer. - - - - - Returns a read-only dictionary mapping the field names in this message as they're available - in the JSON representation to the field descriptors. For example, a field foo_bar - in the message would result two entries, one with a key fooBar and one with a key - foo_bar, both referring to the same field. - - - - - Retrieves the descriptor for the field with the given number. - - Number of the field to retrieve the descriptor for - The accessor for the given field - The message descriptor does not contain a field - with the given number - - - - Retrieves the descriptor for the field with the given name. - - Name of the field to retrieve the descriptor for - The descriptor for the given field - The message descriptor does not contain a field - with the given name - - - - Describes a single method in a service. - - - - - The service this method belongs to. - - - - - The method's input type. - - - - - The method's input type. - - - - - Indicates if client streams multiple requests. - - - - - Indicates if server streams multiple responses. - - - - - The (possibly empty) set of custom options for this method. - - - - - The brief name of the descriptor's target. - - - - - Reflection access for a oneof, allowing clear and "get case" actions. - - - - - Gets the descriptor for this oneof. - - - The descriptor of the oneof. - - - - - Clears the oneof in the specified message. - - - - - Indicates which field in the oneof is set for specified message - - - - - Describes a "oneof" field collection in a message type: a set of - fields of which at most one can be set in any particular message. - - - - - The brief name of the descriptor's target. - - - - - Gets the message type containing this oneof. - - - The message type containing this oneof. - - - - - Gets the fields within this oneof, in declaration order. - - - The fields within this oneof, in declaration order. - - - - - Gets an accessor for reflective access to the values associated with the oneof - in a particular message. - - - The accessor used for reflective access. - - - - - The (possibly empty) set of custom options for this oneof. - - - - - Specifies the original name (in the .proto file) of a named element, - such as an enum value. - - - - - The name of the element in the .proto file. - - - - - If the name is preferred in the .proto file. - - - - - Constructs a new attribute instance for the given name. - - The name of the element in the .proto file. - - - - Represents a package in the symbol table. We use PackageDescriptors - just as placeholders so that someone cannot define, say, a message type - that has the same name as an existing package. - - - - - The methods in this class are somewhat evil, and should not be tampered with lightly. - Basically they allow the creation of relatively weakly typed delegates from MethodInfos - which are more strongly typed. They do this by creating an appropriate strongly typed - delegate from the MethodInfo, and then calling that within an anonymous method. - Mind-bending stuff (at least to your humble narrator) but the resulting delegates are - very fast compared with calling Invoke later on. - - - - - Empty Type[] used when calling GetProperty to force property instead of indexer fetching. - - - - - Creates a delegate which will cast the argument to the appropriate method target type, - call the method on it, then convert the result to object. - - - - - Creates a delegate which will cast the argument to the appropriate method target type, - call the method on it, then convert the result to the specified type. - - - - - Creates a delegate which will execute the given method after casting the first argument to - the target type of the method, and the second argument to the first parameter type of the method. - - - - - Creates a delegate which will execute the given method after casting the first argument to - the target type of the method. - - - - - Accessor for repeated fields. - - - - - Describes a service type. - - - - - The brief name of the descriptor's target. - - - - - An unmodifiable list of methods in this service. - - - - - Finds a method by name. - - The unqualified name of the method (e.g. "Foo"). - The method's decsriptor, or null if not found. - - - - The (possibly empty) set of custom options for this service. - - - - - Accessor for single fields. - - - - - An immutable registry of types which can be looked up by their full name. - - - - - An empty type registry, containing no types. - - - - - Attempts to find a message descriptor by its full name. - - The full name of the message, which is the dot-separated - combination of package, containing messages and message name - The message descriptor corresponding to or null - if there is no such message descriptor. - - - - Creates a type registry from the specified set of file descriptors. - - - This is a convenience overload for - to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). - - The set of files to include in the registry. Must not contain null values. - A type registry for the given files. - - - - Creates a type registry from the specified set of file descriptors. - - - All message types within all the specified files are added to the registry, and - the dependencies of the specified files are also added, recursively. - - The set of files to include in the registry. Must not contain null values. - A type registry for the given files. - - - - Creates a type registry from the file descriptor parents of the specified set of message descriptors. - - - This is a convenience overload for - to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). - - The set of message descriptors to use to identify file descriptors to include in the registry. - Must not contain null values. - A type registry for the given files. - - - - Creates a type registry from the file descriptor parents of the specified set of message descriptors. - - - The specified message descriptors are only used to identify their file descriptors; the returned registry - contains all the types within the file descriptors which contain the specified message descriptors (and - the dependencies of those files), not just the specified messages. - - The set of message descriptors to use to identify file descriptors to include in the registry. - Must not contain null values. - A type registry for the given files. - - - - Builder class which isn't exposed, but acts as a convenient alternative to passing round two dictionaries in recursive calls. - - - - Holder for reflection information generated from google/protobuf/any.proto - - - File descriptor for google/protobuf/any.proto - - - - `Any` contains an arbitrary serialized protocol buffer message along with a - URL that describes the type of the serialized message. - - Protobuf library provides support to pack/unpack Any values in the form - of utility functions or additional generated methods of the Any type. - - Example 1: Pack and unpack a message in C++. - - Foo foo = ...; - Any any; - any.PackFrom(foo); - ... - if (any.UnpackTo(&foo)) { - ... - } - - Example 2: Pack and unpack a message in Java. - - Foo foo = ...; - Any any = Any.pack(foo); - ... - if (any.is(Foo.class)) { - foo = any.unpack(Foo.class); - } - - Example 3: Pack and unpack a message in Python. - - foo = Foo(...) - any = Any() - any.Pack(foo) - ... - if any.Is(Foo.DESCRIPTOR): - any.Unpack(foo) - ... - - The pack methods provided by protobuf library will by default use - 'type.googleapis.com/full.type.name' as the type URL and the unpack - methods only use the fully qualified type name after the last '/' - in the type URL, for example "foo.bar.com/x/y.z" will yield type - name "y.z". - - JSON - ==== - The JSON representation of an `Any` value uses the regular - representation of the deserialized, embedded message, with an - additional field `@type` which contains the type URL. Example: - - package google.profile; - message Person { - string first_name = 1; - string last_name = 2; - } - - { - "@type": "type.googleapis.com/google.profile.Person", - "firstName": <string>, - "lastName": <string> - } - - If the embedded message type is well-known and has a custom JSON - representation, that representation will be embedded adding a field - `value` which holds the custom JSON in addition to the `@type` - field. Example (for message [google.protobuf.Duration][]): - - { - "@type": "type.googleapis.com/google.protobuf.Duration", - "value": "1.212s" - } - - - - Field number for the "type_url" field. - - - - A URL/resource name whose content describes the type of the - serialized protocol buffer message. - - For URLs which use the scheme `http`, `https`, or no scheme, the - following restrictions and interpretations apply: - - * If no scheme is provided, `https` is assumed. - * The last segment of the URL's path must represent the fully - qualified name of the type (as in `path/google.protobuf.Duration`). - The name should be in a canonical form (e.g., leading "." is - not accepted). - * An HTTP GET on the URL must yield a [google.protobuf.Type][] - value in binary format, or produce an error. - * Applications are allowed to cache lookup results based on the - URL, or have them precompiled into a binary to avoid any - lookup. Therefore, binary compatibility needs to be preserved - on changes to types. (Use versioned type names to manage - breaking changes.) - - Schemes other than `http`, `https` (or the empty scheme) might be - used with implementation specific semantics. - - - - Field number for the "value" field. - - - - Must be a valid serialized protocol buffer of the above specified type. - - - - - Retrieves the type name for a type URL. This is always just the last part of the URL, - after the trailing slash. No validation of anything before the trailing slash is performed. - If the type URL does not include a slash, an empty string is returned rather than an exception - being thrown; this won't match any types, and the calling code is probably in a better position - to give a meaningful error. - There is no handling of fragments or queries at the moment. - - The URL to extract the type name from - The type name - - - - Unpacks the content of this Any message into the target message type, - which must match the type URL within this Any message. - - The type of message to unpack the content into. - The unpacked message. - The target message type doesn't match the type URL in this message - - - - Packs the specified message into an Any message using a type URL prefix of "type.googleapis.com". - - The message to pack. - An Any message with the content and type URL of . - - - - Packs the specified message into an Any message using the specified type URL prefix. - - The message to pack. - The prefix for the type URL. - An Any message with the content and type URL of . - - - Holder for reflection information generated from google/protobuf/api.proto - - - File descriptor for google/protobuf/api.proto - - - - Api is a light-weight descriptor for a protocol buffer service. - - - - Field number for the "name" field. - - - - The fully qualified name of this api, including package name - followed by the api's simple name. - - - - Field number for the "methods" field. - - - - The methods of this api, in unspecified order. - - - - Field number for the "options" field. - - - - Any metadata attached to the API. - - - - Field number for the "version" field. - - - - A version string for this api. If specified, must have the form - `major-version.minor-version`, as in `1.10`. If the minor version - is omitted, it defaults to zero. If the entire version field is - empty, the major version is derived from the package name, as - outlined below. If the field is not empty, the version in the - package name will be verified to be consistent with what is - provided here. - - The versioning schema uses [semantic - versioning](http://semver.org) where the major version number - indicates a breaking change and the minor version an additive, - non-breaking change. Both version numbers are signals to users - what to expect from different versions, and should be carefully - chosen based on the product plan. - - The major version is also reflected in the package name of the - API, which must end in `v<major-version>`, as in - `google.feature.v1`. For major versions 0 and 1, the suffix can - be omitted. Zero major versions must only be used for - experimental, none-GA apis. - - - - Field number for the "source_context" field. - - - - Source context for the protocol buffer service represented by this - message. - - - - Field number for the "mixins" field. - - - - Included APIs. See [Mixin][]. - - - - Field number for the "syntax" field. - - - - The source syntax of the service. - - - - - Method represents a method of an api. - - - - Field number for the "name" field. - - - - The simple name of this method. - - - - Field number for the "request_type_url" field. - - - - A URL of the input message type. - - - - Field number for the "request_streaming" field. - - - - If true, the request is streamed. - - - - Field number for the "response_type_url" field. - - - - The URL of the output message type. - - - - Field number for the "response_streaming" field. - - - - If true, the response is streamed. - - - - Field number for the "options" field. - - - - Any metadata attached to the method. - - - - Field number for the "syntax" field. - - - - The source syntax of this method. - - - - - Declares an API to be included in this API. The including API must - redeclare all the methods from the included API, but documentation - and options are inherited as follows: - - - If after comment and whitespace stripping, the documentation - string of the redeclared method is empty, it will be inherited - from the original method. - - - Each annotation belonging to the service config (http, - visibility) which is not set in the redeclared method will be - inherited. - - - If an http annotation is inherited, the path pattern will be - modified as follows. Any version prefix will be replaced by the - version of the including API plus the [root][] path if specified. - - Example of a simple mixin: - - package google.acl.v1; - service AccessControl { - // Get the underlying ACL object. - rpc GetAcl(GetAclRequest) returns (Acl) { - option (google.api.http).get = "/v1/{resource=**}:getAcl"; - } - } - - package google.storage.v2; - service Storage { - rpc GetAcl(GetAclRequest) returns (Acl); - - // Get a data record. - rpc GetData(GetDataRequest) returns (Data) { - option (google.api.http).get = "/v2/{resource=**}"; - } - } - - Example of a mixin configuration: - - apis: - - name: google.storage.v2.Storage - mixins: - - name: google.acl.v1.AccessControl - - The mixin construct implies that all methods in `AccessControl` are - also declared with same name and request/response types in - `Storage`. A documentation generator or annotation processor will - see the effective `Storage.GetAcl` method after inherting - documentation and annotations as follows: - - service Storage { - // Get the underlying ACL object. - rpc GetAcl(GetAclRequest) returns (Acl) { - option (google.api.http).get = "/v2/{resource=**}:getAcl"; - } - ... - } - - Note how the version in the path pattern changed from `v1` to `v2`. - - If the `root` field in the mixin is specified, it should be a - relative path under which inherited HTTP paths are placed. Example: - - apis: - - name: google.storage.v2.Storage - mixins: - - name: google.acl.v1.AccessControl - root: acls - - This implies the following inherited HTTP annotation: - - service Storage { - // Get the underlying ACL object. - rpc GetAcl(GetAclRequest) returns (Acl) { - option (google.api.http).get = "/v2/acls/{resource=**}:getAcl"; - } - ... - } - - - - Field number for the "name" field. - - - - The fully qualified name of the API which is included. - - - - Field number for the "root" field. - - - - If non-empty specifies a path under which inherited HTTP paths - are rooted. - - - - Holder for reflection information generated from google/protobuf/duration.proto - - - File descriptor for google/protobuf/duration.proto - - - - A Duration represents a signed, fixed-length span of time represented - as a count of seconds and fractions of seconds at nanosecond - resolution. It is independent of any calendar and concepts like "day" - or "month". It is related to Timestamp in that the difference between - two Timestamp values is a Duration and it can be added or subtracted - from a Timestamp. Range is approximately +-10,000 years. - - # Examples - - Example 1: Compute Duration from two Timestamps in pseudo code. - - Timestamp start = ...; - Timestamp end = ...; - Duration duration = ...; - - duration.seconds = end.seconds - start.seconds; - duration.nanos = end.nanos - start.nanos; - - if (duration.seconds < 0 && duration.nanos > 0) { - duration.seconds += 1; - duration.nanos -= 1000000000; - } else if (durations.seconds > 0 && duration.nanos < 0) { - duration.seconds -= 1; - duration.nanos += 1000000000; - } - - Example 2: Compute Timestamp from Timestamp + Duration in pseudo code. - - Timestamp start = ...; - Duration duration = ...; - Timestamp end = ...; - - end.seconds = start.seconds + duration.seconds; - end.nanos = start.nanos + duration.nanos; - - if (end.nanos < 0) { - end.seconds -= 1; - end.nanos += 1000000000; - } else if (end.nanos >= 1000000000) { - end.seconds += 1; - end.nanos -= 1000000000; - } - - Example 3: Compute Duration from datetime.timedelta in Python. - - td = datetime.timedelta(days=3, minutes=10) - duration = Duration() - duration.FromTimedelta(td) - - # JSON Mapping - - In JSON format, the Duration type is encoded as a string rather than an - object, where the string ends in the suffix "s" (indicating seconds) and - is preceded by the number of seconds, with nanoseconds expressed as - fractional seconds. For example, 3 seconds with 0 nanoseconds should be - encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should - be expressed in JSON format as "3.000000001s", and 3 seconds and 1 - microsecond should be expressed in JSON format as "3.000001s". - - - - Field number for the "seconds" field. - - - - Signed seconds of the span of time. Must be from -315,576,000,000 - to +315,576,000,000 inclusive. Note: these bounds are computed from: - 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years - - - - Field number for the "nanos" field. - - - - Signed fractions of a second at nanosecond resolution of the span - of time. Durations less than one second are represented with a 0 - `seconds` field and a positive or negative `nanos` field. For durations - of one second or more, a non-zero value for the `nanos` field must be - of the same sign as the `seconds` field. Must be from -999,999,999 - to +999,999,999 inclusive. - - - - - The number of nanoseconds in a second. - - - - - The number of nanoseconds in a BCL tick (as used by and ). - - - - - The maximum permitted number of seconds. - - - - - The minimum permitted number of seconds. - - - - - Converts this to a . - - If the duration is not a precise number of ticks, it is truncated towards 0. - The value of this duration, as a TimeSpan. - This value isn't a valid normalized duration, as - described in the documentation. - - - - Converts the given to a . - - The TimeSpan to convert. - The value of the given TimeSpan, as a Duration. - - - - Returns the result of negating the duration. For example, the negation of 5 minutes is -5 minutes. - - The duration to negate. Must not be null. - The negated value of this duration. - - - - Adds the two specified values together. - - The first value to add. Must not be null. - The second value to add. Must not be null. - - - - - Subtracts one from another. - - The duration to subtract from. Must not be null. - The duration to subtract. Must not be null. - The difference between the two specified durations. - - - - Creates a duration with the normalized values from the given number of seconds and - nanoseconds, conforming with the description in the proto file. - - - - - Converts a duration specified in seconds/nanoseconds to a string. - - - If the value is a normalized duration in the range described in duration.proto, - is ignored. Otherwise, if the parameter is true, - a JSON object with a warning is returned; if it is false, an is thrown. - - Seconds portion of the duration. - Nanoseconds portion of the duration. - Determines the handling of non-normalized values - The represented duration is invalid, and is false. - - - - Returns a string representation of this for diagnostic purposes. - - - Normally the returned value will be a JSON string value (including leading and trailing quotes) but - when the value is non-normalized or out of range, a JSON object representation will be returned - instead, including a warning. This is to avoid exceptions being thrown when trying to - diagnose problems - the regular JSON formatter will still throw an exception for non-normalized - values. - - A string representation of this value. - - - - Appends a number of nanoseconds to a StringBuilder. Either 0 digits are added (in which - case no "." is appended), or 3 6 or 9 digits. This is internal for use in Timestamp as well - as Duration. - - - - Holder for reflection information generated from google/protobuf/empty.proto - - - File descriptor for google/protobuf/empty.proto - - - - A generic empty message that you can re-use to avoid defining duplicated - empty messages in your APIs. A typical example is to use it as the request - or the response type of an API method. For instance: - - service Foo { - rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); - } - - The JSON representation for `Empty` is empty JSON object `{}`. - - - - Holder for reflection information generated from google/protobuf/field_mask.proto - - - File descriptor for google/protobuf/field_mask.proto - - - - `FieldMask` represents a set of symbolic field paths, for example: - - paths: "f.a" - paths: "f.b.d" - - Here `f` represents a field in some root message, `a` and `b` - fields in the message found in `f`, and `d` a field found in the - message in `f.b`. - - Field masks are used to specify a subset of fields that should be - returned by a get operation or modified by an update operation. - Field masks also have a custom JSON encoding (see below). - - # Field Masks in Projections - - When used in the context of a projection, a response message or - sub-message is filtered by the API to only contain those fields as - specified in the mask. For example, if the mask in the previous - example is applied to a response message as follows: - - f { - a : 22 - b { - d : 1 - x : 2 - } - y : 13 - } - z: 8 - - The result will not contain specific values for fields x,y and z - (their value will be set to the default, and omitted in proto text - output): - - f { - a : 22 - b { - d : 1 - } - } - - A repeated field is not allowed except at the last position of a - paths string. - - If a FieldMask object is not present in a get operation, the - operation applies to all fields (as if a FieldMask of all fields - had been specified). - - Note that a field mask does not necessarily apply to the - top-level response message. In case of a REST get operation, the - field mask applies directly to the response, but in case of a REST - list operation, the mask instead applies to each individual message - in the returned resource list. In case of a REST custom method, - other definitions may be used. Where the mask applies will be - clearly documented together with its declaration in the API. In - any case, the effect on the returned resource/resources is required - behavior for APIs. - - # Field Masks in Update Operations - - A field mask in update operations specifies which fields of the - targeted resource are going to be updated. The API is required - to only change the values of the fields as specified in the mask - and leave the others untouched. If a resource is passed in to - describe the updated values, the API ignores the values of all - fields not covered by the mask. - - If a repeated field is specified for an update operation, the existing - repeated values in the target resource will be overwritten by the new values. - Note that a repeated field is only allowed in the last position of a `paths` - string. - - If a sub-message is specified in the last position of the field mask for an - update operation, then the existing sub-message in the target resource is - overwritten. Given the target message: - - f { - b { - d : 1 - x : 2 - } - c : 1 - } - - And an update message: - - f { - b { - d : 10 - } - } - - then if the field mask is: - - paths: "f.b" - - then the result will be: - - f { - b { - d : 10 - } - c : 1 - } - - However, if the update mask was: - - paths: "f.b.d" - - then the result would be: - - f { - b { - d : 10 - x : 2 - } - c : 1 - } - - In order to reset a field's value to the default, the field must - be in the mask and set to the default value in the provided resource. - Hence, in order to reset all fields of a resource, provide a default - instance of the resource and set all fields in the mask, or do - not provide a mask as described below. - - If a field mask is not present on update, the operation applies to - all fields (as if a field mask of all fields has been specified). - Note that in the presence of schema evolution, this may mean that - fields the client does not know and has therefore not filled into - the request will be reset to their default. If this is unwanted - behavior, a specific service may require a client to always specify - a field mask, producing an error if not. - - As with get operations, the location of the resource which - describes the updated values in the request message depends on the - operation kind. In any case, the effect of the field mask is - required to be honored by the API. - - ## Considerations for HTTP REST - - The HTTP kind of an update operation which uses a field mask must - be set to PATCH instead of PUT in order to satisfy HTTP semantics - (PUT must only be used for full updates). - - # JSON Encoding of Field Masks - - In JSON, a field mask is encoded as a single string where paths are - separated by a comma. Fields name in each path are converted - to/from lower-camel naming conventions. - - As an example, consider the following message declarations: - - message Profile { - User user = 1; - Photo photo = 2; - } - message User { - string display_name = 1; - string address = 2; - } - - In proto a field mask for `Profile` may look as such: - - mask { - paths: "user.display_name" - paths: "photo" - } - - In JSON, the same mask is represented as below: - - { - mask: "user.displayName,photo" - } - - # Field Masks and Oneof Fields - - Field masks treat fields in oneofs just as regular fields. Consider the - following message: - - message SampleMessage { - oneof test_oneof { - string name = 4; - SubMessage sub_message = 9; - } - } - - The field mask can be: - - mask { - paths: "name" - } - - Or: - - mask { - paths: "sub_message" - } - - Note that oneof type names ("test_oneof" in this case) cannot be used in - paths. - - - - Field number for the "paths" field. - - - - The set of field mask paths. - - - - - Converts a timestamp specified in seconds/nanoseconds to a string. - - - If the value is a normalized duration in the range described in field_mask.proto, - is ignored. Otherwise, if the parameter is true, - a JSON object with a warning is returned; if it is false, an is thrown. - - Paths in the field mask - Determines the handling of non-normalized values - The represented field mask is invalid, and is false. - - - - Checks whether the given path is valid for a field mask. - - true if the path is valid; false otherwise - - - - Returns a string representation of this for diagnostic purposes. - - - Normally the returned value will be a JSON string value (including leading and trailing quotes) but - when the value is non-normalized or out of range, a JSON object representation will be returned - instead, including a warning. This is to avoid exceptions being thrown when trying to - diagnose problems - the regular JSON formatter will still throw an exception for non-normalized - values. - - A string representation of this value. - - - Holder for reflection information generated from google/protobuf/source_context.proto - - - File descriptor for google/protobuf/source_context.proto - - - - `SourceContext` represents information about the source of a - protobuf element, like the file in which it is defined. - - - - Field number for the "file_name" field. - - - - The path-qualified name of the .proto file that contained the associated - protobuf element. For example: `"google/protobuf/source_context.proto"`. - - - - Holder for reflection information generated from google/protobuf/struct.proto - - - File descriptor for google/protobuf/struct.proto - - - - `NullValue` is a singleton enumeration to represent the null value for the - `Value` type union. - - The JSON representation for `NullValue` is JSON `null`. - - - - - Null value. - - - - - `Struct` represents a structured data value, consisting of fields - which map to dynamically typed values. In some languages, `Struct` - might be supported by a native representation. For example, in - scripting languages like JS a struct is represented as an - object. The details of that representation are described together - with the proto support for the language. - - The JSON representation for `Struct` is JSON object. - - - - Field number for the "fields" field. - - - - Unordered map of dynamically typed values. - - - - - `Value` represents a dynamically typed value which can be either - null, a number, a string, a boolean, a recursive struct value, or a - list of values. A producer of value is expected to set one of that - variants, absence of any variant indicates an error. - - The JSON representation for `Value` is JSON value. - - - - Field number for the "null_value" field. - - - - Represents a null value. - - - - Field number for the "number_value" field. - - - - Represents a double value. - - - - Field number for the "string_value" field. - - - - Represents a string value. - - - - Field number for the "bool_value" field. - - - - Represents a boolean value. - - - - Field number for the "struct_value" field. - - - - Represents a structured value. - - - - Field number for the "list_value" field. - - - - Represents a repeated `Value`. - - - - Enum of possible cases for the "kind" oneof. - - - - Convenience method to create a Value message with a string value. - - Value to set for the StringValue property. - A newly-created Value message with the given value. - - - - Convenience method to create a Value message with a number value. - - Value to set for the NumberValue property. - A newly-created Value message with the given value. - - - - Convenience method to create a Value message with a Boolean value. - - Value to set for the BoolValue property. - A newly-created Value message with the given value. - - - - Convenience method to create a Value message with a null initial value. - - A newly-created Value message a null initial value. - - - - Convenience method to create a Value message with an initial list of values. - - The values provided are not cloned; the references are copied directly. - A newly-created Value message an initial list value. - - - - Convenience method to create a Value message with an initial struct value - - The value provided is not cloned; the reference is copied directly. - A newly-created Value message an initial struct value. - - - - `ListValue` is a wrapper around a repeated field of values. - - The JSON representation for `ListValue` is JSON array. - - - - Field number for the "values" field. - - - - Repeated field of dynamically typed values. - - - - - Extension methods on BCL time-related types, converting to protobuf types. - - - - - Converts the given to a . - - The date and time to convert to a timestamp. - The value has a other than Utc. - The converted timestamp. - - - - Converts the given to a - - The offset is taken into consideration when converting the value (so the same instant in time - is represented) but is not a separate part of the resulting value. In other words, there is no - roundtrip operation to retrieve the original DateTimeOffset. - The date and time (with UTC offset) to convert to a timestamp. - The converted timestamp. - - - - Converts the given to a . - - The time span to convert. - The converted duration. - - - Holder for reflection information generated from google/protobuf/timestamp.proto - - - File descriptor for google/protobuf/timestamp.proto - - - - A Timestamp represents a point in time independent of any time zone - or calendar, represented as seconds and fractions of seconds at - nanosecond resolution in UTC Epoch time. It is encoded using the - Proleptic Gregorian Calendar which extends the Gregorian calendar - backwards to year one. It is encoded assuming all minutes are 60 - seconds long, i.e. leap seconds are "smeared" so that no leap second - table is needed for interpretation. Range is from - 0001-01-01T00:00:00Z to 9999-12-31T23:59:59.999999999Z. - By restricting to that range, we ensure that we can convert to - and from RFC 3339 date strings. - See [https://www.ietf.org/rfc/rfc3339.txt](https://www.ietf.org/rfc/rfc3339.txt). - - # Examples - - Example 1: Compute Timestamp from POSIX `time()`. - - Timestamp timestamp; - timestamp.set_seconds(time(NULL)); - timestamp.set_nanos(0); - - Example 2: Compute Timestamp from POSIX `gettimeofday()`. - - struct timeval tv; - gettimeofday(&tv, NULL); - - Timestamp timestamp; - timestamp.set_seconds(tv.tv_sec); - timestamp.set_nanos(tv.tv_usec * 1000); - - Example 3: Compute Timestamp from Win32 `GetSystemTimeAsFileTime()`. - - FILETIME ft; - GetSystemTimeAsFileTime(&ft); - UINT64 ticks = (((UINT64)ft.dwHighDateTime) << 32) | ft.dwLowDateTime; - - // A Windows tick is 100 nanoseconds. Windows epoch 1601-01-01T00:00:00Z - // is 11644473600 seconds before Unix epoch 1970-01-01T00:00:00Z. - Timestamp timestamp; - timestamp.set_seconds((INT64) ((ticks / 10000000) - 11644473600LL)); - timestamp.set_nanos((INT32) ((ticks % 10000000) * 100)); - - Example 4: Compute Timestamp from Java `System.currentTimeMillis()`. - - long millis = System.currentTimeMillis(); - - Timestamp timestamp = Timestamp.newBuilder().setSeconds(millis / 1000) - .setNanos((int) ((millis % 1000) * 1000000)).build(); - - Example 5: Compute Timestamp from current time in Python. - - timestamp = Timestamp() - timestamp.GetCurrentTime() - - # JSON Mapping - - In JSON format, the Timestamp type is encoded as a string in the - [RFC 3339](https://www.ietf.org/rfc/rfc3339.txt) format. That is, the - format is "{year}-{month}-{day}T{hour}:{min}:{sec}[.{frac_sec}]Z" - where {year} is always expressed using four digits while {month}, {day}, - {hour}, {min}, and {sec} are zero-padded to two digits each. The fractional - seconds, which can go up to 9 digits (i.e. up to 1 nanosecond resolution), - are optional. The "Z" suffix indicates the timezone ("UTC"); the timezone - is required, though only UTC (as indicated by "Z") is presently supported. - - For example, "2017-01-15T01:30:15.01Z" encodes 15.01 seconds past - 01:30 UTC on January 15, 2017. - - In JavaScript, one can convert a Date object to this format using the - standard [toISOString()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString] - method. In Python, a standard `datetime.datetime` object can be converted - to this format using [`strftime`](https://docs.python.org/2/library/time.html#time.strftime) - with the time format spec '%Y-%m-%dT%H:%M:%S.%fZ'. Likewise, in Java, one - can use the Joda Time's [`ISODateTimeFormat.dateTime()`]( - http://joda-time.sourceforge.net/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime()) - to obtain a formatter capable of generating timestamps in this format. - - - - Field number for the "seconds" field. - - - - Represents seconds of UTC time since Unix epoch - 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to - 9999-12-31T23:59:59Z inclusive. - - - - Field number for the "nanos" field. - - - - Non-negative fractions of a second at nanosecond resolution. Negative - second values with fractions must still have non-negative nanos values - that count forward in time. Must be from 0 to 999,999,999 - inclusive. - - - - - Returns the difference between one and another, as a . - - The timestamp to subtract from. Must not be null. - The timestamp to subtract. Must not be null. - The difference between the two specified timestamps. - - - - Adds a to a , to obtain another Timestamp. - - The timestamp to add the duration to. Must not be null. - The duration to add. Must not be null. - The result of adding the duration to the timestamp. - - - - Subtracts a from a , to obtain another Timestamp. - - The timestamp to subtract the duration from. Must not be null. - The duration to subtract. - The result of subtracting the duration from the timestamp. - - - - Converts this timestamp into a . - - - The resulting DateTime will always have a Kind of Utc. - If the timestamp is not a precise number of ticks, it will be truncated towards the start - of time. For example, a timestamp with a value of 99 will result in a - value precisely on a second. - - This timestamp as a DateTime. - The timestamp contains invalid values; either it is - incorrectly normalized or is outside the valid range. - - - - Converts this timestamp into a . - - - The resulting DateTimeOffset will always have an Offset of zero. - If the timestamp is not a precise number of ticks, it will be truncated towards the start - of time. For example, a timestamp with a value of 99 will result in a - value precisely on a second. - - This timestamp as a DateTimeOffset. - The timestamp contains invalid values; either it is - incorrectly normalized or is outside the valid range. - - - - Converts the specified to a . - - - The Kind of is not DateTimeKind.Utc. - The converted timestamp. - - - - Converts the given to a - - The offset is taken into consideration when converting the value (so the same instant in time - is represented) but is not a separate part of the resulting value. In other words, there is no - roundtrip operation to retrieve the original DateTimeOffset. - The date and time (with UTC offset) to convert to a timestamp. - The converted timestamp. - - - - Converts a timestamp specified in seconds/nanoseconds to a string. - - - If the value is a normalized duration in the range described in timestamp.proto, - is ignored. Otherwise, if the parameter is true, - a JSON object with a warning is returned; if it is false, an is thrown. - - Seconds portion of the duration. - Nanoseconds portion of the duration. - Determines the handling of non-normalized values - The represented duration is invalid, and is false. - - - - Returns a string representation of this for diagnostic purposes. - - - Normally the returned value will be a JSON string value (including leading and trailing quotes) but - when the value is non-normalized or out of range, a JSON object representation will be returned - instead, including a warning. This is to avoid exceptions being thrown when trying to - diagnose problems - the regular JSON formatter will still throw an exception for non-normalized - values. - - A string representation of this value. - - - Holder for reflection information generated from google/protobuf/type.proto - - - File descriptor for google/protobuf/type.proto - - - - The syntax in which a protocol buffer element is defined. - - - - - Syntax `proto2`. - - - - - Syntax `proto3`. - - - - - A protocol buffer message type. - - - - Field number for the "name" field. - - - - The fully qualified message name. - - - - Field number for the "fields" field. - - - - The list of fields. - - - - Field number for the "oneofs" field. - - - - The list of types appearing in `oneof` definitions in this type. - - - - Field number for the "options" field. - - - - The protocol buffer options. - - - - Field number for the "source_context" field. - - - - The source context. - - - - Field number for the "syntax" field. - - - - The source syntax. - - - - - A single field of a message type. - - - - Field number for the "kind" field. - - - - The field type. - - - - Field number for the "cardinality" field. - - - - The field cardinality. - - - - Field number for the "number" field. - - - - The field number. - - - - Field number for the "name" field. - - - - The field name. - - - - Field number for the "type_url" field. - - - - The field type URL, without the scheme, for message or enumeration - types. Example: `"type.googleapis.com/google.protobuf.Timestamp"`. - - - - Field number for the "oneof_index" field. - - - - The index of the field type in `Type.oneofs`, for message or enumeration - types. The first type has index 1; zero means the type is not in the list. - - - - Field number for the "packed" field. - - - - Whether to use alternative packed wire representation. - - - - Field number for the "options" field. - - - - The protocol buffer options. - - - - Field number for the "json_name" field. - - - - The field JSON name. - - - - Field number for the "default_value" field. - - - - The string value of the default value of this field. Proto2 syntax only. - - - - Container for nested types declared in the Field message type. - - - - Basic field types. - - - - - Field type unknown. - - - - - Field type double. - - - - - Field type float. - - - - - Field type int64. - - - - - Field type uint64. - - - - - Field type int32. - - - - - Field type fixed64. - - - - - Field type fixed32. - - - - - Field type bool. - - - - - Field type string. - - - - - Field type group. Proto2 syntax only, and deprecated. - - - - - Field type message. - - - - - Field type bytes. - - - - - Field type uint32. - - - - - Field type enum. - - - - - Field type sfixed32. - - - - - Field type sfixed64. - - - - - Field type sint32. - - - - - Field type sint64. - - - - - Whether a field is optional, required, or repeated. - - - - - For fields with unknown cardinality. - - - - - For optional fields. - - - - - For required fields. Proto2 syntax only. - - - - - For repeated fields. - - - - - Enum type definition. - - - - Field number for the "name" field. - - - - Enum type name. - - - - Field number for the "enumvalue" field. - - - - Enum value definitions. - - - - Field number for the "options" field. - - - - Protocol buffer options. - - - - Field number for the "source_context" field. - - - - The source context. - - - - Field number for the "syntax" field. - - - - The source syntax. - - - - - Enum value definition. - - - - Field number for the "name" field. - - - - Enum value name. - - - - Field number for the "number" field. - - - - Enum value number. - - - - Field number for the "options" field. - - - - Protocol buffer options. - - - - - A protocol buffer option, which can be attached to a message, field, - enumeration, etc. - - - - Field number for the "name" field. - - - - The option's name. For protobuf built-in options (options defined in - descriptor.proto), this is the short name. For example, `"map_entry"`. - For custom options, it should be the fully-qualified name. For example, - `"google.api.http"`. - - - - Field number for the "value" field. - - - - The option's value packed in an Any message. If the value is a primitive, - the corresponding wrapper type defined in google/protobuf/wrappers.proto - should be used. If the value is an enum, it should be stored as an int32 - value using the google.protobuf.Int32Value type. - - - - Holder for reflection information generated from google/protobuf/wrappers.proto - - - File descriptor for google/protobuf/wrappers.proto - - - - Field number for the single "value" field in all wrapper types. - - - - - Wrapper message for `double`. - - The JSON representation for `DoubleValue` is JSON number. - - - - Field number for the "value" field. - - - - The double value. - - - - - Wrapper message for `float`. - - The JSON representation for `FloatValue` is JSON number. - - - - Field number for the "value" field. - - - - The float value. - - - - - Wrapper message for `int64`. - - The JSON representation for `Int64Value` is JSON string. - - - - Field number for the "value" field. - - - - The int64 value. - - - - - Wrapper message for `uint64`. - - The JSON representation for `UInt64Value` is JSON string. - - - - Field number for the "value" field. - - - - The uint64 value. - - - - - Wrapper message for `int32`. - - The JSON representation for `Int32Value` is JSON number. - - - - Field number for the "value" field. - - - - The int32 value. - - - - - Wrapper message for `uint32`. - - The JSON representation for `UInt32Value` is JSON number. - - - - Field number for the "value" field. - - - - The uint32 value. - - - - - Wrapper message for `bool`. - - The JSON representation for `BoolValue` is JSON `true` and `false`. - - - - Field number for the "value" field. - - - - The bool value. - - - - - Wrapper message for `string`. - - The JSON representation for `StringValue` is JSON string. - - - - Field number for the "value" field. - - - - The string value. - - - - - Wrapper message for `bytes`. - - The JSON representation for `BytesValue` is JSON string. - - - - Field number for the "value" field. - - - - The bytes value. - - - - - This class is used internally by the Protocol Buffer Library and generated - message implementations. It is public only for the sake of those generated - messages. Others should not use this class directly. - - This class contains constants and helper functions useful for dealing with - the Protocol Buffer wire format. - - - - - - Wire types within protobuf encoding. - - - - - Variable-length integer. - - - - - A fixed-length 64-bit value. - - - - - A length-delimited value, i.e. a length followed by that many bytes of data. - - - - - A "start group" value - not supported by this implementation. - - - - - An "end group" value - not supported by this implementation. - - - - - A fixed-length 32-bit value. - - - - - Given a tag value, determines the wire type (lower 3 bits). - - - - - Given a tag value, determines the field number (the upper 29 bits). - - - - - Makes a tag value given a field number and wire type. - - -
-
diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta b/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta deleted file mode 100644 index aedb2691..00000000 --- a/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta +++ /dev/null @@ -1,8 +0,0 @@ -fileFormatVersion: 2 -guid: 32e98c3d38e34d14ea431c91eae90058 -timeCreated: 1496624518 -licenseType: Free -TextScriptImporter: - userData: - assetBundleName: - assetBundleVariant: From b793e953fcb565092c145a7c4318b9a7a548ba14 Mon Sep 17 00:00:00 2001 From: Dewald Bodenstein Date: Thu, 8 Feb 2024 05:57:25 +0200 Subject: [PATCH 4/4] Fixed Plugins dll --- Runtime/Plugins/Protobuf.meta | 9 + Runtime/Plugins/Protobuf/Google.Protobuf.dll | Bin 0 -> 305664 bytes .../Plugins/Protobuf/Google.Protobuf.dll.meta | 34 + Runtime/Plugins/Protobuf/Google.Protobuf.xml | 7028 +++++++++++++++++ .../Plugins/Protobuf/Google.Protobuf.xml.meta | 8 + 5 files changed, 7079 insertions(+) create mode 100644 Runtime/Plugins/Protobuf.meta create mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.dll create mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta create mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.xml create mode 100644 Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta diff --git a/Runtime/Plugins/Protobuf.meta b/Runtime/Plugins/Protobuf.meta new file mode 100644 index 00000000..2443298a --- /dev/null +++ b/Runtime/Plugins/Protobuf.meta @@ -0,0 +1,9 @@ +fileFormatVersion: 2 +guid: fd3426b2e741b4f49a615bd7a48c16f4 +folderAsset: yes +timeCreated: 1496624517 +licenseType: Free +DefaultImporter: + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.dll b/Runtime/Plugins/Protobuf/Google.Protobuf.dll new file mode 100644 index 0000000000000000000000000000000000000000..22e0cc857d5bc4ff7f5a9e9a139f8e46e3ffcca8 GIT binary patch literal 305664 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 literal 0 HcmV?d00001 diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta b/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta new file mode 100644 index 00000000..43672dc3 --- /dev/null +++ b/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta @@ -0,0 +1,34 @@ +fileFormatVersion: 2 +guid: 5ad31ad7e29cad14e933a09c5c84d9c4 +timeCreated: 1496624518 +licenseType: Free +PluginImporter: + serializedVersion: 2 + iconMap: {} + executionOrder: {} + isPreloaded: 0 + isOverridable: 0 + platformData: + data: + first: + Any: + second: + enabled: 1 + settings: {} + data: + first: + Editor: Editor + second: + enabled: 0 + settings: + DefaultValueInitialized: true + data: + first: + Windows Store Apps: WindowsStoreApps + second: + enabled: 0 + settings: + CPU: AnyCPU + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.xml b/Runtime/Plugins/Protobuf/Google.Protobuf.xml new file mode 100644 index 00000000..1a7bbd4b --- /dev/null +++ b/Runtime/Plugins/Protobuf/Google.Protobuf.xml @@ -0,0 +1,7028 @@ + + + + Google.Protobuf + + + + + Provides a utility routine to copy small arrays much more quickly than Buffer.BlockCopy + + + + + The threshold above which you should use Buffer.BlockCopy rather than ByteArray.Copy + + + + + Determines which copy routine to use based on the number of bytes to be copied. + + + + + Reverses the order of bytes in the array + + + + + Immutable array of bytes. + + + + + Unsafe operations that can cause IO Failure and/or other catestrophic side-effects. + + + + + Constructs a new ByteString from the given byte array. The array is + *not* copied, and must not be modified after this constructor is called. + + + + + Provides direct, unrestricted access to the bytes contained in this instance. + You must not modify or resize the byte array returned by this method. + + + + + Internal use only. Ensure that the provided array is not mutated and belongs to this instance. + + + + + Constructs a new ByteString from the given byte array. The array is + *not* copied, and must not be modified after this constructor is called. + + + + + Returns an empty ByteString. + + + + + Returns the length of this ByteString in bytes. + + + + + Returns true if this byte string is empty, false otherwise. + + + + + Converts this into a byte array. + + The data is copied - changes to the returned array will not be reflected in this ByteString. + A byte array with the same data as this ByteString. + + + + Converts this into a standard base64 representation. + + A base64 representation of this ByteString. + + + + Constructs a from the Base64 Encoded String. + + + + + Constructs a from data in the given stream, synchronously. + + If successful, will be read completely, from the position + at the start of the call. + The stream to copy into a ByteString. + A ByteString with content read from the given stream. + + + + Constructs a from the given array. The contents + are copied, so further modifications to the array will not + be reflected in the returned ByteString. + This method can also be invoked in ByteString.CopyFrom(0xaa, 0xbb, ...) form + which is primarily useful for testing. + + + + + Constructs a from a portion of a byte array. + + + + + Creates a new by encoding the specified text with + the given encoding. + + + + + Creates a new by encoding the specified text in UTF-8. + + + + + Retuns the byte at the given index. + + + + + Converts this into a string by applying the given encoding. + + + This method should only be used to convert binary data which was the result of encoding + text with the given encoding. + + The encoding to use to decode the binary data into text. + The result of decoding the binary data with the given decoding. + + + + Converts this into a string by applying the UTF-8 encoding. + + + This method should only be used to convert binary data which was the result of encoding + text with UTF-8. + + The result of decoding the binary data with the given decoding. + + + + Returns an iterator over the bytes in this . + + An iterator over the bytes in this object. + + + + Returns an iterator over the bytes in this . + + An iterator over the bytes in this object. + + + + Creates a CodedInputStream from this ByteString's data. + + + + + Compares two byte strings for equality. + + The first byte string to compare. + The second byte string to compare. + true if the byte strings are equal; false otherwise. + + + + Compares two byte strings for inequality. + + The first byte string to compare. + The second byte string to compare. + false if the byte strings are equal; true otherwise. + + + + Compares this byte string with another object. + + The object to compare this with. + true if refers to an equal ; false otherwise. + + + + Returns a hash code for this object. Two equal byte strings + will return the same hash code. + + A hash code for this object. + + + + Compares this byte string with another. + + The to compare this with. + true if refers to an equal byte string; false otherwise. + + + + Used internally by CodedOutputStream to avoid creating a copy for the write + + + + + Copies the entire byte array to the destination array provided at the offset specified. + + + + + Writes the entire byte array to the provided stream + + + + + Reads and decodes protocol message fields. + + + + This class is generally used by generated code to read appropriate + primitives from the stream. It effectively encapsulates the lowest + levels of protocol buffer format. + + + Repeated fields and map fields are not handled by this class; use + and to serialize such fields. + + + + + + Whether to leave the underlying stream open when disposing of this stream. + This is always true when there's no stream. + + + + + Buffer of data read from the stream or provided at construction time. + + + + + The index of the buffer at which we need to refill from the stream (if there is one). + + + + + The position within the current buffer (i.e. the next byte to read) + + + + + The stream to read further input from, or null if the byte array buffer was provided + directly on construction, with no further data available. + + + + + The last tag we read. 0 indicates we've read to the end of the stream + (or haven't read anything yet). + + + + + The next tag, used to store the value read by PeekTag. + + + + + The total number of bytes read before the current buffer. The + total bytes read up to the current position can be computed as + totalBytesRetired + bufferPos. + + + + + The absolute position of the end of the current message. + + + + + Creates a new CodedInputStream reading data from the given byte array. + + + + + Creates a new that reads from the given byte array slice. + + + + + Creates a new reading data from the given stream, which will be disposed + when the returned object is disposed. + + The stream to read from. + + + + Creates a new reading data from the given stream. + + The stream to read from. + true to leave open when the returned + is disposed; false to dispose of the given stream when the + returned object is disposed. + + + + Creates a new CodedInputStream reading data from the given + stream and buffer, using the default limits. + + + + + Creates a new CodedInputStream reading data from the given + stream and buffer, using the specified limits. + + + This chains to the version with the default limits instead of vice versa to avoid + having to check that the default values are valid every time. + + + + + Creates a with the specified size and recursion limits, reading + from an input stream. + + + This method exists separately from the constructor to reduce the number of constructor overloads. + It is likely to be used considerably less frequently than the constructors, as the default limits + are suitable for most use cases. + + The input stream to read from + The total limit of data to read from the stream. + The maximum recursion depth to allow while reading. + A CodedInputStream reading from with the specified size + and recursion limits. + + + + Returns the current position in the input stream, or the position in the input buffer + + + + + Returns the last tag read, or 0 if no tags have been read or we've read beyond + the end of the stream. + + + + + Returns the size limit for this stream. + + + This limit is applied when reading from the underlying stream, as a sanity check. It is + not applied when reading from a byte array data source without an underlying stream. + The default value is 64MB. + + + The size limit. + + + + + Returns the recursion limit for this stream. This limit is applied whilst reading messages, + to avoid maliciously-recursive data. + + + The default limit is 64. + + + The recursion limit for this stream. + + + + + Disposes of this instance, potentially closing any underlying stream. + + + As there is no flushing to perform here, disposing of a which + was constructed with the leaveOpen option parameter set to true (or one which + was constructed to read from a byte array) has no effect. + + + + + Verifies that the last call to ReadTag() returned tag 0 - in other words, + we've reached the end of the stream when we expected to. + + The + tag read was not the one specified + + + + Peeks at the next field tag. This is like calling , but the + tag is not consumed. (So a subsequent call to will return the + same value.) + + + + + Reads a field tag, returning the tag of 0 for "end of stream". + + + If this method returns 0, it doesn't necessarily mean the end of all + the data in this CodedInputStream; it may be the end of the logical stream + for an embedded message, for example. + + The next field tag, or 0 for end of stream. (0 is never a valid tag.) + + + + Skips the data for the field with the tag we've just read. + This should be called directly after , when + the caller wishes to skip an unknown field. + + + This method throws if the last-read tag was an end-group tag. + If a caller wishes to skip a group, they should skip the whole group, by calling this method after reading the + start-group tag. This behavior allows callers to call this method on any field they don't understand, correctly + resulting in an error if an end-group tag has not been paired with an earlier start-group tag. + + The last tag was an end-group tag + The last read operation read to the end of the logical stream + + + + Reads a double field from the stream. + + + + + Reads a float field from the stream. + + + + + Reads a uint64 field from the stream. + + + + + Reads an int64 field from the stream. + + + + + Reads an int32 field from the stream. + + + + + Reads a fixed64 field from the stream. + + + + + Reads a fixed32 field from the stream. + + + + + Reads a bool field from the stream. + + + + + Reads a string field from the stream. + + + + + Reads an embedded message field value from the stream. + + + + + Reads a bytes field value from the stream. + + + + + Reads a uint32 field value from the stream. + + + + + Reads an enum field value from the stream. + + + + + Reads an sfixed32 field value from the stream. + + + + + Reads an sfixed64 field value from the stream. + + + + + Reads an sint32 field value from the stream. + + + + + Reads an sint64 field value from the stream. + + + + + Reads a length for length-delimited data. + + + This is internally just reading a varint, but this method exists + to make the calling code clearer. + + + + + Peeks at the next tag in the stream. If it matches , + the tag is consumed and the method returns true; otherwise, the + stream is left in the original position and the method returns false. + + + + + Same code as ReadRawVarint32, but read each byte individually, checking for + buffer overflow. + + + + + Reads a raw Varint from the stream. If larger than 32 bits, discard the upper bits. + This method is optimised for the case where we've got lots of data in the buffer. + That means we can check the size just once, then just read directly from the buffer + without constant rechecking of the buffer length. + + + + + Reads a varint from the input one byte at a time, so that it does not + read any bytes after the end of the varint. If you simply wrapped the + stream in a CodedInputStream and used ReadRawVarint32(Stream) + then you would probably end up reading past the end of the varint since + CodedInputStream buffers its input. + + + + + + + Reads a raw varint from the stream. + + + + + Reads a 32-bit little-endian integer from the stream. + + + + + Reads a 64-bit little-endian integer from the stream. + + + + + Decode a 32-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Decode a 32-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Sets currentLimit to (current position) + byteLimit. This is called + when descending into a length-delimited embedded message. The previous + limit is returned. + + The old limit. + + + + Discards the current limit, returning the previous limit. + + + + + Returns whether or not all the data before the limit has been read. + + + + + + Returns true if the stream has reached the end of the input. This is the + case if either the end of the underlying input source has been reached or + the stream has reached a limit created using PushLimit. + + + + + Called when buffer is empty to read more bytes from the + input. If is true, RefillBuffer() gurantees that + either there will be at least one byte in the buffer when it returns + or it will throw an exception. If is false, + RefillBuffer() returns false if no more bytes were available. + + + + + + + Read one byte from the input. + + + the end of the stream or the current limit was reached + + + + + Reads a fixed size of bytes from the input. + + + the end of the stream or the current limit was reached + + + + + Reads and discards bytes. + + the end of the stream + or the current limit was reached + + + + Abstraction of skipping to cope with streams which can't really skip. + + + + + Encodes and writes protocol message fields. + + + + This class is generally used by generated code to write appropriate + primitives to the stream. It effectively encapsulates the lowest + levels of protocol buffer format. Unlike some other implementations, + this does not include combined "write tag and value" methods. Generated + code knows the exact byte representations of the tags they're going to write, + so there's no need to re-encode them each time. Manually-written code calling + this class should just call one of the WriteTag overloads before each value. + + + Repeated fields and map fields are not handled by this class; use RepeatedField<T> + and MapField<TKey, TValue> to serialize such fields. + + + + + + Computes the number of bytes that would be needed to encode a + double field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + float field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + uint64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + int64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + int32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + fixed64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + fixed32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + bool field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + string field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + group field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + embedded message field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + bytes field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + uint32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a + enum field, including the tag. The caller is responsible for + converting the enum value to its numeric value. + + + + + Computes the number of bytes that would be needed to encode an + sfixed32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + sfixed64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + sint32 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode an + sint64 field, including the tag. + + + + + Computes the number of bytes that would be needed to encode a length, + as written by . + + + + + Computes the number of bytes that would be needed to encode a varint. + + + + + Computes the number of bytes that would be needed to encode a varint. + + + + + Computes the number of bytes that would be needed to encode a tag. + + + + + The buffer size used by CreateInstance(Stream). + + + + + Creates a new CodedOutputStream that writes directly to the given + byte array. If more bytes are written than fit in the array, + OutOfSpaceException will be thrown. + + + + + Creates a new CodedOutputStream that writes directly to the given + byte array slice. If more bytes are written than fit in the array, + OutOfSpaceException will be thrown. + + + + + Creates a new which write to the given stream, and disposes of that + stream when the returned CodedOutputStream is disposed. + + The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. + + + + Creates a new CodedOutputStream which write to the given stream and uses + the specified buffer size. + + The stream to write to. It will be disposed when the returned CodedOutputStream is disposed. + The size of buffer to use internally. + + + + Creates a new CodedOutputStream which write to the given stream. + + The stream to write to. + If true, is left open when the returned CodedOutputStream is disposed; + if false, the provided stream is disposed as well. + + + + Creates a new CodedOutputStream which write to the given stream and uses + the specified buffer size. + + The stream to write to. + The size of buffer to use internally. + If true, is left open when the returned CodedOutputStream is disposed; + if false, the provided stream is disposed as well. + + + + Returns the current position in the stream, or the position in the output buffer + + + + + Writes a double field value, without a tag, to the stream. + + The value to write + + + + Writes a float field value, without a tag, to the stream. + + The value to write + + + + Writes a uint64 field value, without a tag, to the stream. + + The value to write + + + + Writes an int64 field value, without a tag, to the stream. + + The value to write + + + + Writes an int32 field value, without a tag, to the stream. + + The value to write + + + + Writes a fixed64 field value, without a tag, to the stream. + + The value to write + + + + Writes a fixed32 field value, without a tag, to the stream. + + The value to write + + + + Writes a bool field value, without a tag, to the stream. + + The value to write + + + + Writes a string field value, without a tag, to the stream. + The data is length-prefixed. + + The value to write + + + + Writes a message, without a tag, to the stream. + The data is length-prefixed. + + The value to write + + + + Write a byte string, without a tag, to the stream. + The data is length-prefixed. + + The value to write + + + + Writes a uint32 value, without a tag, to the stream. + + The value to write + + + + Writes an enum value, without a tag, to the stream. + + The value to write + + + + Writes an sfixed32 value, without a tag, to the stream. + + The value to write. + + + + Writes an sfixed64 value, without a tag, to the stream. + + The value to write + + + + Writes an sint32 value, without a tag, to the stream. + + The value to write + + + + Writes an sint64 value, without a tag, to the stream. + + The value to write + + + + Writes a length (in bytes) for length-delimited data. + + + This method simply writes a rawint, but exists for clarity in calling code. + + Length value, in bytes. + + + + Encodes and writes a tag. + + The number of the field to write the tag for + The wire format type of the tag to write + + + + Writes an already-encoded tag. + + The encoded tag + + + + Writes the given single-byte tag directly to the stream. + + The encoded tag + + + + Writes the given two-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + + + + Writes the given three-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + The third byte of the encoded tag + + + + Writes the given four-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + The third byte of the encoded tag + The fourth byte of the encoded tag + + + + Writes the given five-byte tag directly to the stream. + + The first byte of the encoded tag + The second byte of the encoded tag + The third byte of the encoded tag + The fourth byte of the encoded tag + The fifth byte of the encoded tag + + + + Writes a 32 bit value as a varint. The fast route is taken when + there's enough buffer space left to whizz through without checking + for each byte; otherwise, we resort to calling WriteRawByte each time. + + + + + Writes out an array of bytes. + + + + + Writes out part of an array of bytes. + + + + + Encode a 32-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Encode a 64-bit value with ZigZag encoding. + + + ZigZag encodes signed integers into values that can be efficiently + encoded with varint. (Otherwise, negative values must be + sign-extended to 64 bits to be varint encoded, thus always taking + 10 bytes on the wire.) + + + + + Indicates that a CodedOutputStream wrapping a flat byte array + ran out of space. + + + + + Flushes any buffered data and optionally closes the underlying stream, if any. + + + + By default, any underlying stream is closed by this method. To configure this behaviour, + use a constructor overload with a leaveOpen parameter. If this instance does not + have an underlying stream, this method does nothing. + + + For the sake of efficiency, calling this method does not prevent future write calls - but + if a later write ends up writing to a stream which has been disposed, that is likely to + fail. It is recommend that you not call any other methods after this. + + + + + + Flushes any buffered data to the underlying stream (if there is one). + + + + + Verifies that SpaceLeft returns zero. It's common to create a byte array + that is exactly big enough to hold a message, then write to it with + a CodedOutputStream. Calling CheckNoSpaceLeft after writing verifies that + the message was actually as big as expected, which can help bugs. + + + + + If writing to a flat array, returns the space left in the array. Otherwise, + throws an InvalidOperationException. + + + + + Representation of a map field in a Protocol Buffer message. + + Key type in the map. Must be a type supported by Protocol Buffer map keys. + Value type in the map. Must be a type supported by Protocol Buffers. + + + For string keys, the equality comparison is provided by . + + + Null values are not permitted in the map, either for wrapper types or regular messages. + If a map is deserialized from a data stream and the value is missing from an entry, a default value + is created instead. For primitive types, that is the regular default value (0, the empty string and so + on); for message types, an empty instance of the message is created, as if the map entry contained a 0-length + encoded value for the field. + + + This implementation does not generally prohibit the use of key/value types which are not + supported by Protocol Buffers (e.g. using a key type of byte) but nor does it guarantee + that all operations will work in such cases. + + + The order in which entries are returned when iterating over this object is undefined, and may change + in future versions. + + + + + + Creates a deep clone of this object. + + + A deep clone of this object. + + + + + Adds the specified key/value pair to the map. + + + This operation fails if the key already exists in the map. To replace an existing entry, use the indexer. + + The key to add + The value to add. + The given key already exists in map. + + + + Determines whether the specified key is present in the map. + + The key to check. + true if the map contains the given key; false otherwise. + + + + Removes the entry identified by the given key from the map. + + The key indicating the entry to remove from the map. + true if the map contained the given key before the entry was removed; false otherwise. + + + + Gets the value associated with the specified key. + + The key whose value to get. + When this method returns, the value associated with the specified key, if the key is found; + otherwise, the default value for the type of the parameter. + This parameter is passed uninitialized. + true if the map contains an element with the specified key; otherwise, false. + + + + Gets or sets the value associated with the specified key. + + The key of the value to get or set. + The property is retrieved and key does not exist in the collection. + The value associated with the specified key. If the specified key is not found, + a get operation throws a , and a set operation creates a new element with the specified key. + + + + Gets a collection containing the keys in the map. + + + + + Gets a collection containing the values in the map. + + + + + Adds the specified entries to the map. The keys and values are not automatically cloned. + + The entries to add to the map. + + + + Returns an enumerator that iterates through the collection. + + + An enumerator that can be used to iterate through the collection. + + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Adds the specified item to the map. + + The item to add to the map. + + + + Removes all items from the map. + + + + + Determines whether map contains an entry equivalent to the given key/value pair. + + The key/value pair to find. + + + + + Copies the key/value pairs in this map to an array. + + The array to copy the entries into. + The index of the array at which to start copying values. + + + + Removes the specified key/value pair from the map. + + Both the key and the value must be found for the entry to be removed. + The key/value pair to remove. + true if the key/value pair was found and removed; false otherwise. + + + + Gets the number of elements contained in the map. + + + + + Gets a value indicating whether the map is read-only. + + + + + Determines whether the specified , is equal to this instance. + + The to compare with this instance. + + true if the specified is equal to this instance; otherwise, false. + + + + + Returns a hash code for this instance. + + + A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. + + + + + Compares this map with another for equality. + + + The order of the key/value pairs in the maps is not deemed significant in this comparison. + + The map to compare this with. + true if refers to an equal map; false otherwise. + + + + Adds entries to the map from the given stream. + + + It is assumed that the stream is initially positioned after the tag specified by the codec. + This method will continue reading entries from the stream until the end is reached, or + a different tag is encountered. + + Stream to read from + Codec describing how the key/value pairs are encoded + + + + Writes the contents of this map to the given coded output stream, using the specified codec + to encode each entry. + + The output stream to write to. + The codec to use for each entry. + + + + Calculates the size of this map based on the given entry codec. + + The codec to use to encode each entry. + + + + + Returns a string representation of this repeated field, in the same + way as it would be represented by the default JSON formatter. + + + + + A codec for a specific map field. This contains all the information required to encode and + decode the nested messages. + + + + + Creates a new entry codec based on a separate key codec and value codec, + and the tag to use for each map entry. + + The key codec. + The value codec. + The map tag to use to introduce each map entry. + + + + The tag used in the enclosing message to indicate map entries. + + + + + A mutable message class, used for parsing and serializing. This + delegates the work to a codec, but implements the interface + for interop with and . + This is nested inside Codec as it's tightly coupled to the associated codec, + and it's simpler if it has direct access to all its fields. + + + + + Read-only wrapper around another dictionary. + + + + + The contents of a repeated field: essentially, a collection with some extra + restrictions (no null values) and capabilities (deep cloning). + + + This implementation does not generally prohibit the use of types which are not + supported by Protocol Buffers but nor does it guarantee that all operations will work in such cases. + + The element type of the repeated field. + + + + Creates a deep clone of this repeated field. + + + If the field type is + a message type, each element is also cloned; otherwise, it is + assumed that the field type is primitive (including string and + bytes, both of which are immutable) and so a simple copy is + equivalent to a deep clone. + + A deep clone of this repeated field. + + + + Adds the entries from the given input stream, decoding them with the specified codec. + + The input stream to read from. + The codec to use in order to read each entry. + + + + Calculates the size of this collection based on the given codec. + + The codec to use when encoding each field. + The number of bytes that would be written to a by , + using the same codec. + + + + Writes the contents of this collection to the given , + encoding each value using the specified codec. + + The output stream to write to. + The codec to use when encoding each value. + + + + Adds the specified item to the collection. + + The item to add. + + + + Removes all items from the collection. + + + + + Determines whether this collection contains the given item. + + The item to find. + true if this collection contains the given item; false otherwise. + + + + Copies this collection to the given array. + + The array to copy to. + The first index of the array to copy to. + + + + Removes the specified item from the collection + + The item to remove. + true if the item was found and removed; false otherwise. + + + + Gets the number of elements contained in the collection. + + + + + Gets a value indicating whether the collection is read-only. + + + + + Adds all of the specified values into this collection. + + The values to add to this collection. + + + + Adds all of the specified values into this collection. This method is present to + allow repeated fields to be constructed from queries within collection initializers. + Within non-collection-initializer code, consider using the equivalent + method instead for clarity. + + The values to add to this collection. + + + + Returns an enumerator that iterates through the collection. + + + An enumerator that can be used to iterate through the collection. + + + + + Determines whether the specified , is equal to this instance. + + The to compare with this instance. + + true if the specified is equal to this instance; otherwise, false. + + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Returns a hash code for this instance. + + + A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. + + + + + Compares this repeated field with another for equality. + + The repeated field to compare this with. + true if refers to an equal repeated field; false otherwise. + + + + Returns the index of the given item within the collection, or -1 if the item is not + present. + + The item to find in the collection. + The zero-based index of the item, or -1 if it is not found. + + + + Inserts the given item at the specified index. + + The index at which to insert the item. + The item to insert. + + + + Removes the item at the given index. + + The zero-based index of the item to remove. + + + + Returns a string representation of this repeated field, in the same + way as it would be represented by the default JSON formatter. + + + + + Gets or sets the item at the specified index. + + + The element at the specified index. + + The zero-based index of the element to get or set. + The item at the specified index. + + + + Extension methods for , effectively providing + the familiar members from previous desktop framework versions while + targeting the newer releases, .NET Core etc. + + + + + Returns the public getter of a property, or null if there is no such getter + (either because it's read-only, or the getter isn't public). + + + + + Returns the public setter of a property, or null if there is no such setter + (either because it's write-only, or the setter isn't public). + + + + + Extension methods for in order to provide + backwards compatibility with .NET 3.5 + + + + + Write the contents of the current stream to the destination stream + + + + + Factory methods for . + + + + + Retrieves a codec suitable for a string field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a bytes field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a bool field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an int32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sint32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a fixed32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sfixed32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a uint32 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an int64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sint64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a fixed64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an sfixed64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a uint64 field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a float field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for a double field with the given tag. + + The tag. + A codec for the given tag. + + + + Retrieves a codec suitable for an enum field with the given tag. + + The tag. + A conversion function from to the enum type. + A conversion function from the enum type to . + A codec for the given tag. + + + + Retrieves a codec suitable for a message field with the given tag. + + The tag. + A parser to use for the message type. + A codec for the given tag. + + + + Creates a codec for a wrapper type of a class - which must be string or ByteString. + + + + + Creates a codec for a wrapper type of a struct - which must be Int32, Int64, UInt32, UInt64, + Bool, Single or Double. + + + + + Helper code to create codecs for wrapper types. + + + Somewhat ugly with all the static methods, but the conversions involved to/from nullable types make it + slightly tricky to improve. So long as we keep the public API (ForClassWrapper, ForStructWrapper) in place, + we can refactor later if we come up with something cleaner. + + + + + Returns a field codec which effectively wraps a value of type T in a message. + + + + + + + An encode/decode pair for a single field. This effectively encapsulates + all the information needed to read or write the field value from/to a coded + stream. + + + This class is public and has to be as it is used by generated code, but its public + API is very limited - just what the generated code needs to call directly. + + + + This never writes default values to the stream, and does not address "packedness" + in repeated fields itself, other than to know whether or not the field *should* be packed. + + + + + Returns a delegate to write a value (unconditionally) to a coded output stream. + + + + + Returns the size calculator for just a value. + + + + + Returns a delegate to read a value from a coded input stream. It is assumed that + the stream is already positioned on the appropriate tag. + + + + + Returns the fixed size for an entry, or 0 if sizes vary. + + + + + Gets the tag of the codec. + + + The tag of the codec. + + + + + Default value for this codec. Usually the same for every instance of the same type, but + for string/ByteString wrapper fields the codec's default value is null, whereas for + other string/ByteString fields it's "" or ByteString.Empty. + + + The default value of the codec's type. + + + + + Write a tag and the given value, *if* the value is not the default. + + + + + Reads a value of the codec type from the given . + + The input stream to read from. + The value read from the stream. + + + + Calculates the size required to write the given value, with a tag, + if the value is not the default. + + + + + Class containing helpful workarounds for various platform compatibility + + + + + A message type that has a custom string format for diagnostic purposes. + + + + Calling on a generated message type normally + returns the JSON representation. If a message type implements this interface, + then the method will be called instead of the regular + JSON formatting code, but only when ToString() is called either on the message itself + or on another message which contains it. This does not affect the normal JSON formatting of + the message. + + + For example, if you create a proto message representing a GUID, the internal + representation may be a bytes field or four fixed32 fields. However, when debugging + it may be more convenient to see a result in the same format as provides. + + This interface extends to avoid it accidentally being implemented + on types other than messages, where it would not be used by anything in the framework. + + + + + Returns a string representation of this object, for diagnostic purposes. + + + This method is called when a message is formatted as part of a + call. It does not affect the JSON representation used by other than + in calls to . While it is recommended + that the result is valid JSON, this is never assumed by the Protobuf library. + + A string representation of this object, for diagnostic purposes. + + + + Generic interface for a deeply cloneable type. + + + + All generated messages implement this interface, but so do some non-message types. + Additionally, due to the type constraint on T in , + it is simpler to keep this as a separate interface. + + + The type itself, returned by the method. + + + + Creates a deep clone of this object. + + A deep clone of this object. + + + + Interface for a Protocol Buffers message, supporting + basic operations required for serialization. + + + + + Merges the data from the specified coded input stream with the current message. + + See the user guide for precise merge semantics. + + + + + Writes the data to the given coded output stream. + + Coded output stream to write the data to. Must not be null. + + + + Calculates the size of this message in Protocol Buffer wire format, in bytes. + + The number of bytes required to write this message + to a coded output stream. + + + + Descriptor for this message. All instances are expected to return the same descriptor, + and for generated types this will be an explicitly-implemented member, returning the + same value as the static property declared on the type. + + + + + Generic interface for a Protocol Buffers message, + where the type parameter is expected to be the same type as + the implementation class. + + The message type. + + + + Merges the given message into this one. + + See the user guide for precise merge semantics. + The message to merge with this one. Must not be null. + + + + Thrown when an attempt is made to parse invalid JSON, e.g. using + a non-string property key, or including a redundant comma. Parsing a protocol buffer + message represented in JSON using can throw both this + exception and depending on the situation. This + exception is only thrown for "pure JSON" errors, whereas InvalidProtocolBufferException + is thrown when the JSON may be valid in and of itself, but cannot be parsed as a protocol buffer + message. + + + + + Thrown when a protocol message being parsed is invalid in some way, + e.g. it contains a malformed varint or a negative byte length. + + + + + Creates an exception for an error condition of an invalid tag being encountered. + + + + + Reflection-based converter from messages to JSON. + + + + Instances of this class are thread-safe, with no mutable state. + + + This is a simple start to get JSON formatting working. As it's reflection-based, + it's not as quick as baking calls into generated messages - but is a simpler implementation. + (This code is generally not heavily optimized.) + + + + + + Returns a formatter using the default settings. + + + + + The JSON representation of the first 160 characters of Unicode. + Empty strings are replaced by the static constructor. + + + + + Creates a new formatted with the given settings. + + The settings. + + + + Formats the specified message as JSON. + + The message to format. + The formatted message. + + + + Formats the specified message as JSON. + + The message to format. + The TextWriter to write the formatted message to. + The formatted message. + + + + Converts a message to JSON for diagnostic purposes with no extra context. + + + + This differs from calling on the default JSON + formatter in its handling of . As no type registry is available + in calls, the normal way of resolving the type of + an Any message cannot be applied. Instead, a JSON property named @value + is included with the base64 data from the property of the message. + + The value returned by this method is only designed to be used for diagnostic + purposes. It may not be parsable by , and may not be parsable + by other Protocol Buffer implementations. + + The message to format for diagnostic purposes. + The diagnostic-only JSON representation of the message + + + + Writes a single value to the given writer as JSON. Only types understood by + Protocol Buffers can be written in this way. This method is only exposed for + advanced use cases; most users should be using + or . + + The writer to write the value to. Must not be null. + The value to write. May be null. + + + + Central interception point for well-known type formatting. Any well-known types which + don't need special handling can fall back to WriteMessage. We avoid assuming that the + values are using the embedded well-known types, in order to allow for dynamic messages + in the future. + + + + + Writes a string (including leading and trailing double quotes) to a builder, escaping as required. + + + Other than surrogate pair handling, this code is mostly taken from src/google/protobuf/util/internal/json_escaping.cc. + + + + + Settings controlling JSON formatting. + + + + + Default settings, as used by + + + + + Whether fields whose values are the default for the field type (e.g. 0 for integers) + should be formatted (true) or omitted (false). + + + + + The type registry used to format messages. + + + + + Whether to format enums as ints. Defaults to false. + + + + + Creates a new object with the specified formatting of default values + and an empty type registry. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + + + + Creates a new object with the specified formatting of default values + and type registry. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + The to use when formatting messages. + + + + Creates a new object with the specified parameters. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + The to use when formatting messages. TypeRegistry.Empty will be used if it is null. + true to format the enums as integers; false to format enums as enum names. + + + + Creates a new object with the specified formatting of default values and the current settings. + + true if default values (0, empty strings etc) should be formatted; false otherwise. + + + + Creates a new object with the specified type registry and the current settings. + + The to use when formatting messages. + + + + Creates a new object with the specified enums formatting option and the current settings. + + true to format the enums as integers; false to format enums as enum names. + + + + Reflection-based converter from JSON to messages. + + + + Instances of this class are thread-safe, with no mutable state. + + + This is a simple start to get JSON parsing working. As it's reflection-based, + it's not as quick as baking calls into generated messages - but is a simpler implementation. + (This code is generally not heavily optimized.) + + + + + + Returns a formatter using the default settings. + + + + + Creates a new formatted with the given settings. + + The settings. + + + + Parses and merges the information into the given message. + + The message to merge the JSON information into. + The JSON to parse. + + + + Parses JSON read from and merges the information into the given message. + + The message to merge the JSON information into. + Reader providing the JSON to parse. + + + + Merges the given message using data from the given tokenizer. In most cases, the next + token should be a "start object" token, but wrapper types and nullity can invalidate + that assumption. This is implemented as an LL(1) recursive descent parser over the stream + of tokens provided by the tokenizer. This token stream is assumed to be valid JSON, with the + tokenizer performing that validation - but not every token stream is valid "protobuf JSON". + + + + + Parses into a new message. + + The type of message to create. + The JSON to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Parses JSON read from into a new message. + + The type of message to create. + Reader providing the JSON to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Parses into a new message. + + The JSON to parse. + Descriptor of message type to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Parses JSON read from into a new message. + + Reader providing the JSON to parse. + Descriptor of message type to parse. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Creates a new instance of the message type for the given field. + + + + + Checks that any infinite/NaN values originated from the correct text. + This corrects the lenient whitespace handling of double.Parse/float.Parse, as well as the + way that Mono parses out-of-range values as infinity. + + + + + Settings controlling JSON parsing. + + + + + Default settings, as used by . This has the same default + recursion limit as , and an empty type registry. + + + + + The maximum depth of messages to parse. Note that this limit only applies to parsing + messages, not collections - so a message within a collection within a message only counts as + depth 2, not 3. + + + + + The type registry used to parse messages. + + + + + Creates a new object with the specified recursion limit. + + The maximum depth of messages to parse + + + + Creates a new object with the specified recursion limit and type registry. + + The maximum depth of messages to parse + The type registry used to parse messages + + + + Simple but strict JSON tokenizer, rigidly following RFC 7159. + + + + This tokenizer is stateful, and only returns "useful" tokens - names, values etc. + It does not create tokens for the separator between names and values, or for the comma + between values. It validates the token stream as it goes - so callers can assume that the + tokens it produces are appropriate. For example, it would never produce "start object, end array." + + Implementation details: the base class handles single token push-back and + Not thread-safe. + + + + + Creates a tokenizer that reads from the given text reader. + + + + + Creates a tokenizer that first replays the given list of tokens, then continues reading + from another tokenizer. Note that if the returned tokenizer is "pushed back", that does not push back + on the continuation tokenizer, or vice versa. Care should be taken when using this method - it was + created for the sake of Any parsing. + + + + + Returns the depth of the stack, purely in objects (not collections). + Informally, this is the number of remaining unclosed '{' characters we have. + + + + + Returns the next JSON token in the stream. An EndDocument token is returned to indicate the end of the stream, + after which point Next() should not be called again. + + This implementation provides single-token buffering, and calls if there is no buffered token. + The next token in the stream. This is never null. + This method is called after an EndDocument token has been returned + The input text does not comply with RFC 7159 + + + + Returns the next JSON token in the stream, when requested by the base class. (The method delegates + to this if it doesn't have a buffered token.) + + This method is called after an EndDocument token has been returned + The input text does not comply with RFC 7159 + + + + Tokenizer which first exhausts a list of tokens, then consults another tokenizer. + + + + + Tokenizer which does all the *real* work of parsing JSON. + + + + + This method essentially just loops through characters skipping whitespace, validating and + changing state (e.g. from ObjectBeforeColon to ObjectAfterColon) + until it reaches something which will be a genuine token (e.g. a start object, or a value) at which point + it returns the token. Although the method is large, it would be relatively hard to break down further... most + of it is the large switch statement, which sometimes returns and sometimes doesn't. + + + + + Reads a string token. It is assumed that the opening " has already been read. + + + + + Reads an escaped character. It is assumed that the leading backslash has already been read. + + + + + Reads an escaped Unicode 4-nybble hex sequence. It is assumed that the leading \u has already been read. + + + + + Consumes a text-only literal, throwing an exception if the read text doesn't match it. + It is assumed that the first letter of the literal has already been read. + + + + + Validates that we're in a valid state to read a value (using the given error prefix if necessary) + and changes the state to the appropriate one, e.g. ObjectAfterColon to ObjectAfterProperty. + + + + + Pops the top-most container, and sets the state to the appropriate one for the end of a value + in the parent container. + + + + + Possible states of the tokenizer. + + + This is a flags enum purely so we can simply and efficiently represent a set of valid states + for checking. + + Each is documented with an example, + where ^ represents the current position within the text stream. The examples all use string values, + but could be any value, including nested objects/arrays. + The complete state of the tokenizer also includes a stack to indicate the contexts (arrays/objects). + Any additional notional state of "AfterValue" indicates that a value has been completed, at which + point there's an immediate transition to ExpectedEndOfDocument, ObjectAfterProperty or ArrayAfterValue. + + + These states were derived manually by reading RFC 7159 carefully. + + + + + + ^ { "foo": "bar" } + Before the value in a document. Next states: ObjectStart, ArrayStart, "AfterValue" + + + + + { "foo": "bar" } ^ + After the value in a document. Next states: ReaderExhausted + + + + + { "foo": "bar" } ^ (and already read to the end of the reader) + Terminal state. + + + + + { ^ "foo": "bar" } + Before the *first* property in an object. + Next states: + "AfterValue" (empty object) + ObjectBeforeColon (read a name) + + + + + { "foo" ^ : "bar", "x": "y" } + Next state: ObjectAfterColon + + + + + { "foo" : ^ "bar", "x": "y" } + Before any property other than the first in an object. + (Equivalently: after any property in an object) + Next states: + "AfterValue" (value is simple) + ObjectStart (value is object) + ArrayStart (value is array) + + + + + { "foo" : "bar" ^ , "x" : "y" } + At the end of a property, so expecting either a comma or end-of-object + Next states: ObjectAfterComma or "AfterValue" + + + + + { "foo":"bar", ^ "x":"y" } + Read the comma after the previous property, so expecting another property. + This is like ObjectStart, but closing brace isn't valid here + Next state: ObjectBeforeColon. + + + + + [ ^ "foo", "bar" ] + Before the *first* value in an array. + Next states: + "AfterValue" (read a value) + "AfterValue" (end of array; will pop stack) + + + + + [ "foo" ^ , "bar" ] + After any value in an array, so expecting either a comma or end-of-array + Next states: ArrayAfterComma or "AfterValue" + + + + + [ "foo", ^ "bar" ] + After a comma in an array, so there *must* be another value (simple or complex). + Next states: "AfterValue" (simple value), StartObject, StartArray + + + + + Wrapper around a text reader allowing small amounts of buffering and location handling. + + + + + The buffered next character, if we have one. + + + + + Returns the next character in the stream, or null if we have reached the end. + + + + + + Creates a new exception appropriate for the current state of the reader. + + + + + Stream implementation which proxies another stream, only allowing a certain amount + of data to be read. Note that this is only used to read delimited streams, so it + doesn't attempt to implement everything. + + + + + Extension methods on and . + + + + + Merges data from the given byte array into an existing message. + + The message to merge the data into. + The data to merge, which must be protobuf-encoded binary data. + + + + Merges data from the given byte string into an existing message. + + The message to merge the data into. + The data to merge, which must be protobuf-encoded binary data. + + + + Merges data from the given stream into an existing message. + + The message to merge the data into. + Stream containing the data to merge, which must be protobuf-encoded binary data. + + + + Merges length-delimited data from the given stream into an existing message. + + + The stream is expected to contain a length and then the data. Only the amount of data + specified by the length will be consumed. + + The message to merge the data into. + Stream containing the data to merge, which must be protobuf-encoded binary data. + + + + Converts the given message into a byte array in protobuf encoding. + + The message to convert. + The message data as a byte array. + + + + Writes the given message data to the given stream in protobuf encoding. + + The message to write to the stream. + The stream to write to. + + + + Writes the length and then data of the given message to a stream. + + The message to write. + The output stream to write to. + + + + Converts the given message into a byte string in protobuf encoding. + + The message to convert. + The message data as a byte string. + + + + A general message parser, typically used by reflection-based code as all the methods + return simple . + + + + + Creates a template instance ready for population. + + An empty message. + + + + Parses a message from a byte array. + + The byte array containing the message. Must not be null. + The newly parsed message. + + + + Parses a message from the given byte string. + + The data to parse. + The parsed message. + + + + Parses a message from the given stream. + + The stream to parse. + The parsed message. + + + + Parses a length-delimited message from the given stream. + + + The stream is expected to contain a length and then the data. Only the amount of data + specified by the length will be consumed. + + The stream to parse. + The parsed message. + + + + Parses a message from the given coded input stream. + + The stream to parse. + The parsed message. + + + + Parses a message from the given JSON. + + The JSON to parse. + The parsed message. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + A parser for a specific message type. + + +

+ This delegates most behavior to the + implementation within the original type, but + provides convenient overloads to parse from a variety of sources. +

+

+ Most applications will never need to create their own instances of this type; + instead, use the static Parser property of a generated message type to obtain a + parser for that type. +

+
+ The type of message to be parsed. +
+ + + Creates a new parser. + + + The factory method is effectively an optimization over using a generic constraint + to require a parameterless constructor: delegates are significantly faster to execute. + + Function to invoke when a new, empty message is required. + + + + Creates a template instance ready for population. + + An empty message. + + + + Parses a message from a byte array. + + The byte array containing the message. Must not be null. + The newly parsed message. + + + + Parses a message from the given byte string. + + The data to parse. + The parsed message. + + + + Parses a message from the given stream. + + The stream to parse. + The parsed message. + + + + Parses a length-delimited message from the given stream. + + + The stream is expected to contain a length and then the data. Only the amount of data + specified by the length will be consumed. + + The stream to parse. + The parsed message. + + + + Parses a message from the given coded input stream. + + The stream to parse. + The parsed message. + + + + Parses a message from the given JSON. + + The JSON to parse. + The parsed message. + The JSON does not comply with RFC 7159 + The JSON does not represent a Protocol Buffers message correctly + + + + Helper methods for throwing exceptions when preconditions are not met. + + + This class is used internally and by generated code; it is not particularly + expected to be used from application code, although nothing prevents it + from being used that way. + + + + + Throws an ArgumentNullException if the given value is null, otherwise + return the value to the caller. + + + + + Throws an ArgumentNullException if the given value is null, otherwise + return the value to the caller. + + + This is equivalent to but without the type parameter + constraint. In most cases, the constraint is useful to prevent you from calling CheckNotNull + with a value type - but it gets in the way if either you want to use it with a nullable + value type, or you want to use it with an unconstrained type parameter. + + + + + Container for a set of custom options specified within a message, field etc. + + + + This type is publicly immutable, but internally mutable. It is only populated + by the descriptor parsing code - by the time any user code is able to see an instance, + it will be fully initialized. + + + If an option is requested using the incorrect method, an answer may still be returned: all + of the numeric types are represented internally using 64-bit integers, for example. It is up to + the caller to ensure that they make the appropriate method call for the option they're interested in. + Note that enum options are simply stored as integers, so the value should be fetched using + and then cast appropriately. + + + Repeated options are currently not supported. Asking for a single value of an option + which was actually repeated will return the last value, except for message types where + all the set values are merged together. + + + + + + Singleton for all descriptors with an empty set of options. + + + + + A sequence of values per field. This needs to be per field rather than per tag to allow correct deserialization + of repeated fields which could be "int, ByteString, int" - unlikely as that is. The fact that values are boxed + is unfortunate; we might be able to use a struct instead, and we could combine uint and ulong values. + + + + + Retrieves a Boolean value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 32-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 64-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 32-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 64-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 32-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 64-bit integer value for the specified option field, + assuming a fixed-length representation. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 32-bit integer value for the specified option field, + assuming a zigzag encoding. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a signed 64-bit integer value for the specified option field, + assuming a zigzag encoding. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 32-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves an unsigned 64-bit integer value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a 32-bit floating point value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a 64-bit floating point value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a string value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a bytes value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Retrieves a message value for the specified option field. + + The field to fetch the value for. + The output variable to populate. + true if a suitable value for the field was found; false otherwise. + + + + Reads an unknown field, either parsing it and storing it or skipping it. + + + If the current set of options is empty and we manage to read a field, a new set of options + will be created and returned. Otherwise, the return value is this. This allows + us to start with a singleton empty set of options and just create new ones where necessary. + + Input stream to read from. + The resulting set of custom options, either this or a new set. + + + + All field values can be stored as a byte string or a 64-bit integer. + This struct avoids unnecessary boxing. + + + + Holder for reflection information generated from google/protobuf/descriptor.proto + + + File descriptor for google/protobuf/descriptor.proto + + + + The protocol compiler can output a FileDescriptorSet containing the .proto + files it parses. + + + + Field number for the "file" field. + + + + Describes a complete .proto file. + + + + Field number for the "name" field. + + + + file name, relative to root of source tree + + + + Field number for the "package" field. + + + + e.g. "foo", "foo.bar", etc. + + + + Field number for the "dependency" field. + + + + Names of files imported by this file. + + + + Field number for the "public_dependency" field. + + + + Indexes of the public imported files in the dependency list above. + + + + Field number for the "weak_dependency" field. + + + + Indexes of the weak imported files in the dependency list. + For Google-internal migration only. Do not use. + + + + Field number for the "message_type" field. + + + + All top-level definitions in this file. + + + + Field number for the "enum_type" field. + + + Field number for the "service" field. + + + Field number for the "extension" field. + + + Field number for the "options" field. + + + Field number for the "source_code_info" field. + + + + This field contains optional information about the original source code. + You may safely remove this entire field without harming runtime + functionality of the descriptors -- the information is needed only by + development tools. + + + + Field number for the "syntax" field. + + + + The syntax of the proto file. + The supported values are "proto2" and "proto3". + + + + + Describes a message type. + + + + Field number for the "name" field. + + + Field number for the "field" field. + + + Field number for the "extension" field. + + + Field number for the "nested_type" field. + + + Field number for the "enum_type" field. + + + Field number for the "extension_range" field. + + + Field number for the "oneof_decl" field. + + + Field number for the "options" field. + + + Field number for the "reserved_range" field. + + + Field number for the "reserved_name" field. + + + + Reserved field names, which may not be used by fields in the same message. + A given name may only be reserved once. + + + + Container for nested types declared in the DescriptorProto message type. + + + Field number for the "start" field. + + + Field number for the "end" field. + + + + Range of reserved tag numbers. Reserved tag numbers may not be used by + fields or extension ranges in the same message. Reserved ranges may + not overlap. + + + + Field number for the "start" field. + + + + Inclusive. + + + + Field number for the "end" field. + + + + Exclusive. + + + + + Describes a field within a message. + + + + Field number for the "name" field. + + + Field number for the "number" field. + + + Field number for the "label" field. + + + Field number for the "type" field. + + + + If type_name is set, this need not be set. If both this and type_name + are set, this must be one of TYPE_ENUM, TYPE_MESSAGE or TYPE_GROUP. + + + + Field number for the "type_name" field. + + + + For message and enum types, this is the name of the type. If the name + starts with a '.', it is fully-qualified. Otherwise, C++-like scoping + rules are used to find the type (i.e. first the nested types within this + message are searched, then within the parent, on up to the root + namespace). + + + + Field number for the "extendee" field. + + + + For extensions, this is the name of the type being extended. It is + resolved in the same manner as type_name. + + + + Field number for the "default_value" field. + + + + For numeric types, contains the original text representation of the value. + For booleans, "true" or "false". + For strings, contains the default text contents (not escaped in any way). + For bytes, contains the C escaped value. All bytes >= 128 are escaped. + TODO(kenton): Base-64 encode? + + + + Field number for the "oneof_index" field. + + + + If set, gives the index of a oneof in the containing type's oneof_decl + list. This field is a member of that oneof. + + + + Field number for the "json_name" field. + + + + JSON name of this field. The value is set by protocol compiler. If the + user has set a "json_name" option on this field, that option's value + will be used. Otherwise, it's deduced from the field's name by converting + it to camelCase. + + + + Field number for the "options" field. + + + Container for nested types declared in the FieldDescriptorProto message type. + + + + 0 is reserved for errors. + Order is weird for historical reasons. + + + + + Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT64 if + negative values are likely. + + + + + Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT32 if + negative values are likely. + + + + + Tag-delimited aggregate. + Group type is deprecated and not supported in proto3. However, Proto3 + implementations should still be able to parse the group wire format and + treat group fields as unknown fields. + + + + + Length-delimited aggregate. + + + + + New in version 2. + + + + + Uses ZigZag encoding. + + + + + Uses ZigZag encoding. + + + + + 0 is reserved for errors + + + + + Describes a oneof. + + + + Field number for the "name" field. + + + Field number for the "options" field. + + + + Describes an enum type. + + + + Field number for the "name" field. + + + Field number for the "value" field. + + + Field number for the "options" field. + + + + Describes a value within an enum. + + + + Field number for the "name" field. + + + Field number for the "number" field. + + + Field number for the "options" field. + + + + Describes a service. + + + + Field number for the "name" field. + + + Field number for the "method" field. + + + Field number for the "options" field. + + + + Describes a method of a service. + + + + Field number for the "name" field. + + + Field number for the "input_type" field. + + + + Input and output type names. These are resolved in the same way as + FieldDescriptorProto.type_name, but must refer to a message type. + + + + Field number for the "output_type" field. + + + Field number for the "options" field. + + + Field number for the "client_streaming" field. + + + + Identifies if client streams multiple client messages + + + + Field number for the "server_streaming" field. + + + + Identifies if server streams multiple server messages + + + + Field number for the "java_package" field. + + + + Sets the Java package where classes generated from this .proto will be + placed. By default, the proto package is used, but this is often + inappropriate because proto packages do not normally start with backwards + domain names. + + + + Field number for the "java_outer_classname" field. + + + + If set, all the classes from the .proto file are wrapped in a single + outer class with the given name. This applies to both Proto1 + (equivalent to the old "--one_java_file" option) and Proto2 (where + a .proto always translates to a single class, but you may want to + explicitly choose the class name). + + + + Field number for the "java_multiple_files" field. + + + + If set true, then the Java code generator will generate a separate .java + file for each top-level message, enum, and service defined in the .proto + file. Thus, these types will *not* be nested inside the outer class + named by java_outer_classname. However, the outer class will still be + generated to contain the file's getDescriptor() method as well as any + top-level extensions defined in the file. + + + + Field number for the "java_generate_equals_and_hash" field. + + + + This option does nothing. + + + + Field number for the "java_string_check_utf8" field. + + + + If set true, then the Java2 code generator will generate code that + throws an exception whenever an attempt is made to assign a non-UTF-8 + byte sequence to a string field. + Message reflection will do the same. + However, an extension field still accepts non-UTF-8 byte sequences. + This option has no effect on when used with the lite runtime. + + + + Field number for the "optimize_for" field. + + + Field number for the "go_package" field. + + + + Sets the Go package where structs generated from this .proto will be + placed. If omitted, the Go package will be derived from the following: + - The basename of the package import path, if provided. + - Otherwise, the package statement in the .proto file, if present. + - Otherwise, the basename of the .proto file, without extension. + + + + Field number for the "cc_generic_services" field. + + + + Should generic services be generated in each language? "Generic" services + are not specific to any particular RPC system. They are generated by the + main code generators in each language (without additional plugins). + Generic services were the only kind of service generation supported by + early versions of google.protobuf. + + Generic services are now considered deprecated in favor of using plugins + that generate code specific to your particular RPC system. Therefore, + these default to false. Old code which depends on generic services should + explicitly set them to true. + + + + Field number for the "java_generic_services" field. + + + Field number for the "py_generic_services" field. + + + Field number for the "deprecated" field. + + + + Is this file deprecated? + Depending on the target platform, this can emit Deprecated annotations + for everything in the file, or it will be completely ignored; in the very + least, this is a formalization for deprecating files. + + + + Field number for the "cc_enable_arenas" field. + + + + Enables the use of arenas for the proto messages in this file. This applies + only to generated classes for C++. + + + + Field number for the "objc_class_prefix" field. + + + + Sets the objective c class prefix which is prepended to all objective c + generated classes from this .proto. There is no default. + + + + Field number for the "csharp_namespace" field. + + + + Namespace for generated classes; defaults to the package. + + + + Field number for the "swift_prefix" field. + + + + By default Swift generators will take the proto package and CamelCase it + replacing '.' with underscore and use that to prefix the types/symbols + defined. When this options is provided, they will use this value instead + to prefix the types/symbols defined. + + + + Field number for the "php_class_prefix" field. + + + + Sets the php class prefix which is prepended to all php generated classes + from this .proto. Default is empty. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Container for nested types declared in the FileOptions message type. + + + + Generated classes can be optimized for speed or code size. + + + + + Generate complete code for parsing, serialization, + + + + + etc. + + + + + Generate code using MessageLite and the lite runtime. + + + + Field number for the "message_set_wire_format" field. + + + + Set true to use the old proto1 MessageSet wire format for extensions. + This is provided for backwards-compatibility with the MessageSet wire + format. You should not use this for any other reason: It's less + efficient, has fewer features, and is more complicated. + + The message must be defined exactly as follows: + message Foo { + option message_set_wire_format = true; + extensions 4 to max; + } + Note that the message cannot have any defined fields; MessageSets only + have extensions. + + All extensions of your type must be singular messages; e.g. they cannot + be int32s, enums, or repeated messages. + + Because this is an option, the above two restrictions are not enforced by + the protocol compiler. + + + + Field number for the "no_standard_descriptor_accessor" field. + + + + Disables the generation of the standard "descriptor()" accessor, which can + conflict with a field of the same name. This is meant to make migration + from proto1 easier; new code should avoid fields named "descriptor". + + + + Field number for the "deprecated" field. + + + + Is this message deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the message, or it will be completely ignored; in the very least, + this is a formalization for deprecating messages. + + + + Field number for the "map_entry" field. + + + + Whether the message is an automatically generated map entry type for the + maps field. + + For maps fields: + map<KeyType, ValueType> map_field = 1; + The parsed descriptor looks like: + message MapFieldEntry { + option map_entry = true; + optional KeyType key = 1; + optional ValueType value = 2; + } + repeated MapFieldEntry map_field = 1; + + Implementations may choose not to generate the map_entry=true message, but + use a native map in the target language to hold the keys and values. + The reflection APIs in such implementions still need to work as + if the field is a repeated message field. + + NOTE: Do not set the option in .proto files. Always use the maps syntax + instead. The option should only be implicitly set by the proto compiler + parser. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "ctype" field. + + + + The ctype option instructs the C++ code generator to use a different + representation of the field than it normally would. See the specific + options below. This option is not yet implemented in the open source + release -- sorry, we'll try to include it in a future version! + + + + Field number for the "packed" field. + + + + The packed option can be enabled for repeated primitive fields to enable + a more efficient representation on the wire. Rather than repeatedly + writing the tag and type for each element, the entire array is encoded as + a single length-delimited blob. In proto3, only explicit setting it to + false will avoid using packed encoding. + + + + Field number for the "jstype" field. + + + + The jstype option determines the JavaScript type used for values of the + field. The option is permitted only for 64 bit integral and fixed types + (int64, uint64, sint64, fixed64, sfixed64). By default these types are + represented as JavaScript strings. This avoids loss of precision that can + happen when a large value is converted to a floating point JavaScript + numbers. Specifying JS_NUMBER for the jstype causes the generated + JavaScript code to use the JavaScript "number" type instead of strings. + This option is an enum to permit additional types to be added, + e.g. goog.math.Integer. + + + + Field number for the "lazy" field. + + + + Should this field be parsed lazily? Lazy applies only to message-type + fields. It means that when the outer message is initially parsed, the + inner message's contents will not be parsed but instead stored in encoded + form. The inner message will actually be parsed when it is first accessed. + + This is only a hint. Implementations are free to choose whether to use + eager or lazy parsing regardless of the value of this option. However, + setting this option true suggests that the protocol author believes that + using lazy parsing on this field is worth the additional bookkeeping + overhead typically needed to implement it. + + This option does not affect the public interface of any generated code; + all method signatures remain the same. Furthermore, thread-safety of the + interface is not affected by this option; const methods remain safe to + call from multiple threads concurrently, while non-const methods continue + to require exclusive access. + + Note that implementations may choose not to check required fields within + a lazy sub-message. That is, calling IsInitialized() on the outer message + may return true even if the inner message has missing required fields. + This is necessary because otherwise the inner message would have to be + parsed in order to perform the check, defeating the purpose of lazy + parsing. An implementation which chooses not to check required fields + must be consistent about it. That is, for any particular sub-message, the + implementation must either *always* check its required fields, or *never* + check its required fields, regardless of whether or not the message has + been parsed. + + + + Field number for the "deprecated" field. + + + + Is this field deprecated? + Depending on the target platform, this can emit Deprecated annotations + for accessors, or it will be completely ignored; in the very least, this + is a formalization for deprecating fields. + + + + Field number for the "weak" field. + + + + For Google-internal migration only. Do not use. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Container for nested types declared in the FieldOptions message type. + + + + Default mode. + + + + + Use the default type. + + + + + Use JavaScript strings. + + + + + Use JavaScript numbers. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "allow_alias" field. + + + + Set this option to true to allow mapping different tag names to the same + value. + + + + Field number for the "deprecated" field. + + + + Is this enum deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the enum, or it will be completely ignored; in the very least, this + is a formalization for deprecating enums. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "deprecated" field. + + + + Is this enum value deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the enum value, or it will be completely ignored; in the very least, + this is a formalization for deprecating enum values. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "deprecated" field. + + + + Is this service deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the service, or it will be completely ignored; in the very least, + this is a formalization for deprecating services. + + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Field number for the "deprecated" field. + + + + Is this method deprecated? + Depending on the target platform, this can emit Deprecated annotations + for the method, or it will be completely ignored; in the very least, + this is a formalization for deprecating methods. + + + + Field number for the "idempotency_level" field. + + + Field number for the "uninterpreted_option" field. + + + + The parser stores options it doesn't recognize here. See above. + + + + Container for nested types declared in the MethodOptions message type. + + + + Is this method side-effect-free (or safe in HTTP parlance), or idempotent, + or neither? HTTP based RPC implementation may choose GET verb for safe + methods, and PUT verb for idempotent methods instead of the default POST. + + + + + implies idempotent + + + + + idempotent, but may have side effects + + + + + A message representing a option the parser does not recognize. This only + appears in options protos created by the compiler::Parser class. + DescriptorPool resolves these when building Descriptor objects. Therefore, + options protos in descriptor objects (e.g. returned by Descriptor::options(), + or produced by Descriptor::CopyTo()) will never have UninterpretedOptions + in them. + + + + Field number for the "name" field. + + + Field number for the "identifier_value" field. + + + + The value of the uninterpreted option, in whatever type the tokenizer + identified it as during parsing. Exactly one of these should be set. + + + + Field number for the "positive_int_value" field. + + + Field number for the "negative_int_value" field. + + + Field number for the "double_value" field. + + + Field number for the "string_value" field. + + + Field number for the "aggregate_value" field. + + + Container for nested types declared in the UninterpretedOption message type. + + + + The name of the uninterpreted option. Each string represents a segment in + a dot-separated name. is_extension is true iff a segment represents an + extension (denoted with parentheses in options specs in .proto files). + E.g.,{ ["foo", false], ["bar.baz", true], ["qux", false] } represents + "foo.(bar.baz).qux". + + + + Field number for the "name_part" field. + + + Field number for the "is_extension" field. + + + + Encapsulates information about the original source file from which a + FileDescriptorProto was generated. + + + + Field number for the "location" field. + + + + A Location identifies a piece of source code in a .proto file which + corresponds to a particular definition. This information is intended + to be useful to IDEs, code indexers, documentation generators, and similar + tools. + + For example, say we have a file like: + message Foo { + optional string foo = 1; + } + Let's look at just the field definition: + optional string foo = 1; + ^ ^^ ^^ ^ ^^^ + a bc de f ghi + We have the following locations: + span path represents + [a,i) [ 4, 0, 2, 0 ] The whole field definition. + [a,b) [ 4, 0, 2, 0, 4 ] The label (optional). + [c,d) [ 4, 0, 2, 0, 5 ] The type (string). + [e,f) [ 4, 0, 2, 0, 1 ] The name (foo). + [g,h) [ 4, 0, 2, 0, 3 ] The number (1). + + Notes: + - A location may refer to a repeated field itself (i.e. not to any + particular index within it). This is used whenever a set of elements are + logically enclosed in a single code segment. For example, an entire + extend block (possibly containing multiple extension definitions) will + have an outer location whose path refers to the "extensions" repeated + field without an index. + - Multiple locations may have the same path. This happens when a single + logical declaration is spread out across multiple places. The most + obvious example is the "extend" block again -- there may be multiple + extend blocks in the same scope, each of which will have the same path. + - A location's span is not always a subset of its parent's span. For + example, the "extendee" of an extension declaration appears at the + beginning of the "extend" block and is shared by all extensions within + the block. + - Just because a location's span is a subset of some other location's span + does not mean that it is a descendent. For example, a "group" defines + both a type and a field in a single declaration. Thus, the locations + corresponding to the type and field and their components will overlap. + - Code which tries to interpret locations should probably be designed to + ignore those that it doesn't understand, as more types of locations could + be recorded in the future. + + + + Container for nested types declared in the SourceCodeInfo message type. + + + Field number for the "path" field. + + + + Identifies which part of the FileDescriptorProto was defined at this + location. + + Each element is a field number or an index. They form a path from + the root FileDescriptorProto to the place where the definition. For + example, this path: + [ 4, 3, 2, 7, 1 ] + refers to: + file.message_type(3) // 4, 3 + .field(7) // 2, 7 + .name() // 1 + This is because FileDescriptorProto.message_type has field number 4: + repeated DescriptorProto message_type = 4; + and DescriptorProto.field has field number 2: + repeated FieldDescriptorProto field = 2; + and FieldDescriptorProto.name has field number 1: + optional string name = 1; + + Thus, the above path gives the location of a field name. If we removed + the last element: + [ 4, 3, 2, 7 ] + this path refers to the whole field declaration (from the beginning + of the label to the terminating semicolon). + + + + Field number for the "span" field. + + + + Always has exactly three or four elements: start line, start column, + end line (optional, otherwise assumed same as start line), end column. + These are packed into a single field for efficiency. Note that line + and column numbers are zero-based -- typically you will want to add + 1 to each before displaying to a user. + + + + Field number for the "leading_comments" field. + + + + If this SourceCodeInfo represents a complete declaration, these are any + comments appearing before and after the declaration which appear to be + attached to the declaration. + + A series of line comments appearing on consecutive lines, with no other + tokens appearing on those lines, will be treated as a single comment. + + leading_detached_comments will keep paragraphs of comments that appear + before (but not connected to) the current element. Each paragraph, + separated by empty lines, will be one comment element in the repeated + field. + + Only the comment content is provided; comment markers (e.g. //) are + stripped out. For block comments, leading whitespace and an asterisk + will be stripped from the beginning of each line other than the first. + Newlines are included in the output. + + Examples: + + optional int32 foo = 1; // Comment attached to foo. + // Comment attached to bar. + optional int32 bar = 2; + + optional string baz = 3; + // Comment attached to baz. + // Another line attached to baz. + + // Comment attached to qux. + // + // Another line attached to qux. + optional double qux = 4; + + // Detached comment for corge. This is not leading or trailing comments + // to qux or corge because there are blank lines separating it from + // both. + + // Detached comment for corge paragraph 2. + + optional string corge = 5; + /* Block comment attached + * to corge. Leading asterisks + * will be removed. */ + /* Block comment attached to + * grault. */ + optional int32 grault = 6; + + // ignored detached comments. + + + + Field number for the "trailing_comments" field. + + + Field number for the "leading_detached_comments" field. + + + + Describes the relationship between generated code and its original source + file. A GeneratedCodeInfo message is associated with only one generated + source file, but may contain references to different source .proto files. + + + + Field number for the "annotation" field. + + + + An Annotation connects some span of text in generated code to an element + of its generating .proto file. + + + + Container for nested types declared in the GeneratedCodeInfo message type. + + + Field number for the "path" field. + + + + Identifies the element in the original source .proto file. This field + is formatted the same as SourceCodeInfo.Location.path. + + + + Field number for the "source_file" field. + + + + Identifies the filesystem path to the original source .proto. + + + + Field number for the "begin" field. + + + + Identifies the starting offset in bytes in the generated code + that relates to the identified object. + + + + Field number for the "end" field. + + + + Identifies the ending offset in bytes in the generated code that + relates to the identified offset. The end offset should be one past + the last relevant byte (so the length of the text = end - begin). + + + + + Base class for nearly all descriptors, providing common functionality. + + + + + The index of this descriptor within its parent descriptor. + + + This returns the index of this descriptor within its parent, for + this descriptor's type. (There can be duplicate values for different + types, e.g. one enum type with index 0 and one message type with index 0.) + + + + + Returns the name of the entity (field, message etc) being described. + + + + + The fully qualified name of the descriptor's target. + + + + + The file this descriptor was declared in. + + + + + Contains lookup tables containing all the descriptors defined in a particular file. + + + + + Finds a symbol of the given name within the pool. + + The type of symbol to look for + Fully-qualified name to look up + The symbol with the given name and type, + or null if the symbol doesn't exist or has the wrong type + + + + Adds a package to the symbol tables. If a package by the same name + already exists, that is fine, but if some other kind of symbol + exists under the same name, an exception is thrown. If the package + has multiple components, this also adds the parent package(s). + + + + + Adds a symbol to the symbol table. + + The symbol already existed + in the symbol table. + + + + Verifies that the descriptor's name is valid (i.e. it contains + only letters, digits and underscores, and does not start with a digit). + + + + + + Returns the field with the given number in the given descriptor, + or null if it can't be found. + + + + + Adds a field to the fieldsByNumber table. + + A field with the same + containing type and number already exists. + + + + Adds an enum value to the enumValuesByNumber table. If an enum value + with the same type and number already exists, this method does nothing. + (This is allowed; the first value defined with the number takes precedence.) + + + + + Looks up a descriptor by name, relative to some other descriptor. + The name may be fully-qualified (with a leading '.'), partially-qualified, + or unqualified. C++-like name lookup semantics are used to search for the + matching descriptor. + + + This isn't heavily optimized, but it's only used during cross linking anyway. + If it starts being used more widely, we should look at performance more carefully. + + + + + Struct used to hold the keys for the fieldByNumber table. + + + + + Internal class containing utility methods when working with descriptors. + + + + + Equivalent to Func[TInput, int, TOutput] but usable in .NET 2.0. Only used to convert + arrays. + + + + + Converts the given array into a read-only list, applying the specified conversion to + each input element. + + + + + Thrown when building descriptors fails because the source DescriptorProtos + are not valid. + + + + + The full name of the descriptor where the error occurred. + + + + + A human-readable description of the error. (The Message property + is made up of the descriptor's name and this description.) + + + + + Descriptor for an enum type in a .proto file. + + + + + The brief name of the descriptor's target. + + + + + The CLR type for this enum. For generated code, this will be a CLR enum type. + + + + + If this is a nested type, get the outer descriptor, otherwise null. + + + + + An unmodifiable list of defined value descriptors for this enum. + + + + + Finds an enum value by number. If multiple enum values have the + same number, this returns the first defined value with that number. + If there is no value for the given number, this returns null. + + + + + Finds an enum value by name. + + The unqualified name of the value (e.g. "FOO"). + The value's descriptor, or null if not found. + + + + The (possibly empty) set of custom options for this enum. + + + + + Descriptor for a single enum value within an enum in a .proto file. + + + + + Returns the name of the enum value described by this object. + + + + + Returns the number associated with this enum value. + + + + + Returns the enum descriptor that this value is part of. + + + + + The (possibly empty) set of custom options for this enum value. + + + + + Base class for field accessors. + + + + + Descriptor for a field or extension within a message in a .proto file. + + + + + Get the field's containing message type. + + + + + Returns the oneof containing this field, or null if it is not part of a oneof. + + + + + The effective JSON name for this field. This is usually the lower-camel-cased form of the field name, + but can be overridden using the json_name option in the .proto file. + + + + + The brief name of the descriptor's target. + + + + + Returns the accessor for this field. + + + + While a describes the field, it does not provide + any way of obtaining or changing the value of the field within a specific message; + that is the responsibility of the accessor. + + + The value returned by this property will be non-null for all regular fields. However, + if a message containing a map field is introspected, the list of nested messages will include + an auto-generated nested key/value pair message for the field. This is not represented in any + generated type, and the value of the map field itself is represented by a dictionary in the + reflection API. There are never instances of those "hidden" messages, so no accessor is provided + and this property will return null. + + + + + + Maps a field type as included in the .proto file to a FieldType. + + + + + Returns true if this field is a repeated field; false otherwise. + + + + + Returns true if this field is a map field; false otherwise. + + + + + Returns true if this field is a packed, repeated field; false otherwise. + + + + + Returns the type of the field. + + + + + Returns the field number declared in the proto file. + + + + + Compares this descriptor with another one, ordering in "canonical" order + which simply means ascending order by field number. + must be a field of the same type, i.e. the of + both fields must be the same. + + + + + For enum fields, returns the field's type. + + + + + For embedded message and group fields, returns the field's type. + + + + + The (possibly empty) set of custom options for this field. + + + + + Look up and cross-link all field types etc. + + + + + Enumeration of all the possible field types. + + + + + The double field type. + + + + + The float field type. + + + + + The int64 field type. + + + + + The uint64 field type. + + + + + The int32 field type. + + + + + The fixed64 field type. + + + + + The fixed32 field type. + + + + + The bool field type. + + + + + The string field type. + + + + + The field type used for groups (not supported in this implementation). + + + + + The field type used for message fields. + + + + + The bytes field type. + + + + + The uint32 field type. + + + + + The sfixed32 field type. + + + + + The sfixed64 field type. + + + + + The sint32 field type. + + + + + The sint64 field type. + + + + + The field type used for enum fields. + + + + + Describes a .proto file, including everything defined within. + IDescriptor is implemented such that the File property returns this descriptor, + and the FullName is the same as the Name. + + + + + Computes the full name of a descriptor within this file, with an optional parent message. + + + + + Extracts public dependencies from direct dependencies. This is a static method despite its + first parameter, as the value we're in the middle of constructing is only used for exceptions. + + + + + The descriptor in its protocol message representation. + + + + + The file name. + + + + + The package as declared in the .proto file. This may or may not + be equivalent to the .NET namespace of the generated classes. + + + + + Unmodifiable list of top-level message types declared in this file. + + + + + Unmodifiable list of top-level enum types declared in this file. + + + + + Unmodifiable list of top-level services declared in this file. + + + + + Unmodifiable list of this file's dependencies (imports). + + + + + Unmodifiable list of this file's public dependencies (public imports). + + + + + The original serialized binary form of this descriptor. + + + + + Implementation of IDescriptor.FullName - just returns the same as Name. + + + + + Implementation of IDescriptor.File - just returns this descriptor. + + + + + Pool containing symbol descriptors. + + + + + Finds a type (message, enum, service or extension) in the file by name. Does not find nested types. + + The unqualified type name to look for. + The type of descriptor to look for + The type's descriptor, or null if not found. + + + + Builds a FileDescriptor from its protocol buffer representation. + + The original serialized descriptor data. + We have only limited proto2 support, so serializing FileDescriptorProto + would not necessarily give us this. + The protocol message form of the FileDescriptor. + FileDescriptors corresponding to all of the + file's dependencies, in the exact order listed in the .proto file. May be null, + in which case it is treated as an empty array. + Whether unknown dependencies are ignored (true) or cause an exception to be thrown (false). + Details about generated code, for the purposes of reflection. + If is not + a valid descriptor. This can occur for a number of reasons, such as a field + having an undefined type or because two messages were defined with the same name. + + + + Creates a descriptor for generated code. + + + This method is only designed to be used by the results of generating code with protoc, + which creates the appropriate dependencies etc. It has to be public because the generated + code is "external", but should not be called directly by end users. + + + + + Returns a that represents this instance. + + + A that represents this instance. + + + + + Returns the file descriptor for descriptor.proto. + + + This is used for protos which take a direct dependency on descriptor.proto, typically for + annotations. While descriptor.proto is a proto2 file, it is built into the Google.Protobuf + runtime for reflection purposes. The messages are internal to the runtime as they would require + proto2 semantics for full support, but the file descriptor is available via this property. The + C# codegen in protoc automatically uses this property when it detects a dependency on descriptor.proto. + + + The file descriptor for descriptor.proto. + + + + + The (possibly empty) set of custom options for this file. + + + + + Extra information provided by generated code when initializing a message or file descriptor. + These are constructed as required, and are not long-lived. Hand-written code should + never need to use this type. + + + + + Irrelevant for file descriptors; the CLR type for the message for message descriptors. + + + + + Irrelevant for file descriptors; the parser for message descriptors. + + + + + Irrelevant for file descriptors; the CLR property names (in message descriptor field order) + for fields in the message for message descriptors. + + + + + Irrelevant for file descriptors; the CLR property "base" names (in message descriptor oneof order) + for oneofs in the message for message descriptors. It is expected that for a oneof name of "Foo", + there will be a "FooCase" property and a "ClearFoo" method. + + + + + The reflection information for types within this file/message descriptor. Elements may be null + if there is no corresponding generated type, e.g. for map entry types. + + + + + The CLR types for enums within this file/message descriptor. + + + + + Creates a GeneratedClrTypeInfo for a message descriptor, with nested types, nested enums, the CLR type, property names and oneof names. + Each array parameter may be null, to indicate a lack of values. + The parameter order is designed to make it feasible to format the generated code readably. + + + + + Creates a GeneratedClrTypeInfo for a file descriptor, with only types and enums. + + + + + Interface implemented by all descriptor types. + + + + + Returns the name of the entity (message, field etc) being described. + + + + + Returns the fully-qualified name of the entity being described. + + + + + Returns the descriptor for the .proto file that this entity is part of. + + + + + Allows fields to be reflectively accessed. + + + + + Returns the descriptor associated with this field. + + + + + Clears the field in the specified message. (For repeated fields, + this clears the list.) + + + + + Fetches the field value. For repeated values, this will be an + implementation. For map values, this will be an + implementation. + + + + + Mutator for single "simple" fields only. + + + Repeated fields are mutated by fetching the value and manipulating it as a list. + Map fields are mutated by fetching the value and manipulating it as a dictionary. + + The field is not a "simple" field. + + + + Accessor for map fields. + + + + + Describes a message type. + + + + + The brief name of the descriptor's target. + + + + + The CLR type used to represent message instances from this descriptor. + + + + The value returned by this property will be non-null for all regular fields. However, + if a message containing a map field is introspected, the list of nested messages will include + an auto-generated nested key/value pair message for the field. This is not represented in any + generated type, so this property will return null in such cases. + + + For wrapper types ( and the like), the type returned here + will be the generated message type, not the native type used by reflection for fields of those types. Code + using reflection should call to determine whether a message descriptor represents + a wrapper type, and handle the result appropriately. + + + + + + A parser for this message type. + + + + As is not generic, this cannot be statically + typed to the relevant type, but it should produce objects of a type compatible with . + + + The value returned by this property will be non-null for all regular fields. However, + if a message containing a map field is introspected, the list of nested messages will include + an auto-generated nested key/value pair message for the field. No message parser object is created for + such messages, so this property will return null in such cases. + + + For wrapper types ( and the like), the parser returned here + will be the generated message type, not the native type used by reflection for fields of those types. Code + using reflection should call to determine whether a message descriptor represents + a wrapper type, and handle the result appropriately. + + + + + + Returns whether this message is one of the "well known types" which may have runtime/protoc support. + + + + + Returns whether this message is one of the "wrapper types" used for fields which represent primitive values + with the addition of presence. + + + + + If this is a nested type, get the outer descriptor, otherwise null. + + + + + A collection of fields, which can be retrieved by name or field number. + + + + + An unmodifiable list of this message type's nested types. + + + + + An unmodifiable list of this message type's enum types. + + + + + An unmodifiable list of the "oneof" field collections in this message type. + + + + + Finds a field by field name. + + The unqualified name of the field (e.g. "foo"). + The field's descriptor, or null if not found. + + + + Finds a field by field number. + + The field number within this message type. + The field's descriptor, or null if not found. + + + + Finds a nested descriptor by name. The is valid for fields, nested + message types, oneofs and enums. + + The unqualified name of the descriptor, e.g. "Foo" + The descriptor, or null if not found. + + + + The (possibly empty) set of custom options for this message. + + + + + Looks up and cross-links all fields and nested types. + + + + + A collection to simplify retrieving the field accessor for a particular field. + + + + + Returns the fields in the message as an immutable list, in the order in which they + are declared in the source .proto file. + + + + + Returns the fields in the message as an immutable list, in ascending field number + order. Field numbers need not be contiguous, so there is no direct mapping from the + index in the list to the field number; to retrieve a field by field number, it is better + to use the indexer. + + + + + Returns a read-only dictionary mapping the field names in this message as they're available + in the JSON representation to the field descriptors. For example, a field foo_bar + in the message would result two entries, one with a key fooBar and one with a key + foo_bar, both referring to the same field. + + + + + Retrieves the descriptor for the field with the given number. + + Number of the field to retrieve the descriptor for + The accessor for the given field + The message descriptor does not contain a field + with the given number + + + + Retrieves the descriptor for the field with the given name. + + Name of the field to retrieve the descriptor for + The descriptor for the given field + The message descriptor does not contain a field + with the given name + + + + Describes a single method in a service. + + + + + The service this method belongs to. + + + + + The method's input type. + + + + + The method's input type. + + + + + Indicates if client streams multiple requests. + + + + + Indicates if server streams multiple responses. + + + + + The (possibly empty) set of custom options for this method. + + + + + The brief name of the descriptor's target. + + + + + Reflection access for a oneof, allowing clear and "get case" actions. + + + + + Gets the descriptor for this oneof. + + + The descriptor of the oneof. + + + + + Clears the oneof in the specified message. + + + + + Indicates which field in the oneof is set for specified message + + + + + Describes a "oneof" field collection in a message type: a set of + fields of which at most one can be set in any particular message. + + + + + The brief name of the descriptor's target. + + + + + Gets the message type containing this oneof. + + + The message type containing this oneof. + + + + + Gets the fields within this oneof, in declaration order. + + + The fields within this oneof, in declaration order. + + + + + Gets an accessor for reflective access to the values associated with the oneof + in a particular message. + + + The accessor used for reflective access. + + + + + The (possibly empty) set of custom options for this oneof. + + + + + Specifies the original name (in the .proto file) of a named element, + such as an enum value. + + + + + The name of the element in the .proto file. + + + + + If the name is preferred in the .proto file. + + + + + Constructs a new attribute instance for the given name. + + The name of the element in the .proto file. + + + + Represents a package in the symbol table. We use PackageDescriptors + just as placeholders so that someone cannot define, say, a message type + that has the same name as an existing package. + + + + + The methods in this class are somewhat evil, and should not be tampered with lightly. + Basically they allow the creation of relatively weakly typed delegates from MethodInfos + which are more strongly typed. They do this by creating an appropriate strongly typed + delegate from the MethodInfo, and then calling that within an anonymous method. + Mind-bending stuff (at least to your humble narrator) but the resulting delegates are + very fast compared with calling Invoke later on. + + + + + Empty Type[] used when calling GetProperty to force property instead of indexer fetching. + + + + + Creates a delegate which will cast the argument to the appropriate method target type, + call the method on it, then convert the result to object. + + + + + Creates a delegate which will cast the argument to the appropriate method target type, + call the method on it, then convert the result to the specified type. + + + + + Creates a delegate which will execute the given method after casting the first argument to + the target type of the method, and the second argument to the first parameter type of the method. + + + + + Creates a delegate which will execute the given method after casting the first argument to + the target type of the method. + + + + + Accessor for repeated fields. + + + + + Describes a service type. + + + + + The brief name of the descriptor's target. + + + + + An unmodifiable list of methods in this service. + + + + + Finds a method by name. + + The unqualified name of the method (e.g. "Foo"). + The method's decsriptor, or null if not found. + + + + The (possibly empty) set of custom options for this service. + + + + + Accessor for single fields. + + + + + An immutable registry of types which can be looked up by their full name. + + + + + An empty type registry, containing no types. + + + + + Attempts to find a message descriptor by its full name. + + The full name of the message, which is the dot-separated + combination of package, containing messages and message name + The message descriptor corresponding to or null + if there is no such message descriptor. + + + + Creates a type registry from the specified set of file descriptors. + + + This is a convenience overload for + to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). + + The set of files to include in the registry. Must not contain null values. + A type registry for the given files. + + + + Creates a type registry from the specified set of file descriptors. + + + All message types within all the specified files are added to the registry, and + the dependencies of the specified files are also added, recursively. + + The set of files to include in the registry. Must not contain null values. + A type registry for the given files. + + + + Creates a type registry from the file descriptor parents of the specified set of message descriptors. + + + This is a convenience overload for + to allow calls such as TypeRegistry.FromFiles(descriptor1, descriptor2). + + The set of message descriptors to use to identify file descriptors to include in the registry. + Must not contain null values. + A type registry for the given files. + + + + Creates a type registry from the file descriptor parents of the specified set of message descriptors. + + + The specified message descriptors are only used to identify their file descriptors; the returned registry + contains all the types within the file descriptors which contain the specified message descriptors (and + the dependencies of those files), not just the specified messages. + + The set of message descriptors to use to identify file descriptors to include in the registry. + Must not contain null values. + A type registry for the given files. + + + + Builder class which isn't exposed, but acts as a convenient alternative to passing round two dictionaries in recursive calls. + + + + Holder for reflection information generated from google/protobuf/any.proto + + + File descriptor for google/protobuf/any.proto + + + + `Any` contains an arbitrary serialized protocol buffer message along with a + URL that describes the type of the serialized message. + + Protobuf library provides support to pack/unpack Any values in the form + of utility functions or additional generated methods of the Any type. + + Example 1: Pack and unpack a message in C++. + + Foo foo = ...; + Any any; + any.PackFrom(foo); + ... + if (any.UnpackTo(&foo)) { + ... + } + + Example 2: Pack and unpack a message in Java. + + Foo foo = ...; + Any any = Any.pack(foo); + ... + if (any.is(Foo.class)) { + foo = any.unpack(Foo.class); + } + + Example 3: Pack and unpack a message in Python. + + foo = Foo(...) + any = Any() + any.Pack(foo) + ... + if any.Is(Foo.DESCRIPTOR): + any.Unpack(foo) + ... + + The pack methods provided by protobuf library will by default use + 'type.googleapis.com/full.type.name' as the type URL and the unpack + methods only use the fully qualified type name after the last '/' + in the type URL, for example "foo.bar.com/x/y.z" will yield type + name "y.z". + + JSON + ==== + The JSON representation of an `Any` value uses the regular + representation of the deserialized, embedded message, with an + additional field `@type` which contains the type URL. Example: + + package google.profile; + message Person { + string first_name = 1; + string last_name = 2; + } + + { + "@type": "type.googleapis.com/google.profile.Person", + "firstName": <string>, + "lastName": <string> + } + + If the embedded message type is well-known and has a custom JSON + representation, that representation will be embedded adding a field + `value` which holds the custom JSON in addition to the `@type` + field. Example (for message [google.protobuf.Duration][]): + + { + "@type": "type.googleapis.com/google.protobuf.Duration", + "value": "1.212s" + } + + + + Field number for the "type_url" field. + + + + A URL/resource name whose content describes the type of the + serialized protocol buffer message. + + For URLs which use the scheme `http`, `https`, or no scheme, the + following restrictions and interpretations apply: + + * If no scheme is provided, `https` is assumed. + * The last segment of the URL's path must represent the fully + qualified name of the type (as in `path/google.protobuf.Duration`). + The name should be in a canonical form (e.g., leading "." is + not accepted). + * An HTTP GET on the URL must yield a [google.protobuf.Type][] + value in binary format, or produce an error. + * Applications are allowed to cache lookup results based on the + URL, or have them precompiled into a binary to avoid any + lookup. Therefore, binary compatibility needs to be preserved + on changes to types. (Use versioned type names to manage + breaking changes.) + + Schemes other than `http`, `https` (or the empty scheme) might be + used with implementation specific semantics. + + + + Field number for the "value" field. + + + + Must be a valid serialized protocol buffer of the above specified type. + + + + + Retrieves the type name for a type URL. This is always just the last part of the URL, + after the trailing slash. No validation of anything before the trailing slash is performed. + If the type URL does not include a slash, an empty string is returned rather than an exception + being thrown; this won't match any types, and the calling code is probably in a better position + to give a meaningful error. + There is no handling of fragments or queries at the moment. + + The URL to extract the type name from + The type name + + + + Unpacks the content of this Any message into the target message type, + which must match the type URL within this Any message. + + The type of message to unpack the content into. + The unpacked message. + The target message type doesn't match the type URL in this message + + + + Packs the specified message into an Any message using a type URL prefix of "type.googleapis.com". + + The message to pack. + An Any message with the content and type URL of . + + + + Packs the specified message into an Any message using the specified type URL prefix. + + The message to pack. + The prefix for the type URL. + An Any message with the content and type URL of . + + + Holder for reflection information generated from google/protobuf/api.proto + + + File descriptor for google/protobuf/api.proto + + + + Api is a light-weight descriptor for a protocol buffer service. + + + + Field number for the "name" field. + + + + The fully qualified name of this api, including package name + followed by the api's simple name. + + + + Field number for the "methods" field. + + + + The methods of this api, in unspecified order. + + + + Field number for the "options" field. + + + + Any metadata attached to the API. + + + + Field number for the "version" field. + + + + A version string for this api. If specified, must have the form + `major-version.minor-version`, as in `1.10`. If the minor version + is omitted, it defaults to zero. If the entire version field is + empty, the major version is derived from the package name, as + outlined below. If the field is not empty, the version in the + package name will be verified to be consistent with what is + provided here. + + The versioning schema uses [semantic + versioning](http://semver.org) where the major version number + indicates a breaking change and the minor version an additive, + non-breaking change. Both version numbers are signals to users + what to expect from different versions, and should be carefully + chosen based on the product plan. + + The major version is also reflected in the package name of the + API, which must end in `v<major-version>`, as in + `google.feature.v1`. For major versions 0 and 1, the suffix can + be omitted. Zero major versions must only be used for + experimental, none-GA apis. + + + + Field number for the "source_context" field. + + + + Source context for the protocol buffer service represented by this + message. + + + + Field number for the "mixins" field. + + + + Included APIs. See [Mixin][]. + + + + Field number for the "syntax" field. + + + + The source syntax of the service. + + + + + Method represents a method of an api. + + + + Field number for the "name" field. + + + + The simple name of this method. + + + + Field number for the "request_type_url" field. + + + + A URL of the input message type. + + + + Field number for the "request_streaming" field. + + + + If true, the request is streamed. + + + + Field number for the "response_type_url" field. + + + + The URL of the output message type. + + + + Field number for the "response_streaming" field. + + + + If true, the response is streamed. + + + + Field number for the "options" field. + + + + Any metadata attached to the method. + + + + Field number for the "syntax" field. + + + + The source syntax of this method. + + + + + Declares an API to be included in this API. The including API must + redeclare all the methods from the included API, but documentation + and options are inherited as follows: + + - If after comment and whitespace stripping, the documentation + string of the redeclared method is empty, it will be inherited + from the original method. + + - Each annotation belonging to the service config (http, + visibility) which is not set in the redeclared method will be + inherited. + + - If an http annotation is inherited, the path pattern will be + modified as follows. Any version prefix will be replaced by the + version of the including API plus the [root][] path if specified. + + Example of a simple mixin: + + package google.acl.v1; + service AccessControl { + // Get the underlying ACL object. + rpc GetAcl(GetAclRequest) returns (Acl) { + option (google.api.http).get = "/v1/{resource=**}:getAcl"; + } + } + + package google.storage.v2; + service Storage { + rpc GetAcl(GetAclRequest) returns (Acl); + + // Get a data record. + rpc GetData(GetDataRequest) returns (Data) { + option (google.api.http).get = "/v2/{resource=**}"; + } + } + + Example of a mixin configuration: + + apis: + - name: google.storage.v2.Storage + mixins: + - name: google.acl.v1.AccessControl + + The mixin construct implies that all methods in `AccessControl` are + also declared with same name and request/response types in + `Storage`. A documentation generator or annotation processor will + see the effective `Storage.GetAcl` method after inherting + documentation and annotations as follows: + + service Storage { + // Get the underlying ACL object. + rpc GetAcl(GetAclRequest) returns (Acl) { + option (google.api.http).get = "/v2/{resource=**}:getAcl"; + } + ... + } + + Note how the version in the path pattern changed from `v1` to `v2`. + + If the `root` field in the mixin is specified, it should be a + relative path under which inherited HTTP paths are placed. Example: + + apis: + - name: google.storage.v2.Storage + mixins: + - name: google.acl.v1.AccessControl + root: acls + + This implies the following inherited HTTP annotation: + + service Storage { + // Get the underlying ACL object. + rpc GetAcl(GetAclRequest) returns (Acl) { + option (google.api.http).get = "/v2/acls/{resource=**}:getAcl"; + } + ... + } + + + + Field number for the "name" field. + + + + The fully qualified name of the API which is included. + + + + Field number for the "root" field. + + + + If non-empty specifies a path under which inherited HTTP paths + are rooted. + + + + Holder for reflection information generated from google/protobuf/duration.proto + + + File descriptor for google/protobuf/duration.proto + + + + A Duration represents a signed, fixed-length span of time represented + as a count of seconds and fractions of seconds at nanosecond + resolution. It is independent of any calendar and concepts like "day" + or "month". It is related to Timestamp in that the difference between + two Timestamp values is a Duration and it can be added or subtracted + from a Timestamp. Range is approximately +-10,000 years. + + # Examples + + Example 1: Compute Duration from two Timestamps in pseudo code. + + Timestamp start = ...; + Timestamp end = ...; + Duration duration = ...; + + duration.seconds = end.seconds - start.seconds; + duration.nanos = end.nanos - start.nanos; + + if (duration.seconds < 0 && duration.nanos > 0) { + duration.seconds += 1; + duration.nanos -= 1000000000; + } else if (durations.seconds > 0 && duration.nanos < 0) { + duration.seconds -= 1; + duration.nanos += 1000000000; + } + + Example 2: Compute Timestamp from Timestamp + Duration in pseudo code. + + Timestamp start = ...; + Duration duration = ...; + Timestamp end = ...; + + end.seconds = start.seconds + duration.seconds; + end.nanos = start.nanos + duration.nanos; + + if (end.nanos < 0) { + end.seconds -= 1; + end.nanos += 1000000000; + } else if (end.nanos >= 1000000000) { + end.seconds += 1; + end.nanos -= 1000000000; + } + + Example 3: Compute Duration from datetime.timedelta in Python. + + td = datetime.timedelta(days=3, minutes=10) + duration = Duration() + duration.FromTimedelta(td) + + # JSON Mapping + + In JSON format, the Duration type is encoded as a string rather than an + object, where the string ends in the suffix "s" (indicating seconds) and + is preceded by the number of seconds, with nanoseconds expressed as + fractional seconds. For example, 3 seconds with 0 nanoseconds should be + encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should + be expressed in JSON format as "3.000000001s", and 3 seconds and 1 + microsecond should be expressed in JSON format as "3.000001s". + + + + Field number for the "seconds" field. + + + + Signed seconds of the span of time. Must be from -315,576,000,000 + to +315,576,000,000 inclusive. Note: these bounds are computed from: + 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years + + + + Field number for the "nanos" field. + + + + Signed fractions of a second at nanosecond resolution of the span + of time. Durations less than one second are represented with a 0 + `seconds` field and a positive or negative `nanos` field. For durations + of one second or more, a non-zero value for the `nanos` field must be + of the same sign as the `seconds` field. Must be from -999,999,999 + to +999,999,999 inclusive. + + + + + The number of nanoseconds in a second. + + + + + The number of nanoseconds in a BCL tick (as used by and ). + + + + + The maximum permitted number of seconds. + + + + + The minimum permitted number of seconds. + + + + + Converts this to a . + + If the duration is not a precise number of ticks, it is truncated towards 0. + The value of this duration, as a TimeSpan. + This value isn't a valid normalized duration, as + described in the documentation. + + + + Converts the given to a . + + The TimeSpan to convert. + The value of the given TimeSpan, as a Duration. + + + + Returns the result of negating the duration. For example, the negation of 5 minutes is -5 minutes. + + The duration to negate. Must not be null. + The negated value of this duration. + + + + Adds the two specified values together. + + The first value to add. Must not be null. + The second value to add. Must not be null. + + + + + Subtracts one from another. + + The duration to subtract from. Must not be null. + The duration to subtract. Must not be null. + The difference between the two specified durations. + + + + Creates a duration with the normalized values from the given number of seconds and + nanoseconds, conforming with the description in the proto file. + + + + + Converts a duration specified in seconds/nanoseconds to a string. + + + If the value is a normalized duration in the range described in duration.proto, + is ignored. Otherwise, if the parameter is true, + a JSON object with a warning is returned; if it is false, an is thrown. + + Seconds portion of the duration. + Nanoseconds portion of the duration. + Determines the handling of non-normalized values + The represented duration is invalid, and is false. + + + + Returns a string representation of this for diagnostic purposes. + + + Normally the returned value will be a JSON string value (including leading and trailing quotes) but + when the value is non-normalized or out of range, a JSON object representation will be returned + instead, including a warning. This is to avoid exceptions being thrown when trying to + diagnose problems - the regular JSON formatter will still throw an exception for non-normalized + values. + + A string representation of this value. + + + + Appends a number of nanoseconds to a StringBuilder. Either 0 digits are added (in which + case no "." is appended), or 3 6 or 9 digits. This is internal for use in Timestamp as well + as Duration. + + + + Holder for reflection information generated from google/protobuf/empty.proto + + + File descriptor for google/protobuf/empty.proto + + + + A generic empty message that you can re-use to avoid defining duplicated + empty messages in your APIs. A typical example is to use it as the request + or the response type of an API method. For instance: + + service Foo { + rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); + } + + The JSON representation for `Empty` is empty JSON object `{}`. + + + + Holder for reflection information generated from google/protobuf/field_mask.proto + + + File descriptor for google/protobuf/field_mask.proto + + + + `FieldMask` represents a set of symbolic field paths, for example: + + paths: "f.a" + paths: "f.b.d" + + Here `f` represents a field in some root message, `a` and `b` + fields in the message found in `f`, and `d` a field found in the + message in `f.b`. + + Field masks are used to specify a subset of fields that should be + returned by a get operation or modified by an update operation. + Field masks also have a custom JSON encoding (see below). + + # Field Masks in Projections + + When used in the context of a projection, a response message or + sub-message is filtered by the API to only contain those fields as + specified in the mask. For example, if the mask in the previous + example is applied to a response message as follows: + + f { + a : 22 + b { + d : 1 + x : 2 + } + y : 13 + } + z: 8 + + The result will not contain specific values for fields x,y and z + (their value will be set to the default, and omitted in proto text + output): + + f { + a : 22 + b { + d : 1 + } + } + + A repeated field is not allowed except at the last position of a + paths string. + + If a FieldMask object is not present in a get operation, the + operation applies to all fields (as if a FieldMask of all fields + had been specified). + + Note that a field mask does not necessarily apply to the + top-level response message. In case of a REST get operation, the + field mask applies directly to the response, but in case of a REST + list operation, the mask instead applies to each individual message + in the returned resource list. In case of a REST custom method, + other definitions may be used. Where the mask applies will be + clearly documented together with its declaration in the API. In + any case, the effect on the returned resource/resources is required + behavior for APIs. + + # Field Masks in Update Operations + + A field mask in update operations specifies which fields of the + targeted resource are going to be updated. The API is required + to only change the values of the fields as specified in the mask + and leave the others untouched. If a resource is passed in to + describe the updated values, the API ignores the values of all + fields not covered by the mask. + + If a repeated field is specified for an update operation, the existing + repeated values in the target resource will be overwritten by the new values. + Note that a repeated field is only allowed in the last position of a `paths` + string. + + If a sub-message is specified in the last position of the field mask for an + update operation, then the existing sub-message in the target resource is + overwritten. Given the target message: + + f { + b { + d : 1 + x : 2 + } + c : 1 + } + + And an update message: + + f { + b { + d : 10 + } + } + + then if the field mask is: + + paths: "f.b" + + then the result will be: + + f { + b { + d : 10 + } + c : 1 + } + + However, if the update mask was: + + paths: "f.b.d" + + then the result would be: + + f { + b { + d : 10 + x : 2 + } + c : 1 + } + + In order to reset a field's value to the default, the field must + be in the mask and set to the default value in the provided resource. + Hence, in order to reset all fields of a resource, provide a default + instance of the resource and set all fields in the mask, or do + not provide a mask as described below. + + If a field mask is not present on update, the operation applies to + all fields (as if a field mask of all fields has been specified). + Note that in the presence of schema evolution, this may mean that + fields the client does not know and has therefore not filled into + the request will be reset to their default. If this is unwanted + behavior, a specific service may require a client to always specify + a field mask, producing an error if not. + + As with get operations, the location of the resource which + describes the updated values in the request message depends on the + operation kind. In any case, the effect of the field mask is + required to be honored by the API. + + ## Considerations for HTTP REST + + The HTTP kind of an update operation which uses a field mask must + be set to PATCH instead of PUT in order to satisfy HTTP semantics + (PUT must only be used for full updates). + + # JSON Encoding of Field Masks + + In JSON, a field mask is encoded as a single string where paths are + separated by a comma. Fields name in each path are converted + to/from lower-camel naming conventions. + + As an example, consider the following message declarations: + + message Profile { + User user = 1; + Photo photo = 2; + } + message User { + string display_name = 1; + string address = 2; + } + + In proto a field mask for `Profile` may look as such: + + mask { + paths: "user.display_name" + paths: "photo" + } + + In JSON, the same mask is represented as below: + + { + mask: "user.displayName,photo" + } + + # Field Masks and Oneof Fields + + Field masks treat fields in oneofs just as regular fields. Consider the + following message: + + message SampleMessage { + oneof test_oneof { + string name = 4; + SubMessage sub_message = 9; + } + } + + The field mask can be: + + mask { + paths: "name" + } + + Or: + + mask { + paths: "sub_message" + } + + Note that oneof type names ("test_oneof" in this case) cannot be used in + paths. + + + + Field number for the "paths" field. + + + + The set of field mask paths. + + + + + Converts a timestamp specified in seconds/nanoseconds to a string. + + + If the value is a normalized duration in the range described in field_mask.proto, + is ignored. Otherwise, if the parameter is true, + a JSON object with a warning is returned; if it is false, an is thrown. + + Paths in the field mask + Determines the handling of non-normalized values + The represented field mask is invalid, and is false. + + + + Checks whether the given path is valid for a field mask. + + true if the path is valid; false otherwise + + + + Returns a string representation of this for diagnostic purposes. + + + Normally the returned value will be a JSON string value (including leading and trailing quotes) but + when the value is non-normalized or out of range, a JSON object representation will be returned + instead, including a warning. This is to avoid exceptions being thrown when trying to + diagnose problems - the regular JSON formatter will still throw an exception for non-normalized + values. + + A string representation of this value. + + + Holder for reflection information generated from google/protobuf/source_context.proto + + + File descriptor for google/protobuf/source_context.proto + + + + `SourceContext` represents information about the source of a + protobuf element, like the file in which it is defined. + + + + Field number for the "file_name" field. + + + + The path-qualified name of the .proto file that contained the associated + protobuf element. For example: `"google/protobuf/source_context.proto"`. + + + + Holder for reflection information generated from google/protobuf/struct.proto + + + File descriptor for google/protobuf/struct.proto + + + + `NullValue` is a singleton enumeration to represent the null value for the + `Value` type union. + + The JSON representation for `NullValue` is JSON `null`. + + + + + Null value. + + + + + `Struct` represents a structured data value, consisting of fields + which map to dynamically typed values. In some languages, `Struct` + might be supported by a native representation. For example, in + scripting languages like JS a struct is represented as an + object. The details of that representation are described together + with the proto support for the language. + + The JSON representation for `Struct` is JSON object. + + + + Field number for the "fields" field. + + + + Unordered map of dynamically typed values. + + + + + `Value` represents a dynamically typed value which can be either + null, a number, a string, a boolean, a recursive struct value, or a + list of values. A producer of value is expected to set one of that + variants, absence of any variant indicates an error. + + The JSON representation for `Value` is JSON value. + + + + Field number for the "null_value" field. + + + + Represents a null value. + + + + Field number for the "number_value" field. + + + + Represents a double value. + + + + Field number for the "string_value" field. + + + + Represents a string value. + + + + Field number for the "bool_value" field. + + + + Represents a boolean value. + + + + Field number for the "struct_value" field. + + + + Represents a structured value. + + + + Field number for the "list_value" field. + + + + Represents a repeated `Value`. + + + + Enum of possible cases for the "kind" oneof. + + + + Convenience method to create a Value message with a string value. + + Value to set for the StringValue property. + A newly-created Value message with the given value. + + + + Convenience method to create a Value message with a number value. + + Value to set for the NumberValue property. + A newly-created Value message with the given value. + + + + Convenience method to create a Value message with a Boolean value. + + Value to set for the BoolValue property. + A newly-created Value message with the given value. + + + + Convenience method to create a Value message with a null initial value. + + A newly-created Value message a null initial value. + + + + Convenience method to create a Value message with an initial list of values. + + The values provided are not cloned; the references are copied directly. + A newly-created Value message an initial list value. + + + + Convenience method to create a Value message with an initial struct value + + The value provided is not cloned; the reference is copied directly. + A newly-created Value message an initial struct value. + + + + `ListValue` is a wrapper around a repeated field of values. + + The JSON representation for `ListValue` is JSON array. + + + + Field number for the "values" field. + + + + Repeated field of dynamically typed values. + + + + + Extension methods on BCL time-related types, converting to protobuf types. + + + + + Converts the given to a . + + The date and time to convert to a timestamp. + The value has a other than Utc. + The converted timestamp. + + + + Converts the given to a + + The offset is taken into consideration when converting the value (so the same instant in time + is represented) but is not a separate part of the resulting value. In other words, there is no + roundtrip operation to retrieve the original DateTimeOffset. + The date and time (with UTC offset) to convert to a timestamp. + The converted timestamp. + + + + Converts the given to a . + + The time span to convert. + The converted duration. + + + Holder for reflection information generated from google/protobuf/timestamp.proto + + + File descriptor for google/protobuf/timestamp.proto + + + + A Timestamp represents a point in time independent of any time zone + or calendar, represented as seconds and fractions of seconds at + nanosecond resolution in UTC Epoch time. It is encoded using the + Proleptic Gregorian Calendar which extends the Gregorian calendar + backwards to year one. It is encoded assuming all minutes are 60 + seconds long, i.e. leap seconds are "smeared" so that no leap second + table is needed for interpretation. Range is from + 0001-01-01T00:00:00Z to 9999-12-31T23:59:59.999999999Z. + By restricting to that range, we ensure that we can convert to + and from RFC 3339 date strings. + See [https://www.ietf.org/rfc/rfc3339.txt](https://www.ietf.org/rfc/rfc3339.txt). + + # Examples + + Example 1: Compute Timestamp from POSIX `time()`. + + Timestamp timestamp; + timestamp.set_seconds(time(NULL)); + timestamp.set_nanos(0); + + Example 2: Compute Timestamp from POSIX `gettimeofday()`. + + struct timeval tv; + gettimeofday(&tv, NULL); + + Timestamp timestamp; + timestamp.set_seconds(tv.tv_sec); + timestamp.set_nanos(tv.tv_usec * 1000); + + Example 3: Compute Timestamp from Win32 `GetSystemTimeAsFileTime()`. + + FILETIME ft; + GetSystemTimeAsFileTime(&ft); + UINT64 ticks = (((UINT64)ft.dwHighDateTime) << 32) | ft.dwLowDateTime; + + // A Windows tick is 100 nanoseconds. Windows epoch 1601-01-01T00:00:00Z + // is 11644473600 seconds before Unix epoch 1970-01-01T00:00:00Z. + Timestamp timestamp; + timestamp.set_seconds((INT64) ((ticks / 10000000) - 11644473600LL)); + timestamp.set_nanos((INT32) ((ticks % 10000000) * 100)); + + Example 4: Compute Timestamp from Java `System.currentTimeMillis()`. + + long millis = System.currentTimeMillis(); + + Timestamp timestamp = Timestamp.newBuilder().setSeconds(millis / 1000) + .setNanos((int) ((millis % 1000) * 1000000)).build(); + + Example 5: Compute Timestamp from current time in Python. + + timestamp = Timestamp() + timestamp.GetCurrentTime() + + # JSON Mapping + + In JSON format, the Timestamp type is encoded as a string in the + [RFC 3339](https://www.ietf.org/rfc/rfc3339.txt) format. That is, the + format is "{year}-{month}-{day}T{hour}:{min}:{sec}[.{frac_sec}]Z" + where {year} is always expressed using four digits while {month}, {day}, + {hour}, {min}, and {sec} are zero-padded to two digits each. The fractional + seconds, which can go up to 9 digits (i.e. up to 1 nanosecond resolution), + are optional. The "Z" suffix indicates the timezone ("UTC"); the timezone + is required, though only UTC (as indicated by "Z") is presently supported. + + For example, "2017-01-15T01:30:15.01Z" encodes 15.01 seconds past + 01:30 UTC on January 15, 2017. + + In JavaScript, one can convert a Date object to this format using the + standard [toISOString()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString] + method. In Python, a standard `datetime.datetime` object can be converted + to this format using [`strftime`](https://docs.python.org/2/library/time.html#time.strftime) + with the time format spec '%Y-%m-%dT%H:%M:%S.%fZ'. Likewise, in Java, one + can use the Joda Time's [`ISODateTimeFormat.dateTime()`]( + http://joda-time.sourceforge.net/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime()) + to obtain a formatter capable of generating timestamps in this format. + + + + Field number for the "seconds" field. + + + + Represents seconds of UTC time since Unix epoch + 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to + 9999-12-31T23:59:59Z inclusive. + + + + Field number for the "nanos" field. + + + + Non-negative fractions of a second at nanosecond resolution. Negative + second values with fractions must still have non-negative nanos values + that count forward in time. Must be from 0 to 999,999,999 + inclusive. + + + + + Returns the difference between one and another, as a . + + The timestamp to subtract from. Must not be null. + The timestamp to subtract. Must not be null. + The difference between the two specified timestamps. + + + + Adds a to a , to obtain another Timestamp. + + The timestamp to add the duration to. Must not be null. + The duration to add. Must not be null. + The result of adding the duration to the timestamp. + + + + Subtracts a from a , to obtain another Timestamp. + + The timestamp to subtract the duration from. Must not be null. + The duration to subtract. + The result of subtracting the duration from the timestamp. + + + + Converts this timestamp into a . + + + The resulting DateTime will always have a Kind of Utc. + If the timestamp is not a precise number of ticks, it will be truncated towards the start + of time. For example, a timestamp with a value of 99 will result in a + value precisely on a second. + + This timestamp as a DateTime. + The timestamp contains invalid values; either it is + incorrectly normalized or is outside the valid range. + + + + Converts this timestamp into a . + + + The resulting DateTimeOffset will always have an Offset of zero. + If the timestamp is not a precise number of ticks, it will be truncated towards the start + of time. For example, a timestamp with a value of 99 will result in a + value precisely on a second. + + This timestamp as a DateTimeOffset. + The timestamp contains invalid values; either it is + incorrectly normalized or is outside the valid range. + + + + Converts the specified to a . + + + The Kind of is not DateTimeKind.Utc. + The converted timestamp. + + + + Converts the given to a + + The offset is taken into consideration when converting the value (so the same instant in time + is represented) but is not a separate part of the resulting value. In other words, there is no + roundtrip operation to retrieve the original DateTimeOffset. + The date and time (with UTC offset) to convert to a timestamp. + The converted timestamp. + + + + Converts a timestamp specified in seconds/nanoseconds to a string. + + + If the value is a normalized duration in the range described in timestamp.proto, + is ignored. Otherwise, if the parameter is true, + a JSON object with a warning is returned; if it is false, an is thrown. + + Seconds portion of the duration. + Nanoseconds portion of the duration. + Determines the handling of non-normalized values + The represented duration is invalid, and is false. + + + + Returns a string representation of this for diagnostic purposes. + + + Normally the returned value will be a JSON string value (including leading and trailing quotes) but + when the value is non-normalized or out of range, a JSON object representation will be returned + instead, including a warning. This is to avoid exceptions being thrown when trying to + diagnose problems - the regular JSON formatter will still throw an exception for non-normalized + values. + + A string representation of this value. + + + Holder for reflection information generated from google/protobuf/type.proto + + + File descriptor for google/protobuf/type.proto + + + + The syntax in which a protocol buffer element is defined. + + + + + Syntax `proto2`. + + + + + Syntax `proto3`. + + + + + A protocol buffer message type. + + + + Field number for the "name" field. + + + + The fully qualified message name. + + + + Field number for the "fields" field. + + + + The list of fields. + + + + Field number for the "oneofs" field. + + + + The list of types appearing in `oneof` definitions in this type. + + + + Field number for the "options" field. + + + + The protocol buffer options. + + + + Field number for the "source_context" field. + + + + The source context. + + + + Field number for the "syntax" field. + + + + The source syntax. + + + + + A single field of a message type. + + + + Field number for the "kind" field. + + + + The field type. + + + + Field number for the "cardinality" field. + + + + The field cardinality. + + + + Field number for the "number" field. + + + + The field number. + + + + Field number for the "name" field. + + + + The field name. + + + + Field number for the "type_url" field. + + + + The field type URL, without the scheme, for message or enumeration + types. Example: `"type.googleapis.com/google.protobuf.Timestamp"`. + + + + Field number for the "oneof_index" field. + + + + The index of the field type in `Type.oneofs`, for message or enumeration + types. The first type has index 1; zero means the type is not in the list. + + + + Field number for the "packed" field. + + + + Whether to use alternative packed wire representation. + + + + Field number for the "options" field. + + + + The protocol buffer options. + + + + Field number for the "json_name" field. + + + + The field JSON name. + + + + Field number for the "default_value" field. + + + + The string value of the default value of this field. Proto2 syntax only. + + + + Container for nested types declared in the Field message type. + + + + Basic field types. + + + + + Field type unknown. + + + + + Field type double. + + + + + Field type float. + + + + + Field type int64. + + + + + Field type uint64. + + + + + Field type int32. + + + + + Field type fixed64. + + + + + Field type fixed32. + + + + + Field type bool. + + + + + Field type string. + + + + + Field type group. Proto2 syntax only, and deprecated. + + + + + Field type message. + + + + + Field type bytes. + + + + + Field type uint32. + + + + + Field type enum. + + + + + Field type sfixed32. + + + + + Field type sfixed64. + + + + + Field type sint32. + + + + + Field type sint64. + + + + + Whether a field is optional, required, or repeated. + + + + + For fields with unknown cardinality. + + + + + For optional fields. + + + + + For required fields. Proto2 syntax only. + + + + + For repeated fields. + + + + + Enum type definition. + + + + Field number for the "name" field. + + + + Enum type name. + + + + Field number for the "enumvalue" field. + + + + Enum value definitions. + + + + Field number for the "options" field. + + + + Protocol buffer options. + + + + Field number for the "source_context" field. + + + + The source context. + + + + Field number for the "syntax" field. + + + + The source syntax. + + + + + Enum value definition. + + + + Field number for the "name" field. + + + + Enum value name. + + + + Field number for the "number" field. + + + + Enum value number. + + + + Field number for the "options" field. + + + + Protocol buffer options. + + + + + A protocol buffer option, which can be attached to a message, field, + enumeration, etc. + + + + Field number for the "name" field. + + + + The option's name. For protobuf built-in options (options defined in + descriptor.proto), this is the short name. For example, `"map_entry"`. + For custom options, it should be the fully-qualified name. For example, + `"google.api.http"`. + + + + Field number for the "value" field. + + + + The option's value packed in an Any message. If the value is a primitive, + the corresponding wrapper type defined in google/protobuf/wrappers.proto + should be used. If the value is an enum, it should be stored as an int32 + value using the google.protobuf.Int32Value type. + + + + Holder for reflection information generated from google/protobuf/wrappers.proto + + + File descriptor for google/protobuf/wrappers.proto + + + + Field number for the single "value" field in all wrapper types. + + + + + Wrapper message for `double`. + + The JSON representation for `DoubleValue` is JSON number. + + + + Field number for the "value" field. + + + + The double value. + + + + + Wrapper message for `float`. + + The JSON representation for `FloatValue` is JSON number. + + + + Field number for the "value" field. + + + + The float value. + + + + + Wrapper message for `int64`. + + The JSON representation for `Int64Value` is JSON string. + + + + Field number for the "value" field. + + + + The int64 value. + + + + + Wrapper message for `uint64`. + + The JSON representation for `UInt64Value` is JSON string. + + + + Field number for the "value" field. + + + + The uint64 value. + + + + + Wrapper message for `int32`. + + The JSON representation for `Int32Value` is JSON number. + + + + Field number for the "value" field. + + + + The int32 value. + + + + + Wrapper message for `uint32`. + + The JSON representation for `UInt32Value` is JSON number. + + + + Field number for the "value" field. + + + + The uint32 value. + + + + + Wrapper message for `bool`. + + The JSON representation for `BoolValue` is JSON `true` and `false`. + + + + Field number for the "value" field. + + + + The bool value. + + + + + Wrapper message for `string`. + + The JSON representation for `StringValue` is JSON string. + + + + Field number for the "value" field. + + + + The string value. + + + + + Wrapper message for `bytes`. + + The JSON representation for `BytesValue` is JSON string. + + + + Field number for the "value" field. + + + + The bytes value. + + + + + This class is used internally by the Protocol Buffer Library and generated + message implementations. It is public only for the sake of those generated + messages. Others should not use this class directly. + + This class contains constants and helper functions useful for dealing with + the Protocol Buffer wire format. + + + + + + Wire types within protobuf encoding. + + + + + Variable-length integer. + + + + + A fixed-length 64-bit value. + + + + + A length-delimited value, i.e. a length followed by that many bytes of data. + + + + + A "start group" value - not supported by this implementation. + + + + + An "end group" value - not supported by this implementation. + + + + + A fixed-length 32-bit value. + + + + + Given a tag value, determines the wire type (lower 3 bits). + + + + + Given a tag value, determines the field number (the upper 29 bits). + + + + + Makes a tag value given a field number and wire type. + + +
+
diff --git a/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta b/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta new file mode 100644 index 00000000..aedb2691 --- /dev/null +++ b/Runtime/Plugins/Protobuf/Google.Protobuf.xml.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: 32e98c3d38e34d14ea431c91eae90058 +timeCreated: 1496624518 +licenseType: Free +TextScriptImporter: + userData: + assetBundleName: + assetBundleVariant:

d^86@E!DAv@!A;dP03k8#g>fWOtgwSnP+k@UCre}`a*u#Mei?^h~m{7Yfy z{chfl(@q9%KBKi7TAl8K?;Q*jA|ExQqP=pM0==BMTvN%7T5#58R%~&#MuFOHH0y^s zIhTSn(=FkFgt%Uu0j6r5J~h?ylgW;I+VYSriShyNI5JvZTFgSzLhVA(6jWh?V(;XR z>4>SgsoNA|et6-;B;l0Hp4${tVXH1Rv*v4>FpLjW`kKO`of^WqpR#@xu@n^K;r&P| zn#;Tu3(f7G44IiPn#y`tT2gvgmX@QH=b;mr-#IBhIafCE{ajE*mP5#?$g=9lj#rd7 zUb|L1ZCTi(u;rU)qv!W02B=iX3Gm!%reFq%`4_{)FRDh)op9`x?CW@hYS_VIZ zTJvpxWwLb7c5@Eak2v@FS*{z$n2npCnO0n_?{xpfbz*ojGBr%rQ#ZV8lNuT7rJpID zItXvb;_7W0dWeUa>X^{W5e@A&lO!AD92AasD*2-Pq^wcGUEHF+po&!SP0G@AGGG83_JNE;Q&$&^0t4!Z@M?>YX8trODWM<#*Yy!@hRD zKZU-K6bVK6H=#NpFX7#RrTC?=rqLM*TX>q-AB6qfL_Ya(+S+X1_3eKe_|%ji|Ha+j z+1}xzi#5{lK0chjPCdQ#VFaNW+f3QMOi??j^6Y_jSLr}0PrsZ6ouyZ=r5tK5?jTrI z+1%xTvp2jd<2+`6Xlalz+%AYN#0}>dO$Y0lr=8@pY{!>u1wEVf*Q4Po18!-XY4)7E z!nV3+zcveEgJJ^|g-oUP)LIDmlU9;`#Me@m=;)I7;Ra0{j$eO|MD*~V!jtO>35%C< zVcWb2x)5Cn4yYuk8mQzeMbYta4L^AEl$>4@U{+V+5r3HUIKe%{J<=FK5S}{BCA_aS ztzz!Y-etKnn_t6Xwb4geCjBl&Jmnk5bFx{oM(n+%WLNw&&s3ANOXrGU-h)bZ>T${i)i;fA!GPi6Rd+DE;DV}~(7knUVFYXfDbv!P=KP%7-1XTMUAhXRLxa6m)1LLE zW}VjcoY|1s@JvY=$EE5e+mq>~nSPmr)dX@1K7&WCN6Dk)9TO5Ka`lRRtIHP7{`BPn zWZnI--%`W-dUrYZ1h?zk=2*9~W8|;b^6HZIIYt>`P_(IMx{fdJWv^0-r#+~PxaQnyak?%4RGaC6mx_h!W+#x{{GYwm|%W!O8#69KMPAYJY^{@hTr9YU;6Sz*qI=W0v{$;=hRc|Vp5LEcs{ zt3}qPre~{@lPYW*WY-X1Br}FLC(hn}sB*k!TMF8F^<3BrK?MgXwMxD#opeUn~BNE$%)bF zEu)pKF%t_H7Z(#VD-$a#1F#2!or|UYXJ-aWJFlJN2>kr$hYjw|M$rM^Uc3U@-V$T!2fxme}1h$p8`J@ z9|8~4-=CfjL4?F-69Pg2LR>^p(HZg}4KY>P@VYla62a<7Z_!HBvZ0j`o8r4lv?Mt^ zx-H#iI+Cq8h7}e%Q*sRXB%SLZKSG0~xPK6mo+fDm-q7=H$*H;9NUGg$Bs;FR=Nji+ zRT<6KRT+;5$6Ur4H8WM|HLOD^98BtA2P>^QL@t}?Ty9tN$~5Expntchb?B$lNH4J- ztYet>e?JufdBVx5ok9iv6!V7uXOmBdh>MH$LY;-e07L$>@k8eq-}rQD{XH9vtoMM# zKr8G4BzzRapUs;Xq^SJRw#NA1K|Zlm0)`ZLD__&zI}JpWeT+E`_tDycVDdK5Z^LidB}sUM*A_ z4&u0Mr#X?6k_r_n6;XBuq9zb<*@^+Tv6b$26zy?;Wul>wCv!P}Xg*gd-XBBp{c~qP zrR|mkm(x+|^tt21-c-@0W*{nYye|x5A%@M0$2HgGar3n{@5=Rx7n9SHL&6oI$L-l5 z6V#smcZs;o*$Vwi$3ykq*@~QpZT{!zqotpNov8fuT8;L<&TmZjo3EF@!64#%VOvY( zvKtuxF4?Tj#1Zq)n-g#aM^VRPTV=8u^nsTe9lnk7KWl1xJv!VT{XD)1{Ha``4uVe;-x^Fv0Pek?uB<6Lq@OCoo%E;UA%-d`_~zI1LDlG_o-eVdj_uuriCU{? z^H3_6f@Q-Nj*l<&DGyNrjF7PKciXLjd4B2-WFI49dEKr!FI9?FNy6W}iy29KKR8{Y zvGsVpqOwIX#>aO#sQ}t4Fd9xi>%q6;JWS`Z`!Fci)KqghqvKV;I+-a5rB-7a*L3?k zMLpyB-{A{x#t>s2l=wZAG(`)dYtIr6jAc4Qd1o>%qRZgTYW@6pU4+4EIDl1Ct2?{V z<^#1iV>2PmQP82c^7WW767veol(QcsVrG4lDO6Lm`Hd?zPz zV3=d2m@Asu9NNE7Dv8wz)#5tB~LX#E~R%(Yo zVi5*RMoO*4f-BL0!@u)GOa(e-sIt;xf!*bIlCeE?j$U^NiXt@&D$j}c!EA*v@Yobi zi#CCap7)0%PdqMXVikJbxn?t^*KU?#I^r z%n#|5Nn7tEuDT`1lrvF6v5lVaDZSHQABp=hWqGm|m<^z|)^>j7fL72|*%7d5bMGcr z7J7KEp!)w?ZN}+*MDSnvVnZ;|LBXOZ!p;Ljps14$3zc)UqrDoK9(!=1jWuR7)56RT zzWU3q`wX}1p-lGp4;qwGiJ4nn4=SaaTrN+y+lD=1c$MzAwhhjw+1$5{B`k8UGsS?P zM>Fm<=dRGLm>97QQYl^t?#Kp?&dfrcl}?S=XJ>>?Be`N-mh69vn1Cxq)aT_U7w)px zGI^0aXF*Q_lsHJ#kcs2&`z3XSk#L^wYh@rwm;f&3aNL1V4PE~>b1-M$(+2Ug^|8bS zYk-GLI!^%~g`*f8Rl8K?@8Ogp(AO3{oG1;9@s9+N=iWXXr_(rl8Jspkf$2P>hb73C zWdD>{pK1w+MuBWKwSC-8(D97^ z3X2+&#)3=0tIzZ@-@vzUZ7MZl(WJiO%$EG}7eG%qYewb4gm_Hg?RNYE2#0v(eIA{2quwsT`C z?fd&%w~n_l0(%rdAK_g2sXBm=-kPbP?ST@??vL~vRTA#VXE^yC<|aaJWwu!9Jg9SGczVNU($Q0(pRR!QJhX(EgS0#kziXm#a@%a(`X5|`<$@sb(5|L=8RuX z(h?z3lrT{8@;rLBN-hx_>KM!!q=}?0cC9HpgG|jAF+&*~qes&ed-iO%HSvsU*{A;I zkE(I?LZE_J2&K4H_l?p5+LpfX<8UQ zhm0NclGyu}2!A!xlht%U?Fq@}s$hL#fC&5y%#2uM6&0dT?LXFNc|M0d= z_dwj)z|OBiRbrO80S}7vu5aR=-=;yGVsJgq(+1a91oFPD5ydOBN2M80U(Q1&C?VbL zsM|lb%_}h9VZJ@6a$Hhx&YOBNwkS}ji$H-fX+0bs9TX)mtX%)@u~hxi4X>A+rmCU# zL#5?7jfP&|0yX~fRR~o_FOi!RP^-z-*49|vZ>$CDAJci=Bmz+g+01!CLmoi6PA+hn zE&n{v-g6gCI482M#8C1f{LT8ld#xA$(@o9+2fEve^9J(APwjlyv3rLLb^Ba4Ujx5G zeLh*bx6nBHUUp7eK-O{8Sq;+-M+39$_58>=6KqEG-m#cl?e0B)Dc)RS``*Rw#2HXj zB!K2uLnnq3togCr(&2bntL-bs1GFAiP@-o?8BU9D0;AS+Ru8RGp#=6fM-u%WsY7Uz07dg$qKxf75_%rzr1o)82BV^hmzacw(Wcp)xL+dnCS`SBN`|mizR(LvR z0Zs?ium>R)#egE95@gu3a(lq?1$Fy!D+ff3Lycn9a{D8e`jZgfG><_anzTd^^V5l>H|g3Tw++KA@yhKdRDLOiA5zhm`!j6#Oz)Rd36ch@(AC3%UR5=k3>SM|=&OidAXg4)A(N>8@o!Ivf>>8OP&4!DLZjDD?25a z7*}`~dgC)#8z4C>=E(u<99w>S+|5~)nBG|!)4s<*q=NCxl-CP+TEhNitgRv_lMxGh zbEcvbOLZL<`-kyEK55ox0GO_uO&@#Kt*`C7AH52}VJL*Gk5WbFKS}qc65S^c^Ptub zTUo)(Ejt$qwyE24VYJ%!NnO!MS!H(EQ@lO)dZr`$5Qdif&iUcAw>iys!8Z&d7WqEB zW?3gx;%`oXs&ss`Yz_sr{C2~&C#GpZW#3~Ghi_7{3>@?UY-qjm!5T#g5clt|T`-1$}JbF4Jl zP4&9wizw%-u*CfJP`8<$UAGq;Pqu}nJJz)Pn1MkO0B`1KW+GWa4V z*QK$`Gi*v<6($77{SyE!5rdgd9kk7RrN~qzX;nMeGU7OpN+iF?-rq2uul!d`Vw z6{#qwRmgpHhv&y|FCbyjG5*EGQXHlA(`jN)(cNsk_yb?TzzLT&(?nO0l=4rllht*V(p9Da^WPGEYZZ!-X1z8X-hS&l(A{W)ralb5>mK{1SeFpvvI= zF*n|A|4{^YU1rfY61eWtnK#bbc^3DsBa!-%_?Vv0PmghLLE+6O9f-B!j9*hB0#r^K z{8S@vvwxqTZ6!R1PMo6-IWu7?r2HaKPKt{1<(Ar18;NHqYBF|DW>!E|I3!7TSnT~h zkfdOQ_slx!qxW{q-O47tto2FVl1br1-HKuCQKi#jma;;1aN{3b9hBhhf$?^bG3{s9 zP0_4{Yq^r~dTnew=a1~dyKvnfC;=a0gseBd3PDK1q~DRe&g&fl-S}jN;WIyIfvs1C z=a!?;abYftnZlIM&PNw+o0NJ{dFZL-Y{xk2+E$?NAJh~VFF##5Xsaq%Kb}n3psoQA z{IhwVi$4OgNVA8ZL{9n0t}^uj8tphYt3pq;mF|6MsG$S`Rw{Z{R!_F=x2ux8iUVs? z4~Z5so;rR|{k6PrBm_~%ft&tdI;zpkLpW>SE#kHz@M8DqOv_#!z3Kl^Jp0X797K+m z0%3Hj%dR#xptKoZ%o4F)VP+lvg5>4-eK-d~J~1D%YZ9j3*IBMma)tZP5LyxsNW`E* zefMl?0%3@$gA51br)c_%TD5ZGdvba4HK+h2>a$7?vCm4`wwk^}qo~XiY@G%jlLV1E zu%;M}`wvS1Gx~(taM&RJr!_#pL!&~{(zTy!ms9nFgO=@G4&Blk}-HrXO z+w<)N^%~Re`Ea;;r$pw(z9M}X7oVu&a>)e7@j@lKpSO((cH1LU7nkhzHx3+KP%pFO z&n6E8nGuiOm?o@Ts#(A#VqU9k9QZLy>!+jbY8zx^ ziRNE`E_MvLvboCm$-kbRgsb1 zf-xug+ok^JOe7M!)4R)k!-sV5rg|deRGRhHS@b$Bn%2BxPajGCBQcXQ24@oT*xL#Tni5Nx_!n~fgF1jgtZ2Y^19qQ7ue{lhA{_l^f+QoVADU^(hV zVR=C5nMUd-At8yVI=nhuaHyxDr!tdVd7O9Af!JBCs$L?ICyg{$NK$vRa7 z-4;dH=kNHThPzQx9_s{NNr;0{H^%-GH2(uo+%nV|m}3=wI$Gr20h-w6oN)&BO|4>~ zV*lKcTD|R7hz?9gimi{n?Pgz=GLEXcZc>36D6;r&IvA!dtY<9Z;iNVzS)S za5oB2s(v$GOY;AIX)za&r-!onHBgAj^JLO6=%LV6*;XfAM|rQi3bmVE9g=w6YVG%@ zrGbX`or!Z&PZhRPH0MLOJaIg`#eBY@!Oh8m!LJ5w z-jJYHTxve+>XJ`6ABy>Ow{A{1##_C-N}Nts1zpzsan~o;Ui~+*eOAFy?VM>Ja_H`_ zk8!)i0qxT~=8B${R)SHpK2xTSx^n^X^y4MUkECHXR)sj#Df%6Wih#tan@_qtv0P5E@rk(93(E1 z8%-f-lfvo|Z6lC0;{P*3_2mrhp zL13Ha?@pi><dQ`f**v$!MpDEQ!=_!j(`1tY^r|pul&hgHzvo|ll2v{2= zm{klucv|ZW-0F)alP}j5?2l(inXn;$O91dV0Uv;eIMjB&u>;tm%Iw^yo#u31@1*$8cZFFJrt0yR1|N&GbX6h*JzH3OWIC~^$pPK z28WW~#`OYXq#;n7=gZgh$)@_Rp6xUF z=Z-?l9S`SO&8F#17HUfXUL(jr?noRDP}Vvm0#3Pf&pQ)AEjX;W7bO{Bst$yM7!(p; zlKxXZ|McKYIc4TpJ3y;Kpr=pN4=+eghpc4OX`w&SDfpBVz-G0)NTO39Pw@g;H-}SH zfMWRD-1vV*%K{A!!EmdntY!RjDj;GP<{U0LtuO#`vkHAjB1^T)xzXh(m#aBr2jXHn zpodM9c#T$mTo}eT)IENGrUvKN)NMc-(v#xR(AqsA8by8B&i&;QJCBLwqrt-leD+j3G zOBvh*-c0vh8|F7aw-#VVYZF7H{Iv+^>@rTw;}}@+*cWgJ1DDh^SEhiFof#6LwH@=f z8UqjZ#*o5dbyF#-?Gn>_1^dUY!XE{T7o!bHS5>(QJ`USTu|6C?9&J{wkCe`z{^{Q9 z7@3tA3Gj7M0+krnk;9bx!7i*XMMsPR+Ltu?GwtVY%YRjLV0u76sw>MwaLbB=f<++& z(YQ+48 zE2m-~Ai5eFw)?`2SDPpRGYbC>-yZaq$M@Igd75z;IWaI7JkVeTD^rdG-fqop7)7Oe ztTl*%Z{Rc^m5^E@zUL5WO~~+A$xb62P{;icx;mI^Mlpd6uk_t%=tGUAQK0m|T&Ol7 zi{!h@A4+?#@`l~~b?g8__ESJWz<@>F(vM$GAH&~#->}%-QRtII27x|NvWMnXykGBv zcbOrF8UE5D3v}PJL>KjTX>TFWZZIH%#d_71{VRg)`N1bA&Ni>;SbhDV#^v?Y^qU{P z*1+#@zUCXy-d&_)I8DaMcjs%0jNG5@_RHR744RcS|BmFijuyzqtjBWbXUUmoddm11 zIS>*@w>5RTv9%G&9}lpq!Ri79%*VxaWKxS)XRncocxLTzXT-rUaI5%&;%cDjbl+bY ziJvoS_NNg%>CB$1Y9|XcJ_h<$M_#@9{k>B#r`UN{BUM_X);#*9#7T>kcU6D+CA6_zW$KOg3(G@YUqwC$?U?=9@^Svj>>sEq@f;g^f17fgYTRvZ`@ zXjZ!oAWw0iVyE$uOuS9SkCsAzDN8O}aVi(iznyKEE25B~SBvx>;nq|_&%R40OubRd z5)us#3yV4ZU;>OlR3&mot(M$ip@nM8oPGYoJ8?qW`^!TrVApuSh1qdTH1b-!&8c>) zOgq;~;W4Z{SgF%F+a6`=3_!Nqn`eLKxyx(9#i4{nA&51fs}j#x_L!`!dir^3v;f)8 zMMEB?34L%)+Az|4-bJB%EPlj`S;jXh>uljmf44(s_Z&PIdOaAwbomK|)^H0jq7-0L zQmk6k8Xfj=ipt>HL-CJ*c}-z9T|D06;iiO!fJL1t{<`)4=zS8OM`P3T(|w^P5>Q?n zosJphgrcwtoKM$1BXvyDg`#&IAMY+%y`J2al(`-D$boJY2cYWSiedsjch$4a{*9Z0 zMf(Zqa zUeT5%ro=k zNEmNfApR;&uyK|04Yr0JdcvL%vU4pSKiiVt4e`{d%{9B#38?w-+#giwZGR#AddPdd zn6q#S9YpfuCgOPMXB{p6>y?*gO0<8RQCE<)TzhNw^KnG@r8l9z0i_YS?gCGfpLY-c;%LUfU+zj$~=(>jtTdGbZaZYK6!f{_sBS_Qj%? zlS9Er+(3Qr*cV@-k*jj7ZTqz7a=TwP@gb=ny-1px?1m_F_+ttWsVv`=%%fq{aC3fe zhW8;Bh8QErF<#s@Epj_pvh5!=sV6`>g+sRZDMrOLSS~frzooZ z|HoPl!>yR$W?PM?h1}g7=^7Vm^n~HDC|ZmkNIn?8B;bRutdOCUS2;wnghkG&JPz__ zo5T9C;o0&n?k?~iE`CIjUa#kE>hLUDP;r?wC-qs7D*$7UweO}3n7En%_o);B^$U1A z#u<1MjM5zN()>{WBMB}2D+xVUS}DF#Sm@=HlcS+~Ds7PeE&;-P`vdM?{!7gI4baE( z)fTG`0V7ueFnSI5r%U8>J|GkF2@#_wh6;iD#lZudv+Ds6!423!%Mhg^I?-YY6i`(G z*<~W{7mhfp4wT(1u zN>R2b0o19v-I3Q*j>UQ+V0iTB^xzSpO4TCs2ED+aabn1OHp6%=Zl~Z=m5PPf06=fa z?$ z5Yh%zUJ~TvRvm1F)XoTaeV1n2hZ`HUlQq!pRMpHS`x?P@giX-%OegBwrzl}R|4nl5 zd)}8G-Db7p&)~+VsddgU0N!Rwok?m!<-5t8utB29<2LNx;uFU@{(IBbN)av0%&HRp8t^txjY%d@X@a}YJcEut}!Ta({6H;{Tz#yE?uNv z21FwOp|GEX%>~nT9t#{VC<@_8r>N|^$MD%$49pIhVzkarDFcsTN9lhS6Km1i@}@NU z1*ol~_a!<@f7g@@LjCIJA5)@?sT0 z&L$(Ve$`*i1R%&nev5w45b13`G$n2DtL|*v{niFc><)e{(TMKT(d6~~gm2>8`-0m9 zV$j4e2SO;mnxw*!f6cFq+LnsR1!5pl42&rpR?`-JEsHrHQFq6`ha$1VPcQ20=Re6V1ATXV*?`_+ zsxVGKuwuMShhMrl_!7XS%7M|DY^_)GW_P^hm*p4JR|{6HB{rKqa_84kX!ki0Gcu7`-zWa1g3vlB~n0S&kSFNOaf69;=SpCtczkf{|; zYKyw{W<4~y;|=;%CczL}R%bLS3_s50-qZvhLH;%$Y|IgKM39*J{Ql>urG?lb;5GGIH@hw;=6utgv@d*;d{p~5itNq z+OgauYWudG^wxNDTEl9}!ugHpauyI1l6-o&HM~ArvOQYl@|hw7>>c)^1w;UT>>t^2 zVwd8a81Mi-1efh*khib78R5$D$gg^Tj;a)vACmmAYdZ^2 zz3yBDB0m#0x!+dOvRomcHRB9~U{AJh{{%WpV*wEHa7?JWn69n*2J^xq;DkUXAJlwC z5iAeVeX~gDoX>`0X})Pqu@+O#9!Zy@_QPk<3-}ah)RiiCV(`N$FK(AF9AL<{Ip1}k zU=%Yuzqz82i_LtE{BF+DhWBYCEy~d&Epp*&g7>|hsT+I-B{g$-r9e5oQeo^;iR9?0 zb8(uAN>j~Y2~pjjnOTljeq5OvP9`uzVux`^1 zPF`x10Jq|Y9uG65h^i~rZTH)!CZN2(kE!yW=5|b9gxm; zkDOBG;oW+dL_M8bg4SA3WhlJSb&pbSIz(qdh)oj4Wk=>Bh1MH$nrPnS%Dp4In{ z44*GMjgd3dq|)+U(jo%oXnne=vN^x-R0&r1qlwasnU7HSL-HIp*8+)^jWtEaItLXh zyz%$|r76%)m-m#ae4q^vSGMT&2iLQHD#H#xc)mxahZ=v6<&m`4hdoZ(N3yP5o9MxK62l=yT}Mlr@=>!6{BEKb0-sVw=K ze;mTn5&i&g(pzOIU$gH*R7!;k>3-$T2-G+bBXu z*+K&`Gaose{!Xt;=fdCcQYXLpx5GN^$2?~e`?kK5smuA0VZoZ z{<}e}4H5Eswm4yFQRJl&?4}DeCO4)YtyqBmQ&1GeyyN2(Z+=t^nuJ0aIgku@0y!a~Q4s|g6L%kVg+^K2lPS5p`F~sCSa*E7pEh=T&+>*!&-&i(aC4v4Y zpbLGHmIX}=>Bf(kYYdm>t?61%<%$xipa$;;-j5Q%!0;A@@mWTbgn$PKkN^n&MX_5O zirEPI|4OO!9S7#N^k)}?LG-@aB-+8!eR;g%eqMm>F!sP5w3v)TUZN$d?kpQ~|K`M_ z-;!^1q}ni&$=>!laGT6$QharfNq6tS{ms$kyTh*YX(NWdh-?#D0pm8_UkVsgmA)4j zeR^T9QC~ZCRQCgMNHste-*zc;^8oZ)->}Z**tmEGje#({w;+^7$E7r}E~rN>S<>_X zX&5daYRtCbi6FwyEwaRKwg{AQ?+w|}^R{;LGEmNnK3@X?A9y(>anIjAsi(<>w!`_p z7G=pnM?g-?9$)=|J>km$f)p>135o{-g^0y4>@M>F{d#l+vp5NT0%nh_9=pqu1<6;| z81!Ya$@zUgE>tN8Xhu;jTdAz8!NyMNSvEd2%~ zD|ON^00TtLWHLWmd;VmtvxZ10AcuEx5;!mi{Z!liRP?17PYc%?iro4Yz~4rxSAWS` zSb7E>jwZ6`Zvtn)y}*NCB?8beud%apeI|d6>C||xA7H~wnDuhCZAF|+x3w+2FuKF;8qs}gbwyTF?< zq__lUx52(8Sgb2J(3d)AR^SBh&SXZmu|#LZ^DfhRvk#r{csQOnrC6s9d_abUK zeCbp5MgKCE!?*h0z7I47|Hh znPO4M*@fai!v!Siing=d*p#VN{Q%>lP9N6u574QU0^-n*z89khXuyTV0wk}25aUZy zG(#207-Hw~*KNdN!x$Ah|8v5P^xA?%uVw0x|%YQ(sVE`;5w9?maC8-NSy&o4F-NG&E zwpyi$OwNLkh*(vPhEu9&njn$U(A?ZghDt)Mtu{^WtcK9N9QD9{6;AFYUpbKoT6k=ylut2-00cj_lkT4*A ztYzpK6f;yTY&a~0I!#&rEOH-gXrjqggl^=8BE^Dr%k(Wpfi_;mzL$K-cj%0%-#zMe zKzQMH^IP}btWCe_XUBsZ?IYF>@^ zpRa`47_so48TnTbhCddW)M@tuDslFk$-RTQs=JNdIq39POViM?Yiv7*!Q^5Hcx>`?aeb{4AoD@3ofYAl@BVkvirr#WlXx}_T|Ig{t z_}YzviG{fd*PY#Ql^@rSN2jM%)pOnjF#WZog?61_0Vkl+8>zH>+Ez&%55;9-Jb`a> z5NdBj9Dt&io*wtL%PuP~pUtAz7&W6B?(w_8lDX+?y1|CyCK_&VZTDb&Gn!JqS^Y8*^X!k)MGp19EXWVxUx}K! zR-R)DnPtx3fa0OM=6nmpYhv|Cd;JSjjJJ-|)>-0$e zC)G4nR6=fYrlu2LS$;e#T%=y@n+~Mc%mR<%nQ}bmLvLrcqSXI072l58G&=)gk~DMi z#J`a5uDtCOhmY>0vpv=l$)i1?CnGyP%9DuW_tVqk{r)Am?RBD@JT4^C_G%S!1<|?a zu(6@vtxUJ7mI$D)7BKzfTboi*A{j}3S47)4ON1dm=Kd;gkEJ0D+bI5Yxbjjs{5gbB zrklmlZI85j8DNjO>Yyv}A^M;8M;IGrdUd;^Y7Ue~*hb7U$@ztRxQTdB-_F7jJbBhG zf{8U%KP`f`We?7;g%3-Q)dFmNGFfig14jdDR-LCqtq6bEQY-8b7lUW$PTsX45#KCj zBGJKm!hy^0GLbNOp{KD@F+CZV13ar^dRqnV;Y)+;pgwNw8?M`!mQrH+FtywWy;=5Z z-S}$I>rjykpi}4%5Z4kCC+Ka$i5^zwbLZ^`$*rGWae1vZjer7lim-1CDU%Jm*+VE| zv6`CTJ#))cJ_)+9la@LRTslSw)I!FW@x8KbDuL>5qlG$q`YK1 z#IuW?)BW~=9a`YQ5o5qA19~6`vhi-H`k1UC@I}lRM}Z8B7x>f;;2I#Ofw9I7PyQBC zb#c`@;{T5z2oUIkb{Dp;+>ZuUN^ru%mTfx|3BSP2KaX_vk_QQE;^@oTkVNw?1{Ot( zSc+I8BO}KFY~QSF8US8N@66(>_@g>rNNbu$t@#|NV1)bM;{nj>?Ja8v!$Le=thV9T z?@%Ss#Wk9Uw&HnT5|H2pBm-*p8tk@Hh39L`r~plEV)5O`2b>pz`_Bf30P)3PcddUU zZvfy|m&q$248j2S4z=iIX$_l6R!szeZ9aB%cD@THrf2EfRRHo64FEg8JOQ)^_+n;Y zrHd^`o?24Y4fq(v7N-XA<)%GLUx>_~Ef@90$wxb5xBESNhcw;n-%$cApFu%%0PIm9 zH0vR#$14VCX5@MOPu#8-Uv}rJ@_l$PYOG^+|go2rK*2)1cYg%wDhn04LdQD*qz^N^q?EdHHN5FNNsX>Om5L+o?dXIh; z9S@4vwLU^n9~XWew`d$S?lYDw|6A91u4eUL0_X*r4VCI9tJ|PnP1*hgrVJDsWS}@2 zqY3_cSwWHu#G=!c8f5+s*dBO;MBwslrRc(}i4Jyv`oG^|0PXkQ^Pyf~u8lcDLne)z zLaoY3DHM^OS(fiMS1OUY{n-BZ&d!(MprEnZrrZAd1>>Z@1Mm>N?O?;3p3X;`8w*R8 zqMIlM2$E<_-Y~!*V4W1@XR@w02%Kj9Z$#;Uf(whGLn?scN-z$Og|q*nIlK^OZmKBK zfe@yBNp3GD=i9&YLmSRHV}9d1DaXJ2z3eK1mRT8tG3g@nH|XIFFQ*3o8k_Eat}8T< z1fvm5+y0wMflCw!;hb%Bb2^x1xqZ4n-U4#RN5eJ)a72LzL(3iKy#+(af3Ip1AP_Ti1^Dx-K$LfUj++OZsTJc*aobB)f6pIa@T?a?Utxj zeMsi8N>^tJe*`3pKP)s*AOsbvJv)X$2fhK#MO-I3S|ycY05^wmFhmw7KO3|^;BmdQ zZNH3z=7JlH2@GupVENNz@rYwa*%nYT^tb5Fl$dDha#qCn$ACx~9-q6jz%Kw_nHPNW z{l%m+17S7=#1p<%?whCl`%+@UUv9pB91)jE++Y&hLn|zVMn8BaUB|IMESQNV3K$YD z!!1bu#()zKl7zCwe7s+ImSOkiuqC~48_yLlv>eW#W`_o*#E_4Q?=~~!mDQb!KwgpDTgodYpmnpsz?X>6IoE zl!s=3fM*DxvkFHmK#b)A<88i(u^v0y#u*+za0-S~INmS(UCXCS3dA)Ax{HMQ>2OBB zZS+1(e$EUvQvEWrxrX7X8|jC|z#z-R(ZN)gpHF=YG8PB}P1!jK?3bUds-OBQ7OVc^Lb=bp@$>gD z7!M!>sEy+lFiStZtPqrbv-|%r_SaEWc5n1A3|o+t4(aX&k&rHFkVd)ym}kt`WNG`^y4+;i3I{um8S3H&sZ_sv052Sub;E5aZUy$ zz&PsBw|1q>DzHdDK2o}(Ec^_t>2(i5oiyGBliz;v`ndn?!>soS{7)qHzvwHIH?L(d zZVxBjU2b^wblGB0Attts)$~Vz3IAlU2{rXzHK*EOrby*rKYRjDqq;oL495K?@@^b2 z(xOBT&g1mP0P=k@g-xPf$$h3lFDg@X=j9q$+skA$I1<`iR$6|3}Hpg zLnCB2vBeWqH``tr;sH@V1)+pQh=T0ruUUcjX?0)c-}M~-28u4u_o;?mcrDjrh`lD8 z%nH~LX~U zSH2{+D%V~?zNmwW;Ht@PjA;3J30K>I6>2wM)?1g-DJ{S-ikQ8(QJ%0(HLy_C=RA^Q zS>yVKzF1aJ7@sDJjg465U))ENRg$bTJTTVE4B3H~hFeT4a_lxlyA6bF&HuRjG`NT= zc9uLcME{6ZRL9+P$QBdi^D6N}VxqS%rKPZh>?ym=H0|QOZ)gos8Jwil!5xejL9Y;+ z(fmh@6STvCSLWpZ8qa;?-vuyJ{aX@+i=`7Vc!GxlYD!96dV z%5*$z{EmZlfq=yr9*-gcxeR1yb0o))#c!y-cbiE7Jj3gK9$k91!1Q3NhxxH&Cix&K z>ZaFD%LZioG_|q3oMgP{?#qd<3q3=UgLyc(+`i`+y>KKbH7$r(9?HL*aM?9&w2?Wf z`*LOQcXkdA$$f6e9SbBld{(kYmcqJyXXFwB16Quwog8GcV)H6=54imP=#;2+?OI76 zV~v)i6VvilyVn?F?Us*bv+AHyCyuzFY5-WG%-%2P|vy&#{>E5hyB%55wL5d+M` zlvI7kYy^<|E!{kJsV83Lc_^%59Xl-$i*(PZ*Gr5fbtIM}%He#X{%Y`5bN*3L6 z+j3%)Sc)c{*obpf$f!(7xcP~u!fWSe6HZ&J-oC*5X1)Tcg zk}GUlwL#6qeRqw`_sekd)|MB{DNU(LWHJ$Cg)Gc(K&NPky193Vn5b79J<5~atIzc3 zDgqRg%CmLzqLpcFRwx96w%@9fz6R8)c*fy% zPZGH^ppgeJ!xm2GfpvVJK5NXgPOQziaf>PM(hNoPnd&s>+rLD| zFf?OWKe`G@eV(4wKDvw|VD*|HrpuFK;IpiC%h;i1=UV(Qw|(>3QcCY$+0m^semF>7 z5w?y?qjWPQarY-5Ja_bL%M#H>udQ>A1@SmUhK^_CQ;<26~C zQ>&tu1h@zv5i~xb)f2YD81WGPHoIf2cYfwGz8L!eo1^t21DUEZH=&biD6f1 zWYW=R&bNPFG7a70oaauG+z?9nG`!dBvmdL)e@{8#yvvG`f5f+wr6zvCP>mxOssy4G zp(W}k()|{DNm&#kLG9(8cD?dv$`Qxb@))w8II2os+EGZdF$6GT3j*Eb5R{hur^St0 z(jh`hrxvYhcvR*S!%^Q|3*1UY_F2UtGTuCi68x{Nc3o;HDl_)q$JJbPn-aovs-= z&R=^_9UQt?864X0%|hT$(KJOY@!7b(i1Em=*jnypnP7l#3#OAUY9_Uq>oC1TFLzs( z^LiqSwAbT#U!r~=3sceD{rj}GRjqymE+H`0u8ZEhtMm?Ch!SvwqqNCdSD9>MczOB8 zEu=+b-Mi{TXG*xQA+qsxvcPKflaD8_zxYwvP&AMC!Yf?#n9!hqY|nYQorYcRfnIjYL=!ld5R6cNbXkD*$dCmB?njpp;jcXFQnvKv8_n!8`LP_^qQ{txz9vJN z4vIC5ChpKX59PdbWA&FTc+ewag z@k~1dE4fHybCe?}Ds^BTeXt};P{fVeO7}U8x0hES-T!bq_?rOoPB_Ex1Q~nbF*+o!OAUvfnuuSKB`@8i`&u72|BG-|m} zHmsxZ)v9a8qEjQoCt2s3@Gjn*(1m&O7QevjpI^2ZkqrO&gV!F8Y0@M0%ywTR>Uvu^ zlR^lr|KjR)U}1g@R$k}HYrJ?<`3{wyFW$+D-ER4XXU${jnqHPf^hSCh?|{joxM)6{ej2N@yJ$^Ax<}!mDB~vB+4m*MBnYLenF6=UBWvSk!veg;_^;LV<=F zai+iI8g~R?%@!5|?S0QyA$=RWTTPa*$4_3ynqvexxatp8+;I;vwA?hB*#>S(`r5q^ z@>`#HSHQa2_;Np>Ir>6DnSZlz{PO;wK;;17d${l9k~@}R^L;Oe^Y3;q#9`$NEb_P; z)WX(7-ZZs^lXXRG-5U-RfPUnhP9i zpUzs_gx}Y$M7g(Gp=&wzh_Z8T=#KMY~Z7! zKe*&BbJ+iI`!1n>A(rseM@`x1QRK$)j|Iqp0g z0tvSrtiM1U>9yZ?F?@ml_?k|ZUFR4JFa>2Fs}5mzA1jKI#s{-;UWx2#5U2~;3v^vx zqN&}4)94@ADtoHlXub}$7>ew*i{QpGMH$lm_L9hl07jWzhwYcqd`K9m=tk-E+w~6B z+r_lAXI5I@3A&nO7QAY3$z^bv&u4xf8!((i!F}hL5RH@Fl@sSKJfaJ?PgLVsQb0hG zxz6Q2=HTG)zQyk*lWg$DX5%t4C^JLg{znib%-)w>m!Kn;RY8P;{5J^pxh%y!RM|&S z>(G6+n5E$*&$Jv{YsfSgslu(v+&li=fCSH+^h zsL;K->-Oc6gz4ILe{WvC4n;IuC;IXH5$8Og;Ge)9Q1k3IZ$!SBF#mwIu6@;0W_OtH znnoSBvhC#b1yACz? zhj7*|hGARLC*2)q--ES!E|>XVZ}rwurUF4zl-W1)nf(L${3L?HhF!Bzdh@AJ+AsQOr=mDVu25cEHoH13SNTrA5;?*qk)d_3YW{BYX^4s}IkdDT|F z3-UbG&Pa3WPrNCvR@VXOd#OovVV;20d!zF%ul{uZ)sMdry9Wx{@;+@|rlrQaCcs0V z`|sUc!rNh*a-9A#-kO=Cc=xj$PELkw{l;l-e_F!*t6{(6ngZ<*=X`t^lg96c#2KT6 zu)u~yA;t0bmq=RA!tti|$D>`x97|nV2h-Q~o8S98>tt5|x^rQJGNIKsw5y+$gAS(cy`@Cx`(we~*m}Uk+b#Da#OU^qL_bmU z_e|Kl^nVyOO3SR9Dat1<9ZsF{)@4rkXET)G(_y&(rDiH}(?T&|y=eLMBc2I268*|^ z3<~x}wUg$3#RmB)r19xh>N{V=2Jg$z+?uaI-_ltnzUTYCKQM?CI_Y<_GUQE}iFIQhy&;v$!(t{H{>_UM(P1HNSq$&Bg7{ zu|Z;N{Q1B$V&i&6Wfc_*mB-GHg#?-`yD?+4v-9spU`Sfx6=)(b5Kl-xFRqdzCFe&Y zY;6&2>3+#NC5#J8k?c^3e8;c-&)@s6f?pF$YS`A7&3Z<q$DW1#l^|D zI}zgLZT4NcC=vJSseWz?RFDu9%iG=hAk|%GSALbtP`k!$NEmR3LcNf^ zg{XVq&S;cw%Vo;*Ao0=C#4uCq=ceV{pW<6J;KUX8bV82N=H^xBbCt$(1L!{Re#SJ^hO>2YZixRRy93F}YU%Xc9|R z-A8lbVZXHXU%(BFu8rWr)2{>D_w8DaS4iDRvpyG%<~%<(ai$Vqq(x%D%?W1LG*ZpD z-|7#n$@84fyF;$GNC^0N8{|W8MbOWkuRGUO zuQZq)MaX+iI)AhH`@AA>ZXfhIe{)Ve_02pVO5LhgIs9D0TSOwdqX9iACKx04e=Bq2^7 zY>UjFTakf<#So?EeC0=>>5AHtL91T0{Wosf1o`+v${2lG5!*6SPw*1l%2eTHUUgAZXojGwO6;>Q$$kEm?4H`eBga8dWDEIO zAZ;EzE&F(V(45C3Ao6;rd=(sN>3yI?O8jL$IXO9oQ5c^Q65*jZqQ6pYoMNr@$iDu( z|L3mYE|^OesGJseEu6{itKXGww~eT z1;onuK4bpU5w|59m0!@vXm%PIqk{JHyOEpEm{ED_A?s@a)89)?4Jy=EZCgFc=_zjf z6Ljn66*Ql_6u7g4;v5$cu&v;m;9h19W3LT9yrXK-OPclwqm15Q&M za~1=?NMa*S-VQ{FWVIaW&BN30JN4hD`i`oHxCUKt1pp7L_)8fI$}2}9Zx&C{_{1iW1UHy zAQ$noX#(%em$%c0xDE8bH{Fgk z6Vq&LQ9a`-;Q2exHhClEQ%EZmzwE|j<>X8Fe}?Kfv4l9yMDvv4!^3l-CojK;7otin zstbcaPrDjvil?dt6JJY0C^$6FY9N{2B_HS1G5tq?;g-TBb74A{UJE-`&F{s8v6go; zLq+pPg`j(=^7G5(qvjp%rQPeR=P9_+b^4toPoDkW(7iS3=9^nE*Km{;VBg;z^l$nr zA!P9lp;M(4e2um)bq#GsM|%f7Vxys@r=TcQc0K-aa%}Ks71D`ylPqpA)(VI|gj78M zA<7L!oa8Uc=GUkX%O4Xz#hY=k{P_!A{rhpr@<6ic`b7DQM^$x%iRIlc2i#<-HqsjM zKTV)#BgTw~P{A!}NW;5&g6eMbwd6v2Tqy+U(hZEOMdMOvKEb(WPB0=h0XWw^S|^z` z2NlWN;)8@4SH3LhoZ~OC4>1UiKlAjS3+|u_1e|dc*no;OWA;iB0w0O^(TfuY8}ulC z+S$?IYW{3$3*CEvzVSh*BkpMqE2FF{A=?A->FU)U!6Mi{U)19qin`Y!PR$|uC&tQY=o6)ts}%5u=NxxAY6TRtz|VYa8^$f0>OTPiOlkG-A-)iCr|tw+n~`D z_gEM)b*}n(DF}G=FaflIfLZC(dyMw$w;>DZPAxnpgH8PNV}aJFk{0AwOl8F;Xe|hd z29f<4f51lL>D#yD3F+j=SN>$(PRPtO0O6S!$J)U0ztC1)s9A2z%oOp?mp5a0O%OUG zaxJx&=8z<0JO|Gmr0AUAJtX_nmrpf`@$JGmF10j`VxOdgD*J+?Jn+(>=qC;f#xn7* zJoj;wl>U|sQw1*fhJEz5`B$Cj{F_b@gtKMkKF46y&@l=vH%*7R9bUGgM6?`?W@J+r z$4SpjJwTsC`+3yQq}+({4KOzGQn=(hFw^|=Y}cR)8@3d7k=oqW-XI71#l(UrbTyJ;<@@V^D2Nl8@%n%azUvx`!taL^8qXF`#Y9dEf z39J4;X(u#b+UtVM(q50HTLq}jg z*h-CqK@gD<=5Pa|)ApVB66g!wv}!?FA%72g@3D}J(GUZEs(@R+>jb8msxCwi5n#H>XV{?i7a)ec?jDkT3%js4ZRNkmfdMKibw=RUyYFO?Y4y zNy;J&$Bv2dRo(3(=rlu+rlNnFaIA!sb(YVnd=2&&5`iupnTgnw7-4jqho##8z z`tnq8yzH0$dm8kLiXxis5=;A~ibc2!A!5#p<7ZNCuwPn(_diC8W6Ot(RQ_a57d1~$ zTkImEu-W0##DM*C-AMKB1AE{ZV2P4Tgs&_Cg+Ad&`g`@_hwvoy-&fXHMCOp6|n%yeJ0q{=xqoJ|A1e`8$%ap1{cXjwRZqx30bsz_HlT#$|Ey`YOVxC45D33;Cz z&!DqYBsHmJ`zf)NWD8NSeCjrIR_U3!WGLvDbL^{S#3fgg!Mu=xlx;>?D5 zqOSMVV06l0#gwhNx~evp8N3uo)^qdiV`XvsPOSPirRuOJw_rug>09VPj&fb!9wTXY zkVkldqVWE6C}2M=d1Qk`1VCYr?|43&*@sWeBx`b(lvxld{N-<@?AiQFRBCIr7EeZA>;H8x@ExbmQe^yQWreL$TT>Jvc z+kI6GYnfQ@RXQtQYiR3taQd&nLcErX#l7FOb7aYEVkSr+3}+95PAvx2$kVfn<|vM6 zGrUu>P!x@z1uLL`>Ci2V>n$=>U&M*EDlQP66a+cn-0L)URL+6Kr_D-9W&}ks_zmDe z^S$y=zHNzPW(8%RfjfSg-Xz28)fiT<=qv`iv?-8n))N!tM`(!9;1O=Y(uu=_w_f;-+a$KE0UUd8i>NCgcvJf zMFY@4P-$l;OWO{;66mGEbfBfa#&-Y%iP5YfQ^Vi<{Id1Q^3l=GD5i;bk^?EJV3xmk zZ6J7=rv~X?b^E**d5)n7n#{5(>|tjR_nKF-(#u4eR-qeP3np_m$ghvx`d159z9b!) z(mGHk zp0LWTK=_}=&8gbUQE^GW#n2`E9(uhc8v!-jK)T@vbwpk+GcH-e=GP$M)P1X3ne5Sj z%c5KeV#fx&A|@>oQ?fbw$T~R+2GCRI*D23MgAX?wtM##6ZUTLkEp!j8)9iP2gF`TU zna0#iY${Nl3YRjqBt#J5)-$L7Yr-ayP z$Wu=LPcL|CJPy64P$0uozp zAXW5XSy|lPAi7-9(25csT+nNONW9}PEDsJTp#qY zD9y-XdvY1@OEur8x%AFGim;?cT*T0R&f6@Je)cXux$v#=h=u^dS^;!03E;qk=k#uu zA}e{w&$YW|})jmRg-0438R!Br*S6QV049?n(0M(;=mB^)SG%;Dy3IStl1N_DLzX`;!p&{$-=CS(hGP_T9-k)NeP4Uv{(#Ow zY+T!-;Fb3CewJoIHA>Xf7UoH1Z;iwaT@- zo|#TOW_J$(g%s(s!&X0cCx7mf$S#4y)2ooe45U1bLm;21<Mf$^2h$J&0b)ZjTMj0mwf_ce*{{`&e(Iw}$R&7$L6%rOU=L-5Lgf!aStG`w%_|8F?%WlkP79779pQIm+C&^@i6BdttTM` zKLjdGG~&(|#H=%i>^aDX%(Vvt&Ppxh6wMFinL~T43LT%Ki&6*r;uuw-%3!kLn?h)? zvXv&4ONs@dxY57IGfmbk0-Tr{AFcMQ^xQ0M^4hixA8hr{&n1lu(7ZmV%oxzK^hnk} z!yV)NE5FwtItq}v{W`Q1AihcsDARlpNS1K_H6Kp8PWlT93LIauz^TK8B@>j70T>&` z-=lRKe`+CnMXS$0dxids?vyhw&{m*J&FMZ1#XytKv@-Sl!ITE$ni2j70Qu;4WQBI52kG})Y3#KrI<1z`7lJ$611GeOyyJd)vTHo;>YzvP! z&CO6&fvU2Py6^LTFKrM-4*xs(aVF8@)EtdHkeP=y|I^?)RkIvg0S+w9gMF$^$+BwzM3602JL=>t5nLor*H= zdPbR}^ql>lbwv#=1{I#(`TYD_P6U_fFI;;(*bfJfUl;aLlpcy5vyC*s%{0tNJ@Poc z@64@68Pfap`6(&v7Rlk?noCPd4^}7gYu}x~g)DzQkW!Iagv|TaLhi;*ax&P$)xNn) z5?l=Zn%dgUd-v%c1dHEA<|Sm%jm1}sa_Kcvv;W;xrjjFfG;Fm!vfNJZw(>oXn~8|P>AElqS8~`q!lVPj3+I5MPaE%YJm6)^DxSQ00FSLnBY@_i7dOLMOvt8+7GJ`b`ivmum0yl3d3R7#UkC}@~~`Ph-4`9 zIy_0sHz=c71fSMtGQ$=`A z!Ptxa$>|1ooinUgW?$W1BzB{q#)yh)>MVgZJGQhlhdI^hgR0Get)^C7V?;mKOyr~y z!V0(tBP}5T4oBF^>N{3{6_p~l9;{f`{jvOGPNW2QcGmjRirR(5OeYYDc;(O~(e_q* z3;BwaKONxSmGv=V_SX&2KvbkzrN9&Uvk>NdpAUmhRJw>Vuk0mFND!g@7(S-#q%ljD zU3$kYsz%lgsg%&{+r;N}V1*2B=^ZnM0r&!5#weOS2%TdS{hd+QbtI?MyFlUan*>5R zU`$uUU`yg1a`QT?Yg9>{SSuYXAu=gkBzD}( z_OdV2#bL29;)Aq6uOK#OpPGiJ+r+KerKbD`R!L8u!#+d*mMqvo5Rnc%+hy`!5V>gT zq3s_G+-BC@B17A!-Y4f}f%_RS?7P5zQXTkOXZ`%i2=C<;d6*-{I*5{6_w9MNkBffF zgb#Sqs9A5qF3t)iMeqw>-wWC~fT+MEPY-f)5~LgIq$MPbL&;#vbmE~tAR>0p7H(d!79y{DKCjcQsD0tRw6lxLl#^w9P_qL0Lrh#8 zan~xLOaqd=6Uu`gJVrTx!!d2v*Swq^$6{YPj#fn812}_D$3f}vJ-f^5vAKaJI$_&l zD=PuE7hRim2w&JMn)A>%@P2L)_QkcYRri0>taNe8a=#9b7wvHxNR|Mt4gJ&^cIfQ7 zw{%nWP=Rr^0h&AhviFQR-MiN!2wSA299Hyig32t<+}tV5gVI6oZP zjEDMxQWQGb>sS0`tKp-cgSSFIh;vjte;JpHQ$gYL1t9>qlHrD__jxFByvGqo3#6e* zAQugQ_9Xe<7hd&^!`ftJenv1HgSHV^`|8zf{@t$|wWm+ z;h=`u>BdVPRlaW|CkG%x_4mO(95Pr3@q>Pko8PJP*G1sjkkBj4x^hmIAc&TRu&K~> zrLyGJwuYVot%4CTmV3Rg!@GHy-#y8h#DZN$ zd;rZ*A|f3}HLlwif7|c3u0MYP7x_#<^s89$7k8`lV3IE7NcDiY$I(;!_^uD<(z2vJ z`=1#%k$IO(bkcP)_=cR3@RE;>GF=xH85L8peaqPiMhkD<(2=E&A|;`mTWTHxjiY9~ zo8h#5nlML2d!YRN#VTm`^djda2g76B(x{iQZhUH~&wc@s{z8(lFRzll=?sFhb`7+& z#Cox<_HbCUZ$S*}mnX=G@2ebCTl2hS>xhKEMNGG!1O(}!y6{$-J0baD7Zfw-SJqS_oONasjHp8eG?}{vZ`pl zjlr|+9TlEC(Yj*Cs9DKocjL3ijP}^!j&NI?QV&5EAIp;}`Ye2;RePCqZp*jE>IIdAHg1Oss3^MKI zy84AQ*q0*g)%dG3FSyI3zSQ1dGfM51Pdon9$5IyT_80sIJkyLEzh>|$41I9yOYhrX zrSIt9Q^25{26q@9x(Nz2DOo7n>qq()7<;s=asQSI0A<+Emcg#V;x|?o30>h z-YZ(%T^R+Iz3zRGTXtkfjrsOog<rsdlEHTfT)TJCr7?QQHth}OS`RG z60yb}lvfp`n06dY-@e6eaX4}SqAr;<2{Nq~=3}+HZM_V;&gxENWa6dnQYMn+`w?Bs zYsQ+z!e0$;2yFaHDjd*nDt7;-RMlR+aF4T3kaFX$3>-I)K{PfoBOqI_vkD;UJ z8ypt0Ctl0ulWD32Qra(1UjF!T*~swZncnI}i^CH0T35ZU8%l7Z4ZBOw0}#-s#w7DE z)F?xRVV_SaZO^;}<+x<@$D}Bfjo?$$PQc1J)*G%~q{mH9Ut}M;qs2;$@*?YH`S)Ui zBM^kk2GwxXj{rx?;en|dqWQqop1lRASh?{9ak=UxW7ivz~T;L|#pWW4>cnp{~~AMH4~Rk6Ob6w5kG7w3pt^UCA8O z=Ebp$!ii1Bf|>|@;>5dUMac9Kfn3D6H_YxGnOK8a6~PJX*kZghGR^1ox0?p@L#ZcS z#Y2o=06g(zrC(&7DF=2|LxHzeuXd2${uP(T!G^xZ?X^HFnjLjM)v2{4cQ3SFx$Bp? zE7=c%xtQZcNJ%VqvxdaRl*Me#4LmfWz=YkFa2p{GT=Uh6OApo{MN62?vYf;j4=gOP z95a)<|J|{@A4qMH5jSg|Wu>pLpK+Nb_(Ous^27wT0OOz9Q3ZjWvd5lO6wziV6Vt+- z+-AUKFFb$jzO5rdz<&EuB3>)XfLCBo60Wv);Q_19mlt}B?+kHv4ebg-(BwfXe@f@8#3+oW?C}4sDA3ro1%aRUu3C^ zmM+?b2-7YQxb&{HEJOT)e)a~K=|<&OCEti10`q@O0W&+AVG0~ z4aI{QM$(x5n0sF?ww{oCsmLuc?>&%wJMp%AEW2KtSL;_k z2Yw%?a94y@UV%s3;>y$b!_?+`ez=y6cXB^J0j-0Y*GSPST&08ViG=ff>KQHt1>1?> z2L0Nn&-`?D*1|4HF#?RU>n)kz11H4PBW+y(u30M6${Fn_)85)bC#=FV2F zu=>y~`vZf+JY=Y3f38brfOkVg^ZVKR1ix7a@c-64)eCWZIJRJSMp>A0*|^J?{|KMA zTBlQ{-brElPd}~YtI(RXbRvQK3MWC2X6--y@Xs}rx0T>Jv6m_O`)iCYccSbLTTTdI z11k(VT^9*uzP<|B{P@%9jur3WpBcGxU5Pszc2;&34ODQLPb7R6`WA1{)Ux`|k6J-7 zdFF3?OoEBQ%jB(tE&Xqr-qPI1(T)wXykcbZx7O}1YGho&^+Z`9c^#gDr%-Yu9{Ra; zHP^Ci>{FTOGgAXTfe{fGU$mwt@3yhNh7$A20-N>{$XF(JxITt;mc=$PWf2dB41(Yu%^Y- zW~lg1@T@LKC(Sa8lau$-Tg1@|}4dM9ta)}$h?z6%kfRY|?#t_$NdM2imn%nrLo2mO;(A~tLe6-HtATcXM5sQf$-2|Tg{_Kp%-X=!%YQqh zv%u@bSx@rVzpG~Z(#;#L`>~16b@eK%Zx>X>-M@;;M^dZHmh-?m7muR0y^sqp|+b-flZm?YhEoC$FH3yzo9CM`r8v5Ns=h zGairD$1W!PgAgd9z66$ExxumK)_n5<9D{3yuaauewjVu)AelGiDAcgtBwazJWM}h( z&0!v8Ax-Q!!aO8VeMIrXPjozdC4Z?uadM4K(CrC~!%Z4HL zua%W5A$86_f7`-mUTp>f#X~aU%6h+{GlZn1A4LKA)u+IPo=*&Lnqa=gcQ$Efg7#B- zrXY(T?@Uvp!&mT9|X9Gs|CDf-IUJh-$G#meLk`8&av$XVLsP4Mw zx{SBkpOq;{ytUUd-U2D!=zHxeT>B=E%|{{dF~bp^1+{uk;D%N}-RP55^Yhu_<rBb*E>sT`WF`$-ML;f`g&X; zouDowDNG7uK!aH{z|?V=yD8%G#jpC@WxzlEL(y_F^RK=1iCVu~Wl-$QWw4Xx3lb8j z5n=0^8Wke9FAWDe{n-f=4Ubv*ux4B{n4KM&Ures6*k4!UsN|)C;?lB*lUhrV{O<#X z74sFMJ6po9t7|+F;euBXjRks;H$2J)N3`F-RGe%=5M_z*nz3Ea0E|;2v>o!R>vh z=Vc0mAAm(clccmvU{4@cID`y3nyeWFou2mxwbMRfBQ1#jqSX8*(KX55(p<_|=(F*x zWQ-Z?kED5@#F#amo)z8THAHd*aQGl(0oyu7?e zyW>YpmIb#}6En+MNZj6qL<_fGHq{yPH#(<|&Jlq>KqxEqbrf~w*3IwRjnq2BmkN`? zlD#%B)TVL%2%r&@_hVz_&hEKL_209r7FNrL%F_Q5C<>EPlhBd()F5ABdKCba<%e#0 z)f*0YmIZ(NlOI0hiz;_-zJ|AI=op1X^&P|?EifT|6~ZaCd`ipL*VhRTRhfq9iAVU> zIh?zf45w|8MpW0~EVe35Ff+~xI9LI3wmGCEi_OUzVb7A0iD3V5cy@*haFI)fTPu9= zhP2=CpYv5n2n9R!py$#Mp?pHpUs6lH$^uc4P4s3i+Z=VWo{))Om@Kz4&k(d^hg(kW zT&yI_IFWwbh6o7ACB6GmLHhGV29(lJ+zQ^E`p)lpmE`nGL85l?4dfkV1l8A!N&sq|8y`Zd2u)Ni8 z!z|Y|8~B;v@9=lKKB>L{l%UB}7%+`?9qk^uC--GZR%K>)g|Qp?G#bT!P|T;F_TRE% z!#W0z2X)qPfiBPh>X5i9GE42$QLw`t6abRK-YVYn5aN5H0Fl%PiB}DSy?lA&;fcMC z^6mHb6zkHM`Yxx>Y*;IF1dt+I_$=e(g5W3*TTgKmvKKg*lavf`ehUOgfv<+9w*WRD zA0LMLvglOtvuEr19S=|K(e1j>laQ`;megA{taX_-cj(Lssc~M1_ZOsba&r%YNc(FY zRN~*C2`6P{!>{>kfwUv0+bNMj-4=zI1((g1ax8Lw2rSyg0cZt`Q$+@?pj+gVTcAU2 zdH{t2SC!kun7}p35TLqrn%)VP`=}3W?uWUjpsJ;0WYCoHCkDhRX=p?uT}&ydsisr8 zKqd88BxRoR3Jc`C5_iAP`by*K7e@;$=B(pamVPWd7m9(V<+U`hJG*d58o=_Q5Y#)T zzP-KuA%HfPq_-7ko{U7DA)!vAO6?dX=;!#fx9uMKp02v+_xf04pYhdw;G{U6iBT8M zt10_vPSeGtyU{tAl7GsexQ*te!|pQFs6UN7qtHmR6CqG?hL%39SH&R@LYp>LM`~4B6I}Ho#jkD= zxqRD0C*wgC(Zv;Plviip|DPirJ`E{v;TZ=vMEoV=!pTt(I8TwD&Kuw)9ruwdtd4B! zrg(CSQzlMj4y9^*&jC8=H!iGZe>)*@WI4zo(YUSCZby%$@>m<^=xi z7@@^(`IfRyy))18%*kA%ooa zb4Wlu6-v7Ypy%`{tPaQxbDq}cD>2ANLa5aV+z16Rdvx5`?TE5Le_5gDPal8nerQN? zh(Eg`=o?51>Mma<^dvqk^7ZkV&31c;N5Fb*9*LtvMdo|BM*Ge8&90$kuG1%K07tH% zZ2kstC45k;RVNYzGcKxMode-kLVn(bD|N}VXfXH%Ab{4U=Ro}t{$e4O2I7;0;4+zX zIAGxH4DrlAEkA)n)5%u|zQEP_@6snWe!CS6Gc5yyOi+DYZ8fl!bOd!e)Sg4{78 z^A1v)`Lo7juP^qy9_{_y2E+ilOxV-``U>j}Xbl^nXy^GTjN}aR|{p8l0XokN4 z2#N)QpqyH8o;8=5EUX@DvX#l2ov;!(@?y$b^=}&Tu2$)cxhlz%7D|*j9zCba@{GW0XWIxF|De-2=?g|rsjvbM@|79K5;!|MBe`2H85v9JS!l^kTYRzb7Wq5Ozb8n0cw8+?+j%#J8eX%wL0oM0&FSh{LhUPrK}1MXJLq+hIFx0YKyannKfJ-4l9^e&biYvb zCk?iAgzCFUj&kzZ7Z&AbR~jD&zRu|uLcVEfcTg5p7(>pHStU*NMZO{JDk*{&{9Ab5 z-|;T-%sOQO8px%nJTGfuF_I@Q06o2#P|31lF8P>o%slNQ8`hAmk&)3iYtes(4h&f| zoeLL!cr??0_zB$JHZy44bG9>~FdHiq;`#w3sbwTICVKEe@qARtgn>x40deVXOcDGGg!Xa1LEmqlrr+To?X zp8X!TsA@!LqslVm=w@d2xTw?88;X<%??NOy z+YMKF9`Us*=b&Nm34)Ztm{}Y{`sUH;SV_t<(SqOaiL?2%xL5}O=?gb&`BpPkzbv(624R7GXpow z=#7fjk=3S|2k0|+H`?>}_WWhw3N{jy7AR){fCt;>*( zTZ@qvU67_M+I4F?Q?a}6_p>$U`**%`elzd){odz&pZ9sZTJkPebX8xXPwHQ9x>;J< z0riR30A6b|NekOrh5k{*93i_7@lSnOWBW=4 zKl^Jq9_e|B>h3drCnDqdeEt=wnnnvlxC6sL6jmxrUFT`2B<6}SQ&#dk;=!7yCj6M$ zfYXZ}`HhI`4#!>BbDT3|fLt3Eszo7#E*HI#yGn3yuuZ#+P1Lc~($(D$lwO0*&dzdA z*PNYtq!+@q*!JMf`=+PhR)#cUAJn?yo`ua0C&5{w8 zE1RX8UPVwZqk-2F$ zP_Vt~A98~YugJ$rUL&XaII&Jm> zgwlmr7{x(KZ@@R@TK(L{0nPL{0I6XCYs10O=7c+(P~?|(Juh#%AXS=)J#jYCs-!|| zv=<`e-TeBd22dUt=Nw6mCR7Vc%gRDL7Zk|bIuh`5?yQ!K=~c!J#jZjq98?#?MJToY z<87c|R?8HearP6WFCpbAgmRHw{`P|%fg+e68UFR$?Yi)(dsmGIY`l6^i7=(O^(&>I zMfYpk4M6*1M_~lVw(STIe&?NB=1ReJXBi)l&vY9ZsPw6yik5ut`zi`|s1X8YCIeFLLI{u>FIqlKnPD&!K#@7c^>vtY4S`LyG1m!GE-ux|?2&)hW z6lP}LJZglL@!Z&Rwq#$2y=6D$bQPBIC7@IlIc(x z5BbrDT@yWeW^BkjUgfnA6(JhbyR29~##40u@~dbBGZxwy)S69d7TdO#e$J z&yXl_d-`$xL6OMpY_vK^ehrj+9Ln5m@pO0CbBpH37rP=g78SJyea{sDg6yA&Wt@i?wpwtsWhO4Ck5qy$C-x_QWS}9L|_v2luYy~0i|{i@u#qpwg4SV!D;LW zVAV#NYz5f6I+Z2Thbh5xntlhkjb4pg=7LMod5<;=e5o1>JURsxcMmgE6zsFbpe4Q{9!o8>So@HbZ%%b0QO8kixkpu! zw%qmOkqCv}_i2vV%xv_W*kXW^ElJ++*cWH-WGf&Haf5m^PYWH?OEaY|5vuI nI}iKo^yXV52#Bpj+p&M~RR&U8ze-!Te?#kDe3O+lx~oe?gl|Rq@}x4x=XsdeuGbZpZD|f4>0%6 znK@_9-g~XJ*M!N-i6g<|!GnQ;AxTPzDuRJQP=kSiYk**YBa0&=hhSjv#pWU+@{%GV zMDh-{CgxVgU|8VU18lI~1r{umv#{V89Ws;aG~OHuXA!2YL12c$!UJ$Gmr!mUN#RPdr{+FOIq1 zfyMLJ3C2JSfyE4tVZwMcvXJEE;@%R2fg=)uYiD=w7=g6>{U5=;H{P9m_JP%o+%G(< zoo#!0)+HZ`99jbdgU%rs8d=NF^@MpVOW?-5`WMD41~$9nG6Qzj#&1-niH-FCCI;;I%{Y%uLa6jT#h6y+yQwoTv2JN zuo1@iY0l?d@;1%1v^#D@F6Q*GW;k?hbO<%Sa`riE@vJQ&l_a$}go2wYO!!34DN*>Q zl!9wSwexY#x1DRp-t^a)U2Z>*RTLMl&4lByar47y6&2U8anyY0ouzw9={Og5A++@4 z9W}T&`U_`b;3f;N@D69@?m+71VfT0_*XTwN?6Ca@htQKpJPt{1D)_`p0>;aDUPFss zPg{cP$Db@1B0qOMLgO#HA{}pHrtkD)ul!|H!@d!bo3*}RGD`B1(uz7*Q{4NH*rP8} znypYuR0|M6B}3w`At$%PCqu;G)>Ak(sn@f1Xb>|JGsms_XC`vOgpV<+cQbLY)qv~W zAC5f#u-$ua3ZJW+R#CtK(Vp%-TR$?Z@)K&U6vX#|@Ph5FC0G#$xS8$%8eENuW%3>h z-RIl_KVEqV3qge6kcPD)mU<}Zez2$Dengm}ehI#i=t4B8{xd|dRxo$jsD}^_g4CRd zQNDO~5a|#jYXoMns_o9>ur>j(f`}j5rJ0ad0wh8Hr>I!DLQ*l@`H;9mJE#~AfxJWl zRByic8)QR;qJ(7=m?0>Gu!IWap_LJy5Ho@na%_s;HNheY<&ES2ejm|}sYa+07bjv4G-j4y&(1X_Rzyg{h^js}!%ijw8Ez9u6P`j$r2z9zCj%RU zV5ZGvTQwRLXv@GKUDcIe=b#QPtoZBRXhvFh>-4VlM(M3?+HrErp_m3-^op&=+8x*} z+QZr-HLz<5*u3HJ>)T8?{on@cNt78m*1fxlvKGC`xB+`gdK(SJB9x&gcSiL}Rzn;TIc zk%p*g5+IW@tezs20;ir@nqrl0_5ILg-mrSPdTjgDp~->JL93Csk<=k+E7%+)8@}^l zbG&Z+yIGPs={cu6pL?QbtY^+6+?~#yJv0}zbdX&T8@w_6E>^cwV7avEgwk)Gy>Gu= ze`nzoG1#f2*6S_$-$O$p@KZ4;JE=q{(aBrMx0KzghvjVL#Fy4;7OU@lW%)2K?_PXv zu`M!~l+cGg$XKh}udY^kI^Fp|Q~4!Fs&bG!fs}@i2IITMcb)GLGmzhtl>4TCTZ~#r zT6oMb6h(fYntnUuzV9)^_`OY!ib?AYbp-kcN<%FXu`W%Ke1)8e66WIKZ@7giCG**L z65;th(_dy6N@jA{%FD`+Dl+o4zj^6~6m?BYPS00N6HOb?k3K1DRYmMxS;Y-MJgY^G-7)&*j(X5YYl%et={sBP37+E(N+ zkAM? ze3)p*W#^M-X<5n9hegM_ti#eHmLs|OCv#h?EGwVk=R5SD{Q> z#3jN}K`kiGNXxkQL^1+0n7_~%-nR0#us@0fdWb3nayr;=-S;0T3@Wq~C7O9Uxj8vs zcC$nqKO{!d)oWz7J&wZv#IjUzs!-NRsXl+C+52?(>6>9CGa7TBL2D)Ce8ORvnu?YC zA!lD?P1Z&1!SM3X+epVy+Akj1C#brZFT5SZ`X4*Za+M71H{Ogzst$T&Y-Koc?uj_) zolk5P$A`uTD+^o5?5npD2&Am06eiYDlJV2hA|bIY^nxpIHKvn$JI>&dOYvn01zvA+5ibS&}f>$gwqpR@&-eZH5e zlrxk*e~$N2*22)5Qnysn^pM$}8|7}0Q|9>Wd3V-|aZIVPA9+BF_ZumQvO{uW07szj z(Q`Ncq&RA7cKkH(QEz7O-=_HV98N8??r z(UTUzrWjZKeS_U z+Bfr-!%ct`@=T zA5H?78+jT$caWxt_e6gpRDCu%)eM-^@bvEYD%zFo zkAv+>Ur%Z?eS9`1JE6WZKYM>=`eSS)D+~XM;K-xuu%}iK@ z=Q=_>D!K)`HS=@LQ`zKV-U;2Rvka6huXonH_qj-ictJE~tJTK$F zOV1BK7u#S81||q5DJrDw27Z_U*CO}nrY~t&l#1met`s$VSWE1zvU{E=izp^_0#`x| zF;XCUjzTdR5}ER|LVQk)REn|84%gIE*2yn#?wh3x#N#dgG3^8IOpnodk1W2&%-!@0 z9?Pb`SLesmYpPTm4WL)2 zo6!7qE--}Pf?&4m2_>1K-;mKk;gN%Pd3r3fA;myEb9nl0Wyo;KXq?sPdp^fPnOHW* z57e4e6-x{GF4Zo)>Jso!1*Tc8a(!=mWP&fq0;YNpA04;W*7K@Q*7Vhz+`g9T{M3+2 zVxZ@8*y4;Ue!=?RtYk?})!No$&vJ+IRU!}aXBS@?onJ57 zra6>p)+b(!B3O@0V#f+wQp#ncSq(KSVP51mVz-A(ELRgdvt5xm^(RBZLtln zUT>2TPxEPTE>(u{D(io%l+Oj#`eI)-{B$jz!n7xX%XtsE*_HPr+ZA5(`RW4CixG}Of(O*Zg&&sEXB$08 zrl%?~R%F|kdz@8-47&s7cjmhaTyBr~n4<}@3ba7JtbSS2?7JbNci~%JzrK@ z^9KxN)Nyp&axm%Cm}IXRC*?YHW-D|VjR)hIzY*~5dkVm!NUgNElRNGVe^tStN>bDM zEmCFBgFa)DZNL2Y?vSvDlH-C8mYJ{aXWn(Uf1*d)zPZwrNn5-jOt@O~iGzG-i|YzO zk$UFc9m2>+dqW?l`;CbD<;LfQ5&@eIgo-)nyf@i{xqCNVXT8`jIk?dizFpDwd~P|E zzde?v`~6c1HscE>STe`0ReW9@6zaZdg+2dD-XXX|mQ_Y42B=W(<0mbe-4HVtvJQu~MHh z#E$hsEwk?QZkA7G!xyj74Ol^*Pv4cl#*#}9#t@4b9WOP;4pfn5ayv_9y6@mNUN2aB zjUr|`)itDZ+IOO2$an+uO9IwW=qb*>tAy*%{!e#=Vlf$|fkh^CrX#1UoZ`fbM<@{b zp;)NmOSbZ&`O!g1s#ZQNd)|HTyl-=sJWhVXRd>#yF=Vx#-|d%FKsbvKL=kY2 zm~pkBe{Yp{pYB4@pDovRcsQ!ZXO~WUy1#mF{V|nw;1;fN5#iIj)%WO#IOi?97m$H( zh>`GEney#B1L1bmUa0?y&dL)e_>E-#RZL&m_k;`t)ci?_2?qk0FX0O8#eSLDhC*h93<7vRa z!BS&Q%gu^M9lW8E<;?d4Vv$NAWi=JflY%6j*uHl@OJ?GqFMsQ^VzI9_8`n+Utor!u z3^}v3-EM@t1%e+z;vv*BTsFF%tnBm&^VPChOjEgUeHGv8#kXbEOMpfnAa+z@Lk48UTmP33RJY5 zf0-CmaBX%uLL4ZtVVeEnju?Oc@ijgBv4#m2Ua$;#n{Et+ZHjNttx_6ImL^o+j5CYR z$0$V+@KD=FO&#ntOzreIy*xjGC!yTv5fR#)`*{eBrgM$-9a*f=n;x8!QyV2R>aHY1 zS_#!9!%E!5DMev#C%t_ru#1XNWcldwP060c>Y4k_VZ_DV=GnsCdEm4A{lV&^ob0b! zV14nC;8FU97@FzydfQP>fZsk$CWDe(!GF632}xj*1V~Vem*HNX z9H@iHZ|xgw^uE z5A7P0$d;Gqhn)^?v+-=OiOxfjwo@kWn`PHXA1KkF5S~3V#cI8JPh!lfBw&{N zp<-6z^>E!=(NpMN@BNgc3u?pH%$n(*Z*@PIF#HQq_&G+myQi=W<>dJct@iSP3p)ru zFL=qfYE~)mXVg!+`w0-iX3XqIzvZIyxH-N$Vp58zF&;9}akBQSGVFtYN818*GFR25 zhHO`{7N7_QC#BfG1#U6Rsy}4Uw634gb0)^+d6_ICFE^B9*tcD%+8XP;=qgQW+Uz*y zjr*K%v6DV-gjG5yT3~qJ&iZwts$ibO)m4nwcLH_Eb=AvZ(Yij2&1bH0fww3C&QR1! zz2tlK-qt*8Ezws{DiSM$3c@-+EPWr}&643TiK>=;5D)E2tMyQ{poYO3g|r@IRSKtl zE_0jU{^6U$xec~8f;oHlsi!EBtB~{CWuiLU9l?L|B{h^P|ne`N<8WY((1=kH|nBIPVjcXu6l5q@q z`~s|Vgo9)nW5|LA%iKe(D`DTT=^s;Pa5O)z-{v3MTdAmLB>e7WFQITA+Dfu_)uQFl z)sQEAI>Cyf*d7kxA0NV;>oDqYqL3j?){U_&Z|uE%854M6#Y0%RN5EmA1CnUtfOxb2 z2mQy}vzx3Ow<&EAhQ5hpt{(Gpi`_QM)=L?ON4?{95VuymkRjN(tL16t@E>J(@ z_w%9qHb3w;P9o$ZXW895hfaQTDnYlpjaJ{vAD)}Ki^4I3?lGHF?dpB&cj=C?Wy7!#~gSOx=rFuaed&Dob2ZNaA3cyk2Rigg=xTG@LRpCSMt zB4*k3kn_WuF+AabXc!drVYayerf|3INohv5(Y)JcJ?{=%XmLeprC0{t*DYq+o3K{YC`SO zy-qt|BVEGw79t`Y`oa2Mdbx=_4z75Rf4#dGYak-=Vpj; z@kX*Zd^Cx%iJiTaYSVr6OYNxX^yzK{qgehGr773Sj)F9J)K#Q!x*h}x3I^KykA-p> zc*$2A*6)sBt~m&+6OY`7$Yz;ELAx3f(7Ft(Q_whCdL*hf-UwuHk+7|_9f23>tgyPc zt(Ma+ms#8?^P9i$nAuOk@jabLut>~9_EEg@ZDiB{V(~t|XXBkYzJ}c2bmayg==`-i}pd??HQw5Uedfi%AG%M#rIeIZl4kcMnyE>hw$>6duP zc_b7gwN%Z|*N5gNr!lb9zvrq9<^4O|eFtf3i;2ygN>yM@;DqcE%yU5S#`+azAH5%r zh7V~T9d2*o3~Q8PpU%4qpbw&*vkSCq*`(wi-Y{WVMhsT2mN(#cQrkWSn+^_UjI92)%bT~%c~ttvxiH2jlNY^+Kv`H^^&$Xe4u zd0aSStJ;&}g`k2G3^bhQE3BWx++BB@gxIf?RCgh9WxfU-+ z3qdXApmrifa~KyozK0y*b7ov}Pt9sY^UV&_kmd2p%gg(S0AfN&*k);owMxZg08@!F z>?p5MpsgOqQBwRl<*zx8p3eI+@N`WdIHpff?^tYNY>wt^!ZK7 znMVj8PU1fD<1+5oSV5A41E#dp)1`N?Qn~~EWeSWXFLGu8ZPW>v&{{^Guq4GHFR#D)Yw`Ve!8yaNGcmb z{=+)fA%SbNx%mq#S&w=E33iYewXWCIr@Q$(uWZTh2cGras?xIR)lS7$j^&cMBc!El zZ2Fy0Tw^Km3Ulf!8Ep9=SQd|KD~xv|%N#1;Cl7OmEO!~MO9M?WC=df56hpU$dWHuJ zp>k_DlI$czg76V_Ntt*QwerOTpy%>HUj2d%%9IlHWpR*bR0~!Pfkp&Qh10Dxu z^&2Bi0f9lC{S`=>NzIJdv~}#Oi;1!*!AZI=GREeY@5o|o69E3u=NVZ7<$;j~8PjiVbvUa^1SL z0PR9(+7aNuUSU$FPAE7kL!AmvBPTqhGmS>XXCLNVnPa&O`DFMB)6Yy0>1SIKc=thXW^#JKYu6?*gEqU^l6|NFV8j>it9O9_A00MxX-#w>WyH=!{DW?ZIdw-)gmWxyVu-FM|=$8va2A)EF_#pn-9%zMilq+yd<| zjI&Q!?z?Wv$iT!3Cl0{{JQ zQo~-q_&f!nU*+1CGFVHOOTu);%%ieLR)Gh002$kX*^T;uSBg9=b?~d~eN`Tjw3$*U z={B}agw_peAq)~;Lrv##^c&{R+ga3rL0Zv0lPX~qt>A3p4yNB*o(#9^E?azXi3D7ofB~T{mMu-6*bBjX2igG(RtpcV)d}h~`R- zJ86B;NnKu%X}#a4#bx#kyjbGeW*revUsYpwzu(h0;c_A1Y<4{%h9x+HnI$zD(tL3( z;hlex?2~!(Qa{#c`;$#Fb#-Ftu~mogp&CQ;h$4hHJ^rW1^`Q7WA1i~7<>hM|u65pB zBI=cs^@a-%GOxjS6r;`H$S9SfpBE%A#{R8IG@mq9yl(g~EF*VU^SlUU<#C?E*Z>_2 zg1V!3C=FNBQ}Wp%m$WHK)fOPkjq8=a@%NUdiD+`5&_x7!W%ylSy3e$3DOg*zCNLNp&2NLEo8J#;D^t-LiBGAHuMoTOx=y<}u`9k%)z zcrr{!!Z1vG>-4)|+^3i^kbkf0syx;Td*A98JIXqLC5;L`Y4>|7)Jo6Gso%CvGXv}6 z6ir-RSSJn1FdZe%yK5MBN259t{k`peU2k}Pnc0VM9WuoqFC+JuDiam#Fc3>#?ft|Z z0+zufbj!4PTCFvx&ftBuKeI8*j)y(0{1L@Nqt(uTbuw6Y)wXfl#C-48i{0Fzq*3P! zHhpZifD3O`tt^Y=dY^5^Rf9Tl%Mm8jQ;G1(uheRb|`_#)BB7QqPAI zM-LU`0h_9F;{}esR*zo$?!)?m5Uue6_itX#7W7hjftJI@j?t<+b90Zu2|TyewJF6H z^u;8Lneqf!LQlctBex3TMpzU=mK&d5jamtX#!_MEy%(bw!7C_LK9`8>va=sjwwxO6 z;S4SPGSBU>;hwd`$@(o1euL>5T*$>m2WG0zN(T|!dMB-3Q9IjS7mw62ZN84$8TM;P zpJ0zpAFSO?rT2dQY>x2M&$nGQPdfPNdcr?>Syu?xyLPNfcSMgj&>{BRPfoyj`Po!D(> zRp78a*ee&6M}vnsT*H@|^loYLy_hG>6W*MiU&N_3IU2XZeTB{@?fWA;m zpzLdN%c?io(QO8fWGYUDS^B-Tmm&$SEo;I$G!};50ee}&Mgs2D zt8u*?J+r9bZaArsPpv97dmbh zGR6>>*KDDd+Y_R;OrKUyExV_QHvBqr)+*CryNHb?IJ%obD+hLJXU692Xrom4r&x&0 z$hX!#BOJ?CAov}@TCYTcOV?q3m1fY_Ak>z#d;Fb7{UQ0jA5kBIokqp`MJ&S*z#nk7 zS_LU0vQUd=F&&;G@wf&L7n;UHWnP?`B=I?1v|7$({BBAhL+lpi7TK*w8a;JaTBl$V zp-Zl6ty3`!Zgs0gg^)u&=6#49b`tgm^E`~CTyoDj*Uv91Q;5vl`M?BSr7~0#C0?&O zg#MjjLCC&TrZfPkwQ-;upf>{GjGsz|o1)KuAG7~YC zqu!H!^S$}`7#`uV({eNe6opJWQ6wHaOU*-W$?m$xko3$U7bP6MvlOudpNHS-yj(@R4&Ju=8PBSip& zm!pRMOJ8Gi*x=H`g>rrg15Vzy39Oab2)zBoX*jhTNZ%~jJg}O=yZLzT8xJ`br-u-LAfb+XLnB`Hz zo)uS0`ca_}>bvMl4c}a$E!PLihnJM>yWJnh^2-LfJ;C^6Pb2=tiK!t5>gc?=dp?Gg z{nM|af}jrcwNO+9sgc9W#WT7H}DlsLbLSy6O1wS1qLy-vjI)6BwJ!gP@ z*HNq?`j_D92S)n=gNC#~R8mTcxa5ik0*$Dh^)oiRkyl)q+%UC@5;AtwF0bjrQx6Uf zlg=rca+%nlW*X2gNlwAQBHIRpP7^%iR?oXpJj_I*-iIZ8)2&k4NeoOsDpB9!JQ*RK z>kC^4n#DT^+%t@gP^*<^rBof*plukn0`^I)f~Ve;c-F$TYV>ceNCgu6GBT^~;akmy z1rzb{@dP;GFK8%|VrUZKAhLP;M1=Tc{O&pZML;;KA*3W;QD4ykKC1v#`kz-Bif_k= zT%!O@>Wl*t%fbjb(YrW`6I;_yAL>z;Zwdk6+Z&0Wh9W(mB~9FligGM3oE7%8iM`VO zUA4ky1Fdn2ba|Iw6yytZ6=s*hQ#ou2_lo@-zFzXl&&?BGg5`j$=(5b-;t(T)G;?!7 z`K%B?(}&3~*x|0~X`HePJyPrR|0}JcXyz{`N?`2NA zfaXpb)$nD?8$HP|Mv<1>pB^`Z@zhF)P{&Dx1{tXM1^E~e3|z*;$;^}ak{B4N0iW}n zwYu&6mu5=Ul}=^`?jR?cHi*H9UopAyc(%}v>j$Hov(3IVmd9&<$wwZYN=4$yu&%C= z;AE0ews}--=QKmZli7+aJ7$dKc;kaI&-=Y^8#lki*7F znlKKaoA3%<00Z_)qkC;fs@IqdSl2I`khC+XSBt*3rizumMZulIg$YvK3{YmhL6QrA zLE5Sr<42fYUs10$`&w&0^&yqbGI34zDHz`dm4rq!M|-8bG;lvpcX26%Nz-mjsI<}i zaIT8tt?bFgn1JoExTtx3Cts-9qz>GS>tL?fda!i6SiR_G1BiLDQeWh5EdXUnWWq~~ zNFB{LCR^x-6ha+=W-fYZ6#;y@f_T0JqI81Pt z4#H7K1Q*r*;qe@ipfrS58tT26O&iS{fYnEWQDh;Ej!`GjXziORvJ5~sI!IP^LK`35 zBUSfJpcB#A9w&rhP~x!&ZP^FT@c{@bE|bp#Zwg^Td3g$w$Mx7sqAL`QbQmG9%yzlS z`Fw<9H95oucm|R4`4%(ZgBu=!rtXIaA@xDDZe$Gb)Jbqim^bvnWg+w$NILQ#0BL*Q zqwDNbReqQ!Xfgu#{aiuS@idpIm;;e4Ag;uP(r?JgD8 z9z+O8a5-9#e15!(RDsG$0MN%g-KO#vc73453+LHE`1v<6aXz1D2<&|%$BG#V4aW4i z_2AKXPJlaHj&-2|#>70mbP@xbDERwRK&dgScB|CPX%l6BdAeDREbeQz;)$y0xc@!N zenWgL1aw3>@W4GcACE;ujY2SU?ALQ-cyyH18(QB7Yd5<<*Y>)|SOFntmU+vsjOiCI z?0bNSfnrcbL*P*%VEZ6RL0u=DzCwguNh0te3K#T=ibiqz$4VOdRrWE(GqNqa=l%7O zB`Z@M(lQN1RRma#>$3x)ceu9}MMyM3!q2FR*?UX!UBNFjeR$(Ez{TfU&iXfbBur z3dDF~jrSD6(E`tE*o-=KoEaKiY5boTVPI=(%{)$%F5poNYh`MsxlBmh$+cFgvp8&Z z0&;GafV9_!(VGusJxqvSwT59|t|ZU6Cp;EER&UZ#q-sTJq;lZyNSgw3OeH542SYt1 z{&#uht|h2sxUGaQShT6mB%$yJGu3WG`&A^Ujv&ri=!IDA<{QrUp2$)i{y5V1lq_bM z2o6I#Ws6%4dB$PkLwFOF6CbK22vQMkAh2kZnHIhVA>c^uO%{yEWdD#ea~dXz!Q~Ml z&mGJVPS&5u&c^NG-H6nI2hWYjD(tN5c*?e3tn2j&4rxxX^SZQ5tlr$iwv8?vHl|&D%aWc_zA(%tjar@>mdS(0!cl>^Y7(E3?#&V27_d+=Z=aWt6ues`1 zP(HTUDLf-0?q4@OD#`{@w&Bs?^$hE$rKjje5?8D-kkX2T2sdvD9Lu>733nxb`XW{S0Ro2dotr1gV4y)Q2#9=lY{m<22HR}|^BWHk&k5o*(egySE z<$Sj+x^#8WN`hJjTI=%@;lcwWytV!L&|13CFoP>6Ow#%0J*SVVmZH|N`69QZNbun} z;VcdX8NZ8)4jGmRD^rr4_C*!cz=>A5vC4#Tgc&PIf}R)R47PQ?XrF8P{$(o%&pgkCPh>L{zshLMDK^R0A*=Fw^V!(EZV&kFjjj zh@oj2N$GQbO{xan>M&ULoJz?1N}y;Ur|F=!FDc~hvne(RdiMp|Ex67lvoOt&eIj~J zd=z04{u&`~4c)x6ylY3Fm%^zDH!I#&M@*sPV6f=?pt%;K*`KoU_Di;%PDASyb}Rd> zqo|Z3a35;c*aB~{0QV6|3|(rx1Z;3`5Pq2|8^PWkp!A25LzPlMZ>)1*ke5YaIl|X? zEqRj_&&+O_;U6*F5DVnSX>6X>VU%p1M=3=cB7kFOc4twKSSpeP@zF11k{s0}DnTit zgEQFiPf+YSnEN`;yGVI|tl}<@@0K};0>tm0C5#8AJrI`PmN*f)Rl~rlbeX~*_~#fR zSX~z9a2%XX|95-p)xbnYl1)aA-S+8i+&^|7R7en&WSAeLLdd@^scsSoDMf=b%^Bvu zRdy-}W?$df_&2xc&Y*v+Q@~I$dM+p(t!l(9$*AfH1@%8Wxlu|fGy!`HF+}l~f5v|u zRZ@t^k0NLeXT?{&4t#Rp27@FD-PWi#0++%pMHg3A>Axl}MJV(bOqBq7mD1#syL?zp z`fEUYW)m7FVgX=Ts4KrvFA?LbQKCRPDYXS~i*!H{kov9xumNH_1QFMOgtX3TezF@D z&ggg4|860l779Jt;|(8LB%tbG+ZNj-wvjJ?4E1g?pQ6C{6#of>m`wD|k81nP4>eZD znzlcUAw1Dy%;qZfSpY#9BfC^Kjh%vp#NG>#xhcicPcH+%o~-i8f{Ik}+Br&b1fb~I89w-8LK(U2DxSbm6vRb&vX>b}S@?=%yBzsYBdGbxiGW|^o09#dE zgUx^ZWp7DPGhliW z24+mr=&+4`t?ok(^sI|lIIQLWH^Asyh+zt3i(|=18)j|XvM-t}rlWM8s5h<65kL>< zpLG{JBt@MB0<3Em?LQ_!4KYDUDUBzSTHSxY$1M&V;(h`DefrPB`qh2`BBu6!#H{TP zsd}}*I7I=6oSq@a*Z;kQITkoMwfR-rg!jLpwnqRQ+Ixh}?o$0HE+%P!fSlat$a_-! z_YfDvKvVJ}U`3Oa$<#|m$7tqzGj4B;+WFZcz7(DTNq3zHkBmuRa(F|!FKlf8Q>LyzYgbXWbK3! zyTys9?#{OnwhsOiRo(m$15%1=rfq6f2CYS3vTNSb>Nfe4#$PCn~! zydCBx2#LGDIv4`7(<`Qz67KXX_^WIBy7JtDM6DMREXWN&cvRc2^6TS=X?fpm`zu+M zY5X9eE;s&X;{evyUbOzxX{C=nRVo93uhqb_h@1C6tA`Dhj7G46j6t6_;r*YDDnkq; z`@&Yaw-Nv3C}37Vvd=hC6wm!fV(7+vP4@c-(;feAimCu$pU&MeIFtRm!DWbJ43uIF z;mLuqVjw^*07|8nFHtFe9Yyex#BPl5ru(2JHr~zdw;xH&XAr9B1t63oMC-W5rbcAVA!BJna6wRybmYk{7lG|>m|9GZRs`;9;&0Hf;QY;0_70j^5; z&pIugnUJHKkAT0UduYDKG+J^DaQ+ze#}Mme68@Q}9$KhHpSsH6a*KP-Tj?)0wrx)? zjsYK~NS7*s4oqx3&E=9)s2~8Wf+W_D$Ld$T@lnEFsV>ty>-lPOohCjtziB4zGx zPW}`mphnEossH@^gZFY=M6ub$TD?+Fh$tiDwMNCesuU(t$fouK)OKUrac!2}==Uq_ z1X_qvZQf7$n)Nn*7fr4w3?F&V0)cGUhk6abAeeI}@joex146<2_>}~><2#~I6=+gHKSvleyn7aoC@xc9h{Q1yUe;mNx4G-WyNBI7t21rpPcGR*|ynpDlX}>sRzEAL;=+ ziBT7j7Mz$l9Bo={ObPto7&!bB|JA^z7i0?udIrdExswG$40|KKuKe_XJ$J)jYV&Dp zdA>iWwq9hvaFM_bzVqK;XPozvK*dV}vdY}PQ^}uw z&kJP`m48|Ym*cA^lg_DN@vGE)h2^M-!)A%9#&j$ZkjNzg-=7hXp(w)f*=ek&$6NHV zsTIjGslzVhGI`DWM*uGg(Ng+5w>5CbV<0CDMrX!^y_I!Zf2_rRsi#4Zp@8Yt1HvUyXFH z_F+i(ro2BX0^hHQ{iXrd;Kt{EkCIxWwkV!XeUfaZLRUA_>nh ztbbxE^=(2W$e^X_}0N5gS{d)#H zgo@h&_aUQ!*q&q$q6@$a%{-4vKoS>h@c@*(;Ox!5Pe3!nuY1*fH^UzWwhVQa*qi;f zv*mJ9S}|7?u2|=1Q@uN%%AaZqJVd+qW68{hYbC~6^N{(P_PdL$=Vf>ch2+lR6hUcC zS%UIJQh-mEY2J#y>YTR1yed*Klh+;HOe8tT&=@dUd}!Xi7Q1^D8G@n8pn(3_XTZKf zviVFe)XO}fR)b&!BMXS#>1%Wdjhuk5mzhHr07CHCbX2b%bDUahlk?MNM%D84V!{oS zb$ypKa`|MpTfy&d(qiN7Rs(lvA@(r*l1Zrnz8r%_`XM=uh77C?MF!}Hx2~#cR~d+P z%%i07d_M&m>F<9}OV~6dJD1vtd{BbKP33m}E}JOL(AaGz-q3Mz%?Sj$AmI`7A}m`A z_Zp0zWIYd%9Fu4(S|(i|IY)AtJDh%F*9Ll)>Zx=Dn)!Ux^?CY13}JSDOV6OwG8Y5x z9Ri3<$ejL*7Xj9dgtrldd>Z3XryeM?b=D|K$UDTNeoJma^X|Whm(#xW{V5)ze3E-J zC8~m&eq7Mv>gk5|65D0geNk`WOz3aDj*``r2ioZfl_!T~*0co7=PGmD^-dGRw0{Dz zQz$#V2KZ2a>J173HWth2E7xV`BzJ_KvvGLa0hx~c7hYu|KF)ECA5HWC=mf){AiK5l z;y4}YtR0Bo>?8CT*1|XAV4}^nukyd({)#-&D}>V_jxZALT)hoVgubq^p;W9$ zu7Cd?YRH0SvDVyBrp(NdXuqyZVthw}*x|+N8TL}! z0g6R0N_zz&a#PFGLQsYLw>wwz zs;8KpMG&U=y=Ip^wl!=`I1_$GB-3W3W6E2j3XIWu=M63CjKr37*<}qCAnzL>fa_=g zfB>iQuzCmra1 z{X=r-QY$RGcKsJY2U0L<&c(gf7+e{SFtpGxT@T6P_smb@jzFp=`ivH;9vhon5oq4i za+h;um-ZE1DJe4#B>Dx+ThgZQSYm9-;m>0P95B3&6ZyAcv6whCP@koviu=lGoK?|4 zVPNkaZj1hg4rHPL3>KDQ1*Cf{sHM7DWpjD_Kkr}=4WfoNVwvV4`W%)2gGI7IP(p%i z)Iz=!Mq)$-XnIE&e*;24A2dB`2Ab^w%2nKzQDQTl5zKGJp;Dt3ls zd{}a78`f75!x$>rJF2VhFVeY(3!W$;9~%qN28L~rCg9V`YQ4Y;Z81wT1qpGi=bO_j zefZX3S%Jnb@&|M1O43(Qa3lOBw`mk}X}vku3TC z4GXlyhzKD77*nGMZ{Vy(OGm$2s{Vd&wXIEkCzGn%Ti9tGfOj-iO#Dz^FuwJb zV;+nkU{1ajBf>&!XW-Fm2Q!2auF*FJeCy|cm^1{Wx@~~&z4wE%&h&TyUX+0MgT6yu z051!VOegpr1-vNnu2eVY95g41SPE#-smW?Ub#Zn5bn}O$fWifp^C={RO52k zq{IC(VM+Hv&D8G-9sr8y2>uCBMt2WDMnix&ZAa?669ATw%)DIfe4wJg=lKxx4N(XV zpdT@BylW!yIoQR7XV7S(;{vW|l?e-J2-aU;ddT%!b()f80et*ZI8WdHfPs8a_tqhy z3@2xeurSe^0ct=9Ps$YwPer-XvG2h;Uk`bgO3}X=d6wb20>|2DGLq_M+vA4_yrQH9 zS~G;m@jmOpL8{^dknC9!jaEZtg(Qafv>wD+uP3B>-G=H);d~kW(67RveVi={wXCoP z#GJm963@GHh`qLpQ66ae7#@=9X4&OGl(9WraQJKdTOJpQu}r=K0GBEPHR8lA&T}|2 zi9=n$FMDe=L(^iqNWXeM5h&&rMTOK5XQ;QY^{Wob2Q$!(9{_eO#CWf@oX_JLN`?aU zO|1*+8-WyF_i9W4z^sJ}r^q`CQu)ucIqgkmKWY5@>^#nEa&DIa*d|Avs+5Zrg)a?F zx}Xp0SJnRT_DK#1W^u(=X_{OrJ_hh3CD(I=2K)$dj6*C`Kijbn-~)gJ0MCV9-M6<1 zsC9%#{eF&$nOt!$4y>0pKkknBPu7o)sY276ALFH!EK>cH=@N(;92qVNfD#ty{QT?y2)ekt-S{>Q9r+j0DVSdOmuUChUC_dTkk$z_ zpCF6@R4;)D5zTj<%zOWTjD2@FmH!_%$HB38A>o)I*^=zNNs>`AGAc7 z$rjlmTavw3gsfy$&-+&2@9+1!oviBIV4H;DjS z;41kLdn+{HGIHPbnCj-Wf>A-NKZftpa}F(+2NK40DQaJPk+K|HO9kyoV#fJXQzR8% zpd=HWcnbN>n?3+~#z~zfYkh4dd(NzNDdOv#^jkPtdir#u^;dVR5NVb&@q89hQJ5iF zP%jK$3Ue`}nX^;*^-JU__|qIz6T{BbIFroT6kY(K%E685Ol&B8 zNK1sgZgcsE4mtgUw4w6v$OaqghqjE*Q~Eua!>*=_nQ96u*HuPVo`CI8977^e9={xp z_Y`!15b6`*+H9=<t`Rc#E&*wxdbfbL%wd6VUMiwOaEXc zw74wjguGq<9QC7KcGRq#*QoU3Z?Dzitp@z3A?>neal9v_)&3V{p#={Jyp!wilXevU z*~aS$1Fol!E80_84x%3(?rmw7-5i*)E*asMZ&Qh+r&4=Lo>&3Sk6hRePyY|75bH;& zW~i+J&y|*(jO?ya@T0r0nWVixoen+#XCFbaO;3hHAZi(P8CUJ^<_DKZ%>%>1r*4t% zYw5O2v^0014x26_0V2KLm45#6tLnA4^&8*;oP$Py@UQLAJnTP)Ss?Y9=IW!MNxuVa zc;09wRR1hzN7x+eTPiifcoZ$LeP;uHj1?8l@h>$56*MBAfnoGjKK;BMm%5EHEAi?dnut=T!{Gf#^> zzL^#BjmrOhg<)_L#u!L_Qncuo7n|Hg6J zft!d&F+b6G6b}m>z1`4lCJkYm&QtEopW>25Y}>*An+J; zgB!hB0f<&v;*)|_ERfY2U_P^+Yl{>1-nJVCs6bj9X-NNk<#|kyEkziU`E+A&6hW{9 z$L+oO#~n~d1pqJbshL55Ovq+r* zCr0P<`?2`X=~K40-D$?VtZP4~Z0-IFu~Rya;;~r^yJKGZ`#;|TfEjoc95)6({{vpa zWQYM&C=e(2!~gT2U6__Qk@qbHgymu=@n%H>3Wf83>Z$M_ROp4ax`vd*Hr&V3XiSb5 zv^heunq+V3zQm&kN}>W&MA{C(N^%yBhCa1i4pF$=GS<0I`FQfBhZkQfJE$L(gVGQ= z!1WXI(!Rd7hU>wWLX-%BnT` z5dh^+JPD0n{eE=WOz7-bvv`Yk@{^yB@;Ht)Y1N`~aK zZ$43Ch@GCRK_Q=8dYYLCi11UD{t*>P)hQ6HJOYk@fp%wgl)L#E+h@8>z;p>wo(hb} zl(lsrn*954mT?JO#(ES%zkmRZ$0|N(JKkrgSzX2K+^6HI0ID zP(hxikUcE=^y;eVLT9oShFXBO4Fnu~?q5HXeX_!PkfJr~?Na_v7QmnB$e$!2DJ`(( z?%r+KnNIKQSiLH4TcSk55`maKPHhK0dU$vO=@IE00@r8sq;D9uMDCi;&vC(Urk-^om+-i_2GS!KMat1S z4Re9lh)2$gGB~16@=`Pg$UWa%-P#DRcG&N7x(A^U`Sf)@ezQq2HC{<+UqU#wCcM8J zLBWT00ftM9l-zg2mO2d=jx8E7=~rPbe}G%MwaKre@bJTFLYs}OJ2pGGi~B@7u6MOP z@vO@gL6)kOTF{exES!hXBAk2KdqT>^yV;@-03#T}h5AK>MC84lv&xn|O?4{5ak#Y9 ziZbhnYPIanth)qm&lugppFFLV+S%zf6UH5>f+tHI#M5aQIG-Ib=WUtTEjD7b?x}x-913FU@)ox4rvxHM2BnWn7a$eFYb?6Jf#qG={Jc0p<`FDX2@Gn*PYJOk% z>axOCbaQ~$s#ZQC&Zq%|(x_x(1#1D>h1sfFs5UziM`^(6mAa$Rnz@=ToD@h@lw za53V?9yDt0o#lZS^VuQH@gP#@2*f8@;j!s(m&>zCd|`X;r{nlr{LQd???3K~)1o`Z zOf7Jg5(l`O@sxZaqCmW(xr_LYSyt>HUYHUU&}KHRVBmbFjPTzQhSQA-9z0|8O_jV8spp3F(~xZ7h}7E5%M+(o>N zkSwE_0Gl9D46#D27F+OWTU$9(9@-)D>axt3SHAFHyoes1WAc#N-hONj41#R824B%l ztc4nm)%yDELFz|P2o7#fEHvws`L>^%;`T%4j-M0Q6@<`)(+{FYQY(gF8*7JXm@d5g zQWy%SN*XRL==fpOrZ9_mQZThYL*^d20wTRIhAnuA$!Le)y1yuLtK~!|U{7I}68+J{ zzf17q7S4`Vx>z|G23mD$NW6?iOSIg<`Hue}yU+uF@xj-~MhalEn!ID+S4vW=* z`YOypy!9;V6VqA^I=vTtw0+z?0_VDDYz@^gX!di~K;l10lhcdkdsV3*bGWWpqRV`C z9eQXh(-y^nv^)t&w)6n=YJAHhP`jIh#gQn_Nj~)l^6F9+#FA4kWCO=dz(*~RZudUc zNlgV_5I@ilHaB9%6QUwXK0v{9AdJtVeEdr3jX>KOLcBL#OHUr>DTPr3C+|-4UE-71 zhGZ7u(ei?pXI)Th|3?6GEEnc_`3LE{*Buwe@_wQNbVfY|K3QT)uAR8Kj$ACnpDmg;3;$mt%R<3bwRx|Gf)5|2FGIS*f~g7O0`y_D)H6p zGJUAedeMV6fD-cw=(t@Ygw2aw>ireHJH9dc0B1e*1!zI)mkyvCi*w+vPQW@FsY3AZ zdLD}E&3CI;4GB%(CaI~G8)}+ux4-nM%+9EOO1@!xvd>{OF3q;%&j^PrfV!Zo4|_IU zuf4gq{QbZYrtg4>J?SD;9fkpp@kDjH$}ob58JXYnSOk)+P2yzE=URAd@Gp|$>8CoG>6Gw+?{b)Q>G z9f8kBKYwi@zlUoupXAru3zUE#rqHCUU5i3xlrn5RwdDgHDvi31&!!}s%z`WCV87la z(anZbUTw^B%ejWLhx$bOkW}5)m^-u?WTCJ50(XkQOf-2+JS#9be%JW(8mUQs$XIX9 zeVFwKSKnIjx-_^(gB559x^%YhIlSM8FdU_Noek}7Z-=XtGdM1~Lq2Xnjw{4OFCM6%C9aV`!3yp$Zy zfAjA@kwzO?%ByRP9GI1=hWi`S_LAXQFc}5)zRODKvb}Wq7zxKj^q)`uCc6IIKwjb1 zYC{52ddm7FI$q=N-$5|1Ra9(!)U|}d{i8T)?1zOJfHNQSoQ(>Iqpo=kIwqUAM$pEm z3|zbBIUOul`?tYGVA3weH!de4nh%^oP_QM}`%XNmz{3aBEz|`eiK%x zWb<2S$%BPdCnT#&AGm1-NwhHbGsRNVMkZ9 z83%R4GMzT(1@$93cX7=i_9WlXwUKHMCnUlJHarn?M&d`URZ3nz!M$faR_SsZve#0* zF%Ghj6Im!tdyNOrE5en0mgT%q)pFvxg0HR1D3?ChQ8O1Q0$h@IP~onF*LfitNu z5T`GuFCP(`A$S?X`8$Q%-zKkxniT$-p-!_qcdNI<4}z$5K7!%JQ-a31%OTz(^Gjo1 zNPEQPFwo`*`QwOqg)Ur$eMSV4UokYoKU|}yPbZf@f`X=yAFtT=;0|DDk=v`ImupB& zE*0oCBsq{XNtk>826>AbtXSy9Mm?{Fkmu*Z<=oixU`av{#_OPzt1}J>`cEc2%5L)~`rJjAyupS=J8NKUC^R64Z^1 zyu8N(3a!b0ROTbn-BbV82@tYy*y$fCsfV-hLeI;iMtvQ8eO%_x-=9Je0VWtvNuzxM zt&fjeu_|_n@sr9?Ee#b$cP}9`x5j_Z+|NQ0n;Mn9g9b2a>m#>bS5dehjkp1BG4&8Z zL_>kc$+I!l3+&)`%1YQ|wd%FLDLi;Ki1!b`7l4y3YgF)&PeZ>Z^vfG$KBpW%4=Cod zp&aoiN8f%#(Vz7>=pZM4hckJ5#io61x7_m?7e{`7xjI|4&07Lq~a_`XMMVOuD3d>9y65)mv0-AQ29Gd&IIkngP z_Bb;}ZU8RSXnLy>zk<5|H|u!soLeZ4P$4t;yOGBUNq!Qx9}>JqYZS28r^+%gVC&o0 zrv!HyD9z)w^x1Il%LO1QBmn1hfb)tAtzYsH0JM^iV=x7r0nac^bXa60$d&ri`av6N z{MPN6^m~tpn`!RctXh~04~cX_pRU6!j9Tn{3=bH6mu8V90M#RT!qj@K}BP=+ydVHR@P zl*83tU8&OAYFOUcku|DPJD{{LOkqyNK-S46Bj(Bd?CSuPW2Dr)i-s<}2@8tWII1%D zK*A8O;0jprBLKlPA+`!g0QTQItZmHw!Vvbx1H@3#FBeGdC_ z^$uss*mpEbyb$;R?k8#1*z56)Cs{GE#7e#842AVboZe>mV#sP<~#Fx)p zVX>EftIdLuEB>)EY=sf5BP+dcHw&JlG#Q-U3rEs~srz#A>KXv2N8+*kI-YpST!-h< z^8{Vj?1vDH$`(SwA|5P=D7BA?d})?? z>s#IDEqH)KrfGQ{nAetJ2>B~iNH3^|A?(i7%yVaP}cvZ)eg@*rM{u4+z+#%g8z5l|1V9C+9T_Y zTvD3v|E}c8q?rB>HFjTSCrGS=1mvX z?dZ#_f%h+)d2xQ=(@^b=JoZO>G)$!i>AL9amZ9KHcwZ=a-f^sw!#yGOCfKC^y!u&i zOAJG4Wlf%MH7-VM%zPLiFqI4ojVu~9hh#weHy#wi%6t1JadXCyoMBBXqSHd4t2_?W z2L*k5LgSVUwO4B=c>Cf2Dzro$LeuFw_UIpCgt88VIcnfP!Sh02EP2txf30>bZ4%y) z=5Cim$yQ$q|dpgn1u{WW;m1QAV8w3boFWuXKlzGXG+{!jZXdybW(a{B>Z-Zx8S`xLo7Bgq@ArlO zj2TMda>a28Ww!>~!DbKzl^sS%dZ5fmPf8k8_Pv7!*&;+BLedwV={ZC6&@4}l3j6U5 z-Ncj;SDLvmj{5$C-wvB9JrFCWmayGi*-V!vQn-$xvOjL;spf%bXk zbPrM4TFLN20`-TAkyv0#G?3=SC?g21H&G#&m}q&^9BBkgkUfNDgA6l=8q1`_-ZnW6 zauyjTfp0LI)73;1WvDfq91>8XSS(eD#Z~eXVK}#qz)@n_gax7Q#K(=g-#>c}#T}$O z2^6dv_4g+xc}Jw%(0Q^SYxKSki~lUo?j{+asC)aza}!{W;Yj7042R zNh)ah06D~7bYyd7-i}Rx=;=w(c|okPMP@d2E zwwgy^l+eemvNX0S75_;hj!pa8cI!JN*i7H3$e?@g-v1 z<;ISA`8nXf(Cq&sUkjG=%%@zo*JY;IgZY8M0iVJt8kyd(?R+-WGG1E?VoP=g>l;&1 z>oEI?&NW?3H-I(4?kut<6tDlB;*XQ0=A)3=%|e1ja2J)B(f?|b^!B^B^@+q=)OrR% zXmcD_OXeZBu6Xmr&-!bX&e;f&&v@3+o~dIaOfq%yc}2S3cWc;aCL&pXxD;&FIKcdh zEZkswGgc=)+0a0j`49vFrg}uV`>O*l9`8-bAsj$SJC_Na&Bl~&V|(ft`kg-51*|9* zr4IFr8f0PjoUpWYkF+5Sk@InF6%BSGlHu#rnZZt#e-C*fHALT({&X)~P7sY)x~)=b zzP_rSp=;0zBT8@+O@zuP7X5OAIQ_kR!M>n~%jza7pfW}=-Q!r-tqVu{ej{6KgNu2T zl{Z%NV}63*fCq5uE!z({H51WYg1H2n!k+6>XfKZSmQZm{9!A>9@Zaj!#i=jGZ@5~p zxaz}%s+be1uUNEq-(0hE@4yv0;Bxo%tRb=Nd9e11O;JEk$%2t9Hy1o#U^SO5{Rw&HnE zP;)Unt5*+TgRa(Ume({EowaHcE%iBFf*~?pIu4}V;i=5>G z-Wh)}68+#j&lB@WOSM|(yMgEx!gp!9bOHU59kpv;mEO?LP9SN6tY>wYdc2hpJ2TpD z26b$-TG6xC2_3}G`~ov2(XINIJz&M679;aGR>Jd7p_WLHjmS6Zis~O9z;z7A!AeG3 z%7Fe+89!>dS(qRdP`74p^nqUVJ*7FL6ko?o>iZSpznd95>dqyPD{?g??|9YKW9l#` zT~p+60vlJvkI`RWAnhMY=FIP_>Te#*O%J6;SK1hSWJc}y9aHZyn()VI9;10@z!BbX6ALPt7$*DaX4IL3BE4MB#K6NGCZ> zOHTJwEP*m9X@ib+pYIpmX)7~WCyQ1~Zw|D_rh$?owfMt$UD3&2)D7loK%7Z1x}Pvrr_j(FYsLwsV64@%9&JD`)$(m#2F`O2!fq`W_$ zD(5QJ{5!XiS9g-fvC~(~X&DDzzdSQIP}!YySF3KdtH+iS5(N-hahSnjpzB3ofEVTjkfuEF% zM3x(u*5UFWSt+)_gT@V#T``@|gjUWr_2+N5DrKow^bsF35cY$Puv{HRgJmkPX&_ z8T!hd(n=ZOTk%8W$54jH=`)}{k>&1R@HNQH<${bm z9z>0<_NxbTF6`Xxn{cIV9VZYY$n)FW1vy7%5-{XqE2p8l-+Dn|Z;W3G3N#`VSt8Fx z6*HgJGP!dj8((#O43;wQS~4>mK2$K?Kkj(gu&)!V%qF&_(k0v&EBfe*O8qah@myB^ z-^zPkKdSG(zdd}|YE$*5JF3|G`^~L`=@eE8?EIO!!`q4}+*)boZMW*U_mj81wiZ9E zU9HwmxQ;nGkpS`;#kq##1R_P<J~ss|$ASFd_kH;X z_ev`h#VDyxCik{|=L7sZ#B#Q`DeS)RTq^i|=;aiu2uU0t&{{vt|t3 z+$Xy_;G=emTJIpHF!ipluOIJpJLQDtuCn_+agF-9K1;D_K1ewKB`#Noc0+_pg-Kf$p^M&>OKQN0 ztQaKw%VDV4IzmosC6c*~z=Zm&x=T;^^lFy_qh)5uJ~N#1&fYVYiyt?; z6IEUqL9!X5;UM)azK269>IU$#h`V#wZL4)N*I0JZJ9b?6R|$DP!K_Zkiu2~Ox({aP zU^qErgWo##O!NsApOCyF>4tYbeqMsKj%qTHL84IryR(9xzMO@HxqG+OVroyEu`k3 z{6=JF1kwT9yVurzg5QFmLPa)xF%2XznZ1^(bGlY zhtl162;o4XXs7R;K~*qXp)<*Bc7jp}uE2;^5_$<>VYKZhP&}cT4!&FmQWO<&5PFajMKjcFtqgfvdA=;Jv#x+aLHK5AKzG-?~ji@44}434}`Zg`XhW z3D8E1ni;6A=MJw)JcTtcz_l?-RGgD@m$O8e4~;_^OO7e zqtuNq6D(pGJ>VP)mD%R}9>t+?m>Q@+0muhBuccr}Qzj(>LiHu+Fi zwC?f{h|FA;+3HQW-JNQLz>>FGZjZ2dtitHPJqndO<%t?RXwSXk$*A!kwXr|H>L$oX zGoR;mJ-I3%^W1Q~NvoLay#*+zu{gt{j zgr{tyx>IQHDySFzlH&?ghh`?(D*f)f(K&711I$!USu?in(d$Bv;o?jeUfqLtpP7$< zG3PrN4pyFM-&RN*s?C%=bIr!)llLthL+$X2%>;>G{l;IyL)Y`nVew~E9 zLM>i}?c6?1VP*>RC}t{YAC!Fzt*&+RSyn#Vl9ES5c{i*7rJ%>!pb(d@Nvz)-lmAd5o`n}VQu6;hUKg(Urfi}MWQ2F}t3vzMF z)^xX&O`qe_5?A^MTH;6eD`(T;Q#~)gH2s?jE&t{e{#=u#{K)dtGP>(jl-X*=mey39 z#Pk?+(BU_aMkzsdD3AM>(?R z^r^}PCw!U2oBucYK@TlOsfT@!M;rBDQu;6KSqd84-vVwQk&%D2I?R}Y*cse#m4DL@ zz)endN*^0+ov_0EwT$j??ol{Y zyu@9bo}5pwVR@sf4l~^Ct2TtlX*m-TlTFn^=Syd739_f|Qk}2Xfn#D;?ln4ATsxOx z_3e(-nF$CZz&*C!-z2_!M{~U%pL_kqwV&;IPN1DU|F(BpZMR*Q6U2qWru(YJxlVrV z0}$+Rv|ohF6=Gvm)hv1*fE-q^DE(!s#hp-+iT(fwCxH1~5DsCgsm1#n8RwVEj?>Qt zM@QIMwKJrKSFVTTmcm2C$Q=mYXd+Xx>TVN(ZVMVh&M#mhql#UBMxzxx&sVtuF`gmg zQD>6~rT-0rn4t=g>X%+wZ|Qb2Q<54SF9o=;0spYbq6vi}9vnBV&;=hdGuVj{P45(6 z>qo`tYMY&97JyH)u=OGv9nrVEnKq;D)KnEaNC!Q>o<=p}>j@m6xX)CjRVz6naF_bx zdAYO}*ZIm2MD|LJq=C11XuYAV?&qpgfN;U%aanBL{uD*VhE_zseEDX&v`_iQv4hdc zU!Ps}ckTsjVwBpCTfZ`T!$xt<%=%(a9J{KPw1gS@F_5eb@^Rx%{1>rKg--53)9oq;xdejdFnt#a?r+%GUY=NThaFd? zs5rxnKgRQV21LwBi?ss0pS(o9%nVTyr4FN?CBEjqOHNK!!C8O)8cAdF*#uW`p6g;a z!HH583@*U_aYQs+^xvA-+S%qw%*vf6GeQJj7pr&pS}+pTXxRM?tNPA2dau$w7 zfE)NT5karI;cGK~C&>vXXa-J9lHK5f0Qlc=3}qzW+g0)4AK`s~ksNCb7k>Vi*rloQ z=5rejN@)XTL$~O|&KMQdXQV63-G{6$ zY+84es_x>7plLBZaTs?728M;Sdv+Cew;+lFMbKo|*mmDv#dLN13hP4xD8@$*dH}tA z{YABa3UHU8NwtJT=f@(FPzWo1X8L|~Je5rIO%^m2IvS+Oo^({g4|k$!&I8Q0BI&tdiwNf2P`~M(kiSU ziHbHcGi?d5lW2EV{an1vvN0!r-{M0#o`ZhTgHTcBhR4^2r@9lmf#r7^YKVToQ)X^| z`t?qmv;xT|B%zDD6aYgX^_YLlg%)<|#zV_<&ASQFX}K&y-nL5Jyotc8C*NQTBCb{{ z2avSo3_91)5ND&QKH*uYTIlVfi(VizjqD<9#33kc&b&q6`o%l5PR5w%37tJ;u z;Z_)FnVD=}d)WTUxFla_=Dl;`!Tpw-5UNN^7f(5X7#xenATy(Z^*X`3f3L6-Q2@tN z*RC}PJ_65DY42&o;i^*b49tFVYT3Q;!z7be0z%2vX(uz(CU#|h$U{%&qL5j+khts! z`ADE4_T0H)l~i^VIYBLko`;90D&JdhO_{Rs48i6LidCY!@Ist}ZX}IN4#cneX%`Mj z-VXwsce7M(owoD%p5mjZX}*yJXGYo%LeUKRE1ll;%qEYB+W?sj46#55kilAjora#yWS&*PjkrXBxA zUd_=UE}cI0tjtZmf1kA=Md-0X)lWuP|NXi`&|*1-)^f`g z{`sG35@?N@Y5T_U3l4f$u=On=$O%<0C#b?*cBYV{*4&mnPsMH{5+V*JlnYN@kr%^> z#y8n1@obbm7}l(9sLH^HJEk;n1+Mg2rC;Olw6 zp(G~kXFTa!IZ+97hs8b2=R7!$mCK6D1WY8X>GzIG`vc;EX%kb;PSn3HaMC+ zvVyRb7ax?s5R(9g(srN%u7eN3%MssnIaj$MnK>aP8zv@aVc}Re2G?UOEkk)o-I}Lcz#3jYWS~b5ef<+rQqolBqX2C=F>-DK5nr>>J z(>lzh_D8>vB~?JdE&bD{hLSt~7W?w2twd&mSApmJ2$r3$Q=Ieqc0eyT59KESqOYQix5A6tZ6e@^YNhGN7bvVs%>0M zm`nb}<7iWQ_s`p60+RajrdErfupsslKy)sip=dfLkaiFSX$={E`!^8I|HycnR5UoQ zn(vHgG>yw{KAQR|!Q?PeGi)Cd+iq9Q7Iw>B{y!|fJ5|Bq?VG%89^Fs{237n zN)5ha15e#7553ou0SV=-Q&i3*oZ_8vEIYhAMhWgWjsKK$Jd_Z7UeRsBRb}9IBl$nP zb^p3K6|#zHL?^_@TN>_W1q47U#EIS{L=^_gXKtwQ4`HrPl@iZ9pZ>vfho!L-@-W!# z3{DSA?OcfomvdpQZ)Xmodd*VK+wA)H-pIpJiiq!_rU*3|ePEtH$ri zqntovH4Mioblb@qeVA3IA7bleH9#D=m*c^?PjcRsi<`RxWSnVKUx*M)fGGFbG~=Ak z;})EqsM18Lg%b&9T_I&iwrIomk zCAPY-epFeU_Y|q%uoW1wUvvVhvl!~))mKcqXD@ppb`J%1%I{0ecanU;Ju(O3IB{_7 zPPe`F?}%%MIlW{ND!40S2o$gcVenFi>rKU7!&q8xBw5KXn79K{OW$=ySH~sd>B6Jm z_9(6IydxTnvPpb0A0MiX&bm7_a8chLoF+dg%M=G>ST;V#inj}};3w*{EjAw4gQ}Qp z1J9{88gsick&55=*euZ*$+Pf?;ixEtGXxae)TbAd0a~f0q8oP4lj{mvAv6xluyJT1 z2WL`;CmfedgN;KI#-d2oMNmo@n}NGWtwc2;dJ|DkTri<-pvheak-f>8+Fi?sPSAgC z4(?sSr#(LGGg@$gU7n^|&6s``c3((}9Z<7KNCz^$@bC>h0=(l6YtCDA9 zg5%zBjxct91y`^33HubtjU*^N0qsC^iI9wuBk}Ub2AYYiY>?U$OX#hEclVoTdzbJ= z!*5BqFRZ(vZ?@qfZ-WR6Ctcssg;qRquuR-q*0!P50IOUV;}t%Zq?a0r(g zn%?7JBSE_wcy_>n~&Y_*Eot{scRBs*5l3obv%cETMb;@lnHar5P z>b>MypQj|0mWsmT9sQb&I9=%E9w;RvUF)mA)tY{BUi$I{rw=pr%oALvo1i1rfbm(I zkeQdlBp5>S=(&SfrNCU+)C93uU8QY3_kOwdF9|^CHkVeCxhPNeE~ZvfLVWC8QMV9XHaVkzmBC!EuU&mA7Lz z(@c9ymd^d!ZIw-gvPd+7&CjZ58f9sF?LdEXe?v~@^$w*I&)B>7zc2w-;H*Ua)yC!a z$x`1xU9=F>E&nOe-27E6g}25~#67qdwO95*=4?Zc|NJ=<)qM9uT28~T#=rMR{L%dZ zdlXqg75_S<1w8}}ebPmh5l_yH^B%7RpNHI88M25zJOR{=i+J0%hK)^r7{z14Yz|IN zPCbE(-1Jv+!m=F&h%e`#r`QpL(ex4A^H)K3_^O^$!0g_3E(=5UG{oB@$(15euHYRY z&R|)pRE=V^E+sQ-Y+dL|orhpLVHEKr*3KcG`*Kfg@j$vIqCgfn1Xgp~l?(Qab>+dc z4KJk2wW7yN&%d9IuCUlut;|aA1+v*b|B0}$aHm)0y>)FrzgRIT&Xqx~SMm)#ays_g zzcQVJXwh_5_h%#*?2LMg=MHmPvp*LirA*F^GW0pu6Tk@(>pVNt5S_G}e&j1i6VzeP zn%bZzBWmuub2H7yeF7tvy;*r)CkPLXD=NxwQktcvi+tIB#3C$8wlFy&jQ>k|ko-Q`zB)Ud&&q|_+z3@SfHA2j$ta{Cp_ND@m_ae z=JAEuKdk@^M5ymAG(B#}A_2*b=)qI-wwq#jeHWn(|j3pNtWx9Moz8sGUs#f-X2VZvHuEkIMMIuwVveb?__fCsz` z|K(?h2fDAZA#1IErd(X=tRcJg#e*`QPp(#5Dzi!R^evL@)SO4{fi{2@9iJ90k@`+l zFH`m5mwLhc!lSM3&7q+Ff@HshodjF9+LmCuEk^{F$3hfCAEmIaC;{tSnyN{@I@7dl zDT`a_3e|n-aL!2UVOum=44v7E*pIkF^ZO3kl|1wwwNpixN7?4Fm4#ETL1#pnF%Zdr z_5$JHVGy5($!ozz1`}?dp0OJ>BXhOPBo?HxubmA8FTFMyFT(4=cruMA{JQ$~uvN&r z7M75)KE|WiHdYI&dIKn#v}cR8me#k}WJcVa_ux~q;uvA;Pv)ONqt7avM+Q}>c`7@RD6fDZK89&^Exl4n-y_zFP5=~d0Z<~ zhQUQo6b2i8QHf)f2~$fksN;DI|1N}RMb_spe5gq^9sVnnffkG6&7;L8nI!yY#GyTj zk{rM2W^_|MT&|YVe6KqG=e1?cD=0ZVt3D_Mi;k3Bo#$v$=dDJz-l;?lr*-_Hv;IF!BWO7aFT9v6MRk%#^} z;H>Ts^WKBtjH;Q4O%7_A2?K^oFRKBeIsElTA@Jtn>d!%hn>mc2{wQ{BCLdm#8%l$oa8yr#ZJMp7qQ0`%yhfSNx!6c&YQ}9k%XN6Lf~m&+Usx zC!9Zi%x}t7Y3O|Z4e1p(e0tBR-eT4S78xpDBsdp!50AJpbKwGd1{W6{k5u$~jw_`y zpn!H|*3k=l8*ABM?eoJXnu6x=i_r*BnWRh-dT`Pw58zzFeIQ*r#%Ol~Ok23CEePJa z4`A#E&;&S8&jx)1RrA7K=m{-vPR>ujdqsN;7s^R`WPx5F@EV;a%iZ+=^DlNcW}3rn z3__0CflP}FUU^u7@P5Cn%s%CWuS-tIyogyS|Mbc?WHw{u=-}HsooO~dTH~#C1^q<} zFo+vH1eoMjMvUn=f!#^fuu)Ct> zG58;j2XSh`F(dI)-kx{HzmYJu0=AiQ+VdQ@^oYJFSz@oDurvy^hdPw&4w7|0Hj!=z zfi|OTbD$g)$rU~!1i8_<$?vOoGk+i2(nKkCAV;hqhbs~&DeYUJqM@%w_putAjo>$Ts)Jy(Fh>=cQ?kq?RTJ$}c`Z5#57ij_NnE;$3@28`DCA(EQM zkg6ki@ilDKC4CDgNnR1wDcC8#%xWs-Fu5>++gQ`o@QqVyi(EK8c+myziZ0aq#@X1) z@_ScRq~4r3{0HgNyhKorTh0JReg;&G;>?{4l)b-X52q=Y9Ua06Tx_wBkVN2|CDow5{Lqb2E$kEH_4T$6@b>MCERRpm%hV({+sI^zje-Uz_tY`fWhtwp% zg)u9-UmT?J3MMlZIqaIP>_PI9)&{G?4e(92e4z^%k$Gr$jdF;J7dQaRc(#N}A|HMM zyzi>aUd^712s(?un#cLt+Yz)^RuzFLCD=3? zmT*f2wFa)>3*;=R@7UoLnyRBhJmv zy|+_PImji06V0J=qoCfj)XpMzi|H8!mV}H_Hb_WRK5@*U%!P@ae==RQDeS%+OyON3 z-Dxj5OG(@&5l*Y^H&3f+Kxl>Mc#ZzEc8X1m?tu;*}&&>pnNT*u~2x|u(qr|@d zS?E2W*c!P*MTRy(Z_3RnJ`BV`;FesfviVVVskfsxv+trmb@>N)BkA1q{U!=>%W#0* zjSh&fae$B1WHICT;=F6#yhs*rq^*-jI`n^PeBAS8R`_($cZg3Joaj+UXY0Qo5;Lfc z%;}9>pAKG8Wx90ET(I?|7KXNvi#79!o=O;iK_$s1H^BjOX8J*l6;OJeHDVoNJWYug z!3R{2iQcCty9`NCkndvc7k9Tt;gQqcXDdtgdW{nq{m|l)AFvq-t~&3oTewEQLo+I6 zywp>&?INZZ#gS?~4BQfw4lvhRyh`7Aht!8W$ou?ilaDb(&{=Ue8YGtSyAI;T7>eAS zT|KzoGp;)EyJEt-1M|xKAL6};XKQG_nn@PIJDES-_R0Me z_Cva1Q@EVEJP!XU#>@Gc$z4-z=QgsxjP;&2curs4LU{^5Yl~Z~q$KTF7{u@! zN;G~BT8vwyFXQ#eHg8)MN2!uDh6L(Jj1jUM_#*jNUIKeK*g{28xKes&#V`M#qOLp~ zs=f^uBSM(owDMYpnj!SQwvdeR+1HLimPR5&ip(fv9a18LnXzxJ5 zSjN7-WQ+LDd|hvyzt45fb*}R}_ql)feLv4L7|!*_rT>mKz7!tILY&Wi78Zd>6WlrR zWgYA~)UB5?0agrnd}#*7OHkH`p@Zg2tHp7GV2tdt~`O0`yiCb zoKyjY&?uxQWUG#~d4|lYDHtk%k4^|Hw9G^bcC*un>LCnO*tw@GA3U#)y~W_g+Pc#J z%8}bN=*T$ha8g-AHa;1Dt|Kzu|8``zypx`n5DY!%JohfRrZYllAC({`nTCmiL0%T3 zgzldSe&n2mO`m2Ib8a%a6eF!;s~7OIX3+%Mrf=Y|p&9qAakKdoQ?)2YqY`w(DRDGK z8?tO)xk>UVE2J(@f_bLSfVMZS8ZBMJBi92>1}n5g&L)Oz{)OJA=^z_1j}AtYBrT2# zjgB-*3RzDdS9bC^os@d)spnOR@cT`sfrDVJ%o1^xUvXN*P`#@I3)>zX7A(@}m>d<= zC=o?Qlf`gJvjWr4_)XLNcvhZH+aM2eWoj!O4}Q23rotJ(JCe6UUypuwT^Q#3IuvE+ zHx+b5za}Z$k3T7Eo}Xg@DZW*E_+#>;=9c_Ai%IgIN8~EhjDC{Y7J6Kmo!TdgVRu6g z9nSGK_5g}IwbIQpSVVN}%A$Qy9rMM!VMuBHoy zCkE|78{U($esb6-BnC1L7_^P>$AE-JkT9Oy9HVuN;{5-u$SyRJA^m=@vs?DJ0vHDe z`7{ac3yfs{tM`FQ9#`g)ldZ(w#k(9Q%^695EbO_nJKFv8%(4e!FtXZ->Ca zhp4pqBJM%!2pS^U;bOKYzBgJ-{i5Vy`Na^_seffc0PcY>m1 z9@F*aw1~h6ZvB@H#@?p;LE1Hly2V|IU6>yQGY^l6kmxiQ;|ka_`0pG8NRY2XfR^5F zcY-qF0x78au0R{_r<0xR3wg&hZ1}tP%v4kZ>g5($;^B=?yk5C{ee7tQ^JkSWmFN*l z@dqE}0?)BIKJO`RVc?q@02x0;xTzK5*zS-#K_hFw(@nCX$S!+G3eR1;TF^PX(P~yj zGd8WF-p)e};1?RahxVqG+*e*zN5~uVft;T(h@x7cqHX~<=3Qk}qmaSSt+6fl+12rK zAluVlE#sbDMSZ#b-aq-uxV8BV+U*FDG3ol7da0Sq`d0#V7AW{D6k)`2DtmT4Q;;L# zD8Nj&4yUZ))5?zPQn!RgHK&r$>W1?5Z{h>Xr>F~<3Vr!`OUE894XOQF1$EB9U?keSHlEO!V@!t(OP{OP zlD5(6F}Z~aU><~H$aw?B0=zpce{6KP<~tUvTa4!2^`M8kBb`h1y1Z>&!5o%2L8(H@ zs1}9hds`+}J>Lh{gt(IsoDxSW?A1KHChn$Vbb-T7$zd6n;F=&k5u(p!FZeK?NFFhW zFlI3Jt(VC6x;zuj6v`5C{Q#?BE*uymt(I{Dkc94lVUSel9Mg(d&X#{u+LQ%T(zNV{qJ?acVBw1`kWy3G^pyI;oy;4^4(t9 zfPsldJKPjSk&AVa`Er012T3n}KU*M1Yo8Pr9h1@#DA0tvVP2Hi7~GfJ1Bifb)91ObSjU6s?x0gxA@g4l)9Lyujb9ykOZ^@@59Y;JB@b_d(Hn}zO zquYgBiF^fzs%KV>R|Fo3)Sd+FKZT17>Zc1H`Av}JLh$u`Catoz+O89Hk<_{hz5FIA(tw+P(s z=wbKm50k`0u<6?3U@Kv@Z`)9PM&mc40sW9L4ZX^hdp_-~zA+hgK!QH#*Mpa%8`=6;luKm*MJ zELiWR`PGaA?1sSARy|>HgGw!A3j&T1q4UW%5cYWmUa3u(m3+>fNQ~jE$ema` zrX6Y`&hG{-TJU%B|F8=pv(PmN=>$d!j6U*SAWUfY(;%ZC*v`zBM8hL5Pq|3P>ZX=} z{&)(-rA)eS5hC4Yi@UvzjOG|xYw9cX2eDUN1qy!|2Y@yHYMHZ2GPchGZ>)WkvH2JD zk?G=b2~zKc8`0M#=wKqUbgup}3q4`dX7>U~yooVd w%S&ftCQ5R&{CriM?ydX3?`HwwjcwTHY 'Mapzen' -> 'MapStyle'. To edit the Map Style, select it from the project window and then use the inspector window to view and change settings. - -Editing Options ---------------- - -![MapStyle editing options](Images/MapStyleEditingOptions.png) - -If you enable the option to update while editing, any RegionMap instances in the current scene that use this MapStyle will be rebuilt using the current MapStyle settings whenever a change is made. - -**IMPORTANT:** These automatic updates will overwrite any manual edits you have made to the map objects in the scene. - -Layer List ----------- - -![MapStyle layer list editor](Images/MapStyleLayerList.png) - -Next is a list of "Layers". Each Layer in a Map Style represents a grouping of objects in the map data (these objects are called features) and the settings that will be applied to those objects when they are downloaded. - -You can add a new layer with the 'Add Layer' button and remove one or more layers by selecting them in the list and pressing the 'Remove Selected' button. The ordering of Layers in the list does not affect the construction of the map. - -Layers can be renamed in the list by selecting one and pressing Enter. It's often helpful to name Layers according to the grouping of features that you intend to include in the Layer. For example, if you wanted a Layer to style buildings of a certain height you could name the layer "Tall Buildings". - -Layer Properties ----------------- - -![MapStyle layer properties editor](Images/MapStyleLayerProperties.png) - -When a layer is selected its properties will be displayed below the list. - -### Feature Collections - -Features in the map data are organized into broad groupings called "feature collections". Use this drop-down to select which feature collection(s) this Layer will apply to. - -### Matchers - -To narrow down the set of features that this Layer will apply to, you can add one or more Matchers in the form of a list. - -Each item in the list is a separate Matcher, which can be one of several types selectable from the drop-down. - -Type | Description ------|------------ -None | Matches all features. -Property | Matches features that contain the property named in 'Property Key', regardless of the value of that property. -Property Range | Matches features have the property named in 'Property Key' with a value >= and < the two range parameters. -Property Regex | Matches features have the property named in 'Property Key' with a value that matches the regular expression in the 'With Pattern' parameter. -Property Value | Matches features have the property named in 'Property Key' with a value equal to the 'With Value' parameter. - -### Combine Matchers - -If you have more than one Matcher in the Matchers list, they can be logically combined with one of several options. - -Option | The Layer will apply to features that ... --------|------------------------------------------ -All Of | match all of the Matchers in the list -Any Of | match any of the Matchers in the list -None Of | match any of the Matchers in the list - -### Style - -Each of the features in this Layer will be turned into renderable meshes using the builders enabled in the Style section. - -### Polygon Builder - -The Polygon Builder will create flat or extruded polygons from features that include polygon geometry. - -Field | Description -------|------------ -Material | The material that will be applied to the polygon mesh. -Extrusion | Determines how the polygon will be extruded. 'Top Only' produces only a flat polygon. 'Sides Only' produces vertical faces along each segment of the polygon. 'Top And Sides' produces vertical faces with a flat polygon on top. -UV Mode | Determines how UV coordinates will be placed on the mesh. 'Stretch' will generate UV coordinates that span 0 to 1 across each mesh face. 'Tile' will generate UV coordinates distributed uniformly in world space, possibly outside the 0 to 1 range. 'Stretch U Tile V' and 'Tile U Stretch V' apply these two options separately to the U and V coordinates. -Min Height | The height of the bottom of an extruded polygon in meters. If this is left as 0, the "min_height" property of the feature will be used. -Max Height | The height of the top of an extruded polygon in meters. If this is left as 0, the "max_height" property of the feature will be used. - -### Polyline Builder - -The Polyline Builder will create flat or extruded polylines from features that include either polyline geometry or polygon geometry. - -Field | Description -------|------------ -Material | The material that will be applied to the polyline mesh. -Extrusion | Determines how the polyline will be extruded. 'Top Only' produces only a flat polyline. 'Sides Only' produces vertical faces along each segment of the polyline. 'Top And Sides' produces vertical faces with a flat polyline on top. -Min Height | The height of the bottom of an extruded polyline in meters. -Max Height | The height of the top of an extruded polygon in meters. -Width | The width of the polyline in meters. -Miter Limit | Sets a maximum length for the corners of polylines with tight bends. diff --git a/Documentation/RegionMapEditor.md b/Documentation/RegionMapEditor.md deleted file mode 100644 index 25bcae8c..00000000 --- a/Documentation/RegionMapEditor.md +++ /dev/null @@ -1,45 +0,0 @@ -Region Map Editor -================= - -![RegionMap editor interface](Images/RegionMapEditor.png) - -To create a map in a scene, you create a GameObject with a `RegionMap` component. `RegionMap` has a custom editor that allows you to configure where and how the map is built. - -RegionMap Options ------------------ - -### Api Key - -Enter your Mapzen API key. An API key enables access to Mapzen's vector tile service. If you don't have one already, you can click the button next to the field to go straight to the Mapzen developer site. - -### Style - -Select the `MapStyle` that you want to use for building this map. The `MapStyle` will determine which map features are built and how they are styled. See [MapStyleEditor.md](MapStyleEditor.md) for details. - -### Area - -Choose the area of Earth that this map should represent. The area is represented by a bounding box with a `Min` point and a `Max` point in longitude and latitude. The area also requires a `Zoom`. Higher zoom corresponds to more detailed geometry. Zoom 16 provides the maximum detail available in Mapzen vector tiles. - -### Units Per Meter - -Set the scale of map geometry in the scene. A value of `1` will make 1 unit in the Unity scene correspond to 1 meter in geographic space, `0.5` will make 1 unit correspond to 2 geographic meters, etc. - -### Region Name - -Set the name of the GameObject that will contain the map. If an object in the scene already exists with this name then it will be overwritten. - -### Grouping Options - -Choose how the map will be organized in the scene heirarchy. For each of the grouping options selected, the map will be split into seperate GameObjects according to that attribute. - -### Game Object Options - -Choose options for the GameObjects created to contain the map. - - - `Is Static` determines whether the resulting GameObjects use static lightmaps. - - `Generate Physic Mesh Collider` determines whether the resulting GameObjects will have a RigidBody and MeshCollider for physics interactions. - - `Physic Material` determines the PhysicsMaterial that will be used if physics mesh colliders are generated. - -### Download - -Press to retreive map data for the chosen area and construct GameObjects for the map. If the button is grey and inactive, make sure that you have entered values for `Api Key`, `Style`, and `Region Name`. diff --git a/LICENSE.md.meta b/LICENSE.md.meta new file mode 100644 index 00000000..93491a3c --- /dev/null +++ b/LICENSE.md.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: 6793b4b3fbebaf54f939ac613025c373 +TextScriptImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Packages/manifest.json b/Packages/manifest.json deleted file mode 100644 index ffb3838a..00000000 --- a/Packages/manifest.json +++ /dev/null @@ -1,43 +0,0 @@ -{ - "dependencies": { - "com.unity.collab-proxy": "2.0.1", - "com.unity.ide.rider": "3.0.18", - "com.unity.ide.visualstudio": "2.0.17", - "com.unity.ide.vscode": "1.2.5", - "com.unity.test-framework": "1.1.31", - "com.unity.textmeshpro": "3.0.6", - "com.unity.timeline": "1.6.4", - "com.unity.ugui": "1.0.0", - "com.unity.modules.ai": "1.0.0", - "com.unity.modules.androidjni": "1.0.0", - "com.unity.modules.animation": "1.0.0", - "com.unity.modules.assetbundle": "1.0.0", - "com.unity.modules.audio": "1.0.0", - "com.unity.modules.cloth": "1.0.0", - "com.unity.modules.director": "1.0.0", - "com.unity.modules.imageconversion": "1.0.0", - "com.unity.modules.imgui": "1.0.0", - "com.unity.modules.jsonserialize": "1.0.0", - "com.unity.modules.particlesystem": "1.0.0", - "com.unity.modules.physics": "1.0.0", - "com.unity.modules.physics2d": "1.0.0", - "com.unity.modules.screencapture": "1.0.0", - "com.unity.modules.terrain": "1.0.0", - "com.unity.modules.terrainphysics": "1.0.0", - "com.unity.modules.tilemap": "1.0.0", - "com.unity.modules.ui": "1.0.0", - "com.unity.modules.uielements": "1.0.0", - "com.unity.modules.umbra": "1.0.0", - "com.unity.modules.unityanalytics": "1.0.0", - "com.unity.modules.unitywebrequest": "1.0.0", - "com.unity.modules.unitywebrequestassetbundle": "1.0.0", - "com.unity.modules.unitywebrequestaudio": "1.0.0", - "com.unity.modules.unitywebrequesttexture": "1.0.0", - "com.unity.modules.unitywebrequestwww": "1.0.0", - "com.unity.modules.vehicles": "1.0.0", - "com.unity.modules.video": "1.0.0", - "com.unity.modules.vr": "1.0.0", - "com.unity.modules.wind": "1.0.0", - "com.unity.modules.xr": "1.0.0" - } -} diff --git a/Packages/packages-lock.json b/Packages/packages-lock.json deleted file mode 100644 index d1ef6780..00000000 --- a/Packages/packages-lock.json +++ /dev/null @@ -1,338 +0,0 @@ -{ - "dependencies": { - "com.unity.collab-proxy": { - "version": "2.0.1", - "depth": 0, - "source": "registry", - "dependencies": {}, - "url": "https://packages.unity.com" - }, - "com.unity.ext.nunit": { - "version": "1.0.6", - "depth": 1, - "source": "registry", - "dependencies": {}, - "url": "https://packages.unity.com" - }, - "com.unity.ide.rider": { - "version": "3.0.18", - "depth": 0, - "source": "registry", - "dependencies": { - "com.unity.ext.nunit": "1.0.6" - }, - "url": "https://packages.unity.com" - }, - "com.unity.ide.visualstudio": { - "version": "2.0.17", - "depth": 0, - "source": "registry", - "dependencies": { - "com.unity.test-framework": "1.1.9" - }, - "url": "https://packages.unity.com" - }, - "com.unity.ide.vscode": { - "version": "1.2.5", - "depth": 0, - "source": "registry", - "dependencies": {}, - "url": "https://packages.unity.com" - }, - "com.unity.test-framework": { - "version": "1.1.31", - "depth": 0, - "source": "registry", - "dependencies": { - "com.unity.ext.nunit": "1.0.6", - "com.unity.modules.imgui": "1.0.0", - "com.unity.modules.jsonserialize": "1.0.0" - }, - "url": "https://packages.unity.com" - }, - "com.unity.textmeshpro": { - "version": "3.0.6", - "depth": 0, - "source": "registry", - "dependencies": { - "com.unity.ugui": "1.0.0" - }, - "url": "https://packages.unity.com" - }, - "com.unity.timeline": { - "version": "1.6.4", - "depth": 0, - "source": "registry", - "dependencies": { - "com.unity.modules.director": "1.0.0", - "com.unity.modules.animation": "1.0.0", - "com.unity.modules.audio": "1.0.0", - "com.unity.modules.particlesystem": "1.0.0" - }, - "url": "https://packages.unity.com" - }, - "com.unity.ugui": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.ui": "1.0.0", - "com.unity.modules.imgui": "1.0.0" - } - }, - "com.unity.modules.ai": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.androidjni": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.animation": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.assetbundle": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.audio": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.cloth": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.physics": "1.0.0" - } - }, - "com.unity.modules.director": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.audio": "1.0.0", - "com.unity.modules.animation": "1.0.0" - } - }, - "com.unity.modules.imageconversion": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.imgui": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.jsonserialize": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.particlesystem": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.physics": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.physics2d": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.screencapture": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.imageconversion": "1.0.0" - } - }, - "com.unity.modules.subsystems": { - "version": "1.0.0", - "depth": 1, - "source": "builtin", - "dependencies": { - "com.unity.modules.jsonserialize": "1.0.0" - } - }, - "com.unity.modules.terrain": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.terrainphysics": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.physics": "1.0.0", - "com.unity.modules.terrain": "1.0.0" - } - }, - "com.unity.modules.tilemap": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.physics2d": "1.0.0" - } - }, - "com.unity.modules.ui": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.uielements": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.ui": "1.0.0", - "com.unity.modules.imgui": "1.0.0", - "com.unity.modules.jsonserialize": "1.0.0", - "com.unity.modules.uielementsnative": "1.0.0" - } - }, - "com.unity.modules.uielementsnative": { - "version": "1.0.0", - "depth": 1, - "source": "builtin", - "dependencies": { - "com.unity.modules.ui": "1.0.0", - "com.unity.modules.imgui": "1.0.0", - "com.unity.modules.jsonserialize": "1.0.0" - } - }, - "com.unity.modules.umbra": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.unityanalytics": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.unitywebrequest": "1.0.0", - "com.unity.modules.jsonserialize": "1.0.0" - } - }, - "com.unity.modules.unitywebrequest": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.unitywebrequestassetbundle": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.assetbundle": "1.0.0", - "com.unity.modules.unitywebrequest": "1.0.0" - } - }, - "com.unity.modules.unitywebrequestaudio": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.unitywebrequest": "1.0.0", - "com.unity.modules.audio": "1.0.0" - } - }, - "com.unity.modules.unitywebrequesttexture": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.unitywebrequest": "1.0.0", - "com.unity.modules.imageconversion": "1.0.0" - } - }, - "com.unity.modules.unitywebrequestwww": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.unitywebrequest": "1.0.0", - "com.unity.modules.unitywebrequestassetbundle": "1.0.0", - "com.unity.modules.unitywebrequestaudio": "1.0.0", - "com.unity.modules.audio": "1.0.0", - "com.unity.modules.assetbundle": "1.0.0", - "com.unity.modules.imageconversion": "1.0.0" - } - }, - "com.unity.modules.vehicles": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.physics": "1.0.0" - } - }, - "com.unity.modules.video": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.audio": "1.0.0", - "com.unity.modules.ui": "1.0.0", - "com.unity.modules.unitywebrequest": "1.0.0" - } - }, - "com.unity.modules.vr": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.jsonserialize": "1.0.0", - "com.unity.modules.physics": "1.0.0", - "com.unity.modules.xr": "1.0.0" - } - }, - "com.unity.modules.wind": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": {} - }, - "com.unity.modules.xr": { - "version": "1.0.0", - "depth": 0, - "source": "builtin", - "dependencies": { - "com.unity.modules.physics": "1.0.0", - "com.unity.modules.jsonserialize": "1.0.0", - "com.unity.modules.subsystems": "1.0.0" - } - } - } -} diff --git a/ProjectSettings/AudioManager.asset b/ProjectSettings/AudioManager.asset deleted file mode 100644 index 2c4f5a1b..00000000 --- a/ProjectSettings/AudioManager.asset +++ /dev/null @@ -1,16 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!11 &1 -AudioManager: - m_ObjectHideFlags: 0 - m_Volume: 1 - Rolloff Scale: 1 - Doppler Factor: 1 - Default Speaker Mode: 2 - m_SampleRate: 0 - m_DSPBufferSize: 0 - m_VirtualVoiceCount: 512 - m_RealVoiceCount: 32 - m_SpatializerPlugin: - m_DisableAudio: 0 - m_VirtualizeEffects: 1 diff --git a/ProjectSettings/ClusterInputManager.asset b/ProjectSettings/ClusterInputManager.asset deleted file mode 100644 index e7886b26..00000000 --- a/ProjectSettings/ClusterInputManager.asset +++ /dev/null @@ -1,6 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!236 &1 -ClusterInputManager: - m_ObjectHideFlags: 0 - m_Inputs: [] diff --git a/ProjectSettings/DynamicsManager.asset b/ProjectSettings/DynamicsManager.asset deleted file mode 100644 index 6be69106..00000000 --- a/ProjectSettings/DynamicsManager.asset +++ /dev/null @@ -1,18 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!55 &1 -PhysicsManager: - m_ObjectHideFlags: 0 - serializedVersion: 3 - m_Gravity: {x: 0, y: -9.81, z: 0} - m_DefaultMaterial: {fileID: 0} - m_BounceThreshold: 2 - m_SleepThreshold: 0.005 - m_DefaultContactOffset: 0.01 - m_DefaultSolverIterations: 6 - m_DefaultSolverVelocityIterations: 1 - m_QueriesHitBackfaces: 0 - m_QueriesHitTriggers: 1 - m_EnableAdaptiveForce: 0 - m_EnablePCM: 1 - m_LayerCollisionMatrix: ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff diff --git a/ProjectSettings/EditorBuildSettings.asset b/ProjectSettings/EditorBuildSettings.asset deleted file mode 100644 index 18c8bb60..00000000 --- a/ProjectSettings/EditorBuildSettings.asset +++ /dev/null @@ -1,10 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!1045 &1 -EditorBuildSettings: - m_ObjectHideFlags: 0 - serializedVersion: 2 - m_Scenes: - - enabled: 1 - path: Assets/Scenes/RegionMapExample.unity - guid: e1030ce9fa8804eae9a841d9a604d7bc diff --git a/ProjectSettings/EditorSettings.asset b/ProjectSettings/EditorSettings.asset deleted file mode 100644 index 872db487..00000000 --- a/ProjectSettings/EditorSettings.asset +++ /dev/null @@ -1,35 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!159 &1 -EditorSettings: - m_ObjectHideFlags: 0 - serializedVersion: 9 - m_ExternalVersionControlSupport: Visible Meta Files - m_SerializationMode: 2 - m_LineEndingsForNewScripts: 1 - m_DefaultBehaviorMode: 0 - m_PrefabRegularEnvironment: {fileID: 0} - m_PrefabUIEnvironment: {fileID: 0} - m_SpritePackerMode: 2 - m_SpritePackerPaddingPower: 1 - m_EtcTextureCompressorBehavior: 0 - m_EtcTextureFastCompressor: 2 - m_EtcTextureNormalCompressor: 2 - m_EtcTextureBestCompressor: 5 - m_ProjectGenerationIncludedExtensions: txt;xml;fnt;cd;asmref - m_ProjectGenerationRootNamespace: - m_CollabEditorSettings: - inProgressEnabled: 1 - m_EnableTextureStreamingInEditMode: 1 - m_EnableTextureStreamingInPlayMode: 1 - m_AsyncShaderCompilation: 1 - m_EnterPlayModeOptionsEnabled: 0 - m_EnterPlayModeOptions: 3 - m_ShowLightmapResolutionOverlay: 1 - m_UseLegacyProbeSampleCount: 1 - m_AssetPipelineMode: 1 - m_CacheServerMode: 0 - m_CacheServerEndpoint: - m_CacheServerNamespacePrefix: default - m_CacheServerEnableDownload: 1 - m_CacheServerEnableUpload: 1 diff --git a/ProjectSettings/GraphicsSettings.asset b/ProjectSettings/GraphicsSettings.asset deleted file mode 100644 index 6f5e880b..00000000 --- a/ProjectSettings/GraphicsSettings.asset +++ /dev/null @@ -1,64 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!30 &1 -GraphicsSettings: - m_ObjectHideFlags: 0 - serializedVersion: 12 - m_Deferred: - m_Mode: 1 - m_Shader: {fileID: 69, guid: 0000000000000000f000000000000000, type: 0} - m_DeferredReflections: - m_Mode: 1 - m_Shader: {fileID: 74, guid: 0000000000000000f000000000000000, type: 0} - m_ScreenSpaceShadows: - m_Mode: 1 - m_Shader: {fileID: 64, guid: 0000000000000000f000000000000000, type: 0} - m_LegacyDeferred: - m_Mode: 1 - m_Shader: {fileID: 63, guid: 0000000000000000f000000000000000, type: 0} - m_DepthNormals: - m_Mode: 1 - m_Shader: {fileID: 62, guid: 0000000000000000f000000000000000, type: 0} - m_MotionVectors: - m_Mode: 1 - m_Shader: {fileID: 75, guid: 0000000000000000f000000000000000, type: 0} - m_LightHalo: - m_Mode: 1 - m_Shader: {fileID: 105, guid: 0000000000000000f000000000000000, type: 0} - m_LensFlare: - m_Mode: 1 - m_Shader: {fileID: 102, guid: 0000000000000000f000000000000000, type: 0} - m_AlwaysIncludedShaders: - - {fileID: 7, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 15104, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 15105, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 15106, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 10753, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 10770, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 10782, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 16000, guid: 0000000000000000f000000000000000, type: 0} - - {fileID: 16001, guid: 0000000000000000f000000000000000, type: 0} - m_PreloadedShaders: [] - m_SpritesDefaultMaterial: {fileID: 10754, guid: 0000000000000000f000000000000000, - type: 0} - m_CustomRenderPipeline: {fileID: 0} - m_TransparencySortMode: 0 - m_TransparencySortAxis: {x: 0, y: 0, z: 1} - m_DefaultRenderingPath: 1 - m_DefaultMobileRenderingPath: 1 - m_TierSettings: [] - m_LightmapStripping: 0 - m_FogStripping: 0 - m_InstancingStripping: 0 - m_LightmapKeepPlain: 1 - m_LightmapKeepDirCombined: 1 - m_LightmapKeepDynamicPlain: 1 - m_LightmapKeepDynamicDirCombined: 1 - m_LightmapKeepShadowMask: 1 - m_LightmapKeepSubtractive: 1 - m_FogKeepLinear: 1 - m_FogKeepExp: 1 - m_FogKeepExp2: 1 - m_AlbedoSwatchInfos: [] - m_LightsUseLinearIntensity: 0 - m_LightsUseColorTemperature: 0 diff --git a/ProjectSettings/InputManager.asset b/ProjectSettings/InputManager.asset deleted file mode 100644 index 17c8f538..00000000 --- a/ProjectSettings/InputManager.asset +++ /dev/null @@ -1,295 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!13 &1 -InputManager: - m_ObjectHideFlags: 0 - serializedVersion: 2 - m_Axes: - - serializedVersion: 3 - m_Name: Horizontal - descriptiveName: - descriptiveNegativeName: - negativeButton: left - positiveButton: right - altNegativeButton: a - altPositiveButton: d - gravity: 3 - dead: 0.001 - sensitivity: 3 - snap: 1 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Vertical - descriptiveName: - descriptiveNegativeName: - negativeButton: down - positiveButton: up - altNegativeButton: s - altPositiveButton: w - gravity: 3 - dead: 0.001 - sensitivity: 3 - snap: 1 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Fire1 - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: left ctrl - altNegativeButton: - altPositiveButton: mouse 0 - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Fire2 - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: left alt - altNegativeButton: - altPositiveButton: mouse 1 - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Fire3 - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: left shift - altNegativeButton: - altPositiveButton: mouse 2 - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Jump - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: space - altNegativeButton: - altPositiveButton: - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Mouse X - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: - altNegativeButton: - altPositiveButton: - gravity: 0 - dead: 0 - sensitivity: 0.1 - snap: 0 - invert: 0 - type: 1 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Mouse Y - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: - altNegativeButton: - altPositiveButton: - gravity: 0 - dead: 0 - sensitivity: 0.1 - snap: 0 - invert: 0 - type: 1 - axis: 1 - joyNum: 0 - - serializedVersion: 3 - m_Name: Mouse ScrollWheel - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: - altNegativeButton: - altPositiveButton: - gravity: 0 - dead: 0 - sensitivity: 0.1 - snap: 0 - invert: 0 - type: 1 - axis: 2 - joyNum: 0 - - serializedVersion: 3 - m_Name: Horizontal - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: - altNegativeButton: - altPositiveButton: - gravity: 0 - dead: 0.19 - sensitivity: 1 - snap: 0 - invert: 0 - type: 2 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Vertical - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: - altNegativeButton: - altPositiveButton: - gravity: 0 - dead: 0.19 - sensitivity: 1 - snap: 0 - invert: 1 - type: 2 - axis: 1 - joyNum: 0 - - serializedVersion: 3 - m_Name: Fire1 - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: joystick button 0 - altNegativeButton: - altPositiveButton: - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Fire2 - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: joystick button 1 - altNegativeButton: - altPositiveButton: - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Fire3 - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: joystick button 2 - altNegativeButton: - altPositiveButton: - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Jump - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: joystick button 3 - altNegativeButton: - altPositiveButton: - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Submit - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: return - altNegativeButton: - altPositiveButton: joystick button 0 - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Submit - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: enter - altNegativeButton: - altPositiveButton: space - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 - - serializedVersion: 3 - m_Name: Cancel - descriptiveName: - descriptiveNegativeName: - negativeButton: - positiveButton: escape - altNegativeButton: - altPositiveButton: joystick button 1 - gravity: 1000 - dead: 0.001 - sensitivity: 1000 - snap: 0 - invert: 0 - type: 0 - axis: 0 - joyNum: 0 diff --git a/ProjectSettings/MemorySettings.asset b/ProjectSettings/MemorySettings.asset deleted file mode 100644 index 5b5facec..00000000 --- a/ProjectSettings/MemorySettings.asset +++ /dev/null @@ -1,35 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!387306366 &1 -MemorySettings: - m_ObjectHideFlags: 0 - m_EditorMemorySettings: - m_MainAllocatorBlockSize: -1 - m_ThreadAllocatorBlockSize: -1 - m_MainGfxBlockSize: -1 - m_ThreadGfxBlockSize: -1 - m_CacheBlockSize: -1 - m_TypetreeBlockSize: -1 - m_ProfilerBlockSize: -1 - m_ProfilerEditorBlockSize: -1 - m_BucketAllocatorGranularity: -1 - m_BucketAllocatorBucketsCount: -1 - m_BucketAllocatorBlockSize: -1 - m_BucketAllocatorBlockCount: -1 - m_ProfilerBucketAllocatorGranularity: -1 - m_ProfilerBucketAllocatorBucketsCount: -1 - m_ProfilerBucketAllocatorBlockSize: -1 - m_ProfilerBucketAllocatorBlockCount: -1 - m_TempAllocatorSizeMain: -1 - m_JobTempAllocatorBlockSize: -1 - m_BackgroundJobTempAllocatorBlockSize: -1 - m_JobTempAllocatorReducedBlockSize: -1 - m_TempAllocatorSizeGIBakingWorker: -1 - m_TempAllocatorSizeNavMeshWorker: -1 - m_TempAllocatorSizeAudioWorker: -1 - m_TempAllocatorSizeCloudWorker: -1 - m_TempAllocatorSizeGfx: -1 - m_TempAllocatorSizeJobWorker: -1 - m_TempAllocatorSizeBackgroundWorker: -1 - m_TempAllocatorSizePreloadManager: -1 - m_PlatformMemorySettings: {} diff --git a/ProjectSettings/NavMeshAreas.asset b/ProjectSettings/NavMeshAreas.asset deleted file mode 100644 index 6dd520f6..00000000 --- a/ProjectSettings/NavMeshAreas.asset +++ /dev/null @@ -1,89 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!126 &1 -NavMeshProjectSettings: - m_ObjectHideFlags: 0 - serializedVersion: 2 - areas: - - name: Walkable - cost: 1 - - name: Not Walkable - cost: 1 - - name: Jump - cost: 2 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - - name: - cost: 1 - m_LastAgentTypeID: -887442657 - m_Settings: - - serializedVersion: 2 - agentTypeID: 0 - agentRadius: 0.5 - agentHeight: 2 - agentSlope: 45 - agentClimb: 0.75 - ledgeDropHeight: 0 - maxJumpAcrossDistance: 0 - minRegionArea: 2 - manualCellSize: 0 - cellSize: 0.16666667 - manualTileSize: 0 - tileSize: 256 - accuratePlacement: 0 - m_SettingNames: - - Humanoid diff --git a/ProjectSettings/NetworkManager.asset b/ProjectSettings/NetworkManager.asset deleted file mode 100644 index 5dc6a831..00000000 --- a/ProjectSettings/NetworkManager.asset +++ /dev/null @@ -1,8 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!149 &1 -NetworkManager: - m_ObjectHideFlags: 0 - m_DebugLevel: 0 - m_Sendrate: 15 - m_AssetToPrefab: {} diff --git a/ProjectSettings/PackageManagerSettings.asset b/ProjectSettings/PackageManagerSettings.asset deleted file mode 100644 index 137ce765..00000000 --- a/ProjectSettings/PackageManagerSettings.asset +++ /dev/null @@ -1,36 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!114 &1 -MonoBehaviour: - m_ObjectHideFlags: 61 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 0} - m_Enabled: 1 - m_EditorHideFlags: 0 - m_Script: {fileID: 13964, guid: 0000000000000000e000000000000000, type: 0} - m_Name: - m_EditorClassIdentifier: - m_EnablePreReleasePackages: 0 - m_EnablePackageDependencies: 0 - m_AdvancedSettingsExpanded: 1 - m_ScopedRegistriesSettingsExpanded: 1 - m_SeeAllPackageVersions: 0 - oneTimeWarningShown: 0 - m_Registries: - - m_Id: main - m_Name: - m_Url: https://packages.unity.com - m_Scopes: [] - m_IsDefault: 1 - m_Capabilities: 7 - m_ConfigSource: 0 - m_UserSelectedRegistryName: - m_UserAddingNewScopedRegistry: 0 - m_RegistryInfoDraft: - m_Modified: 0 - m_ErrorMessage: - m_UserModificationsInstanceId: -856 - m_OriginalInstanceId: -858 - m_LoadAssets: 0 diff --git a/ProjectSettings/Physics2DSettings.asset b/ProjectSettings/Physics2DSettings.asset deleted file mode 100644 index 5f6ffab1..00000000 --- a/ProjectSettings/Physics2DSettings.asset +++ /dev/null @@ -1,35 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!19 &1 -Physics2DSettings: - m_ObjectHideFlags: 0 - serializedVersion: 3 - m_Gravity: {x: 0, y: -9.81} - m_DefaultMaterial: {fileID: 0} - m_VelocityIterations: 8 - m_PositionIterations: 3 - m_VelocityThreshold: 1 - m_MaxLinearCorrection: 0.2 - m_MaxAngularCorrection: 8 - m_MaxTranslationSpeed: 100 - m_MaxRotationSpeed: 360 - m_BaumgarteScale: 0.2 - m_BaumgarteTimeOfImpactScale: 0.75 - m_TimeToSleep: 0.5 - m_LinearSleepTolerance: 0.01 - m_AngularSleepTolerance: 2 - m_DefaultContactOffset: 0.01 - m_QueriesHitTriggers: 1 - m_QueriesStartInColliders: 1 - m_ChangeStopsCallbacks: 0 - m_CallbacksOnDisable: 1 - m_AlwaysShowColliders: 0 - m_ShowColliderSleep: 1 - m_ShowColliderContacts: 0 - m_ShowColliderAABB: 0 - m_ContactArrowScale: 0.2 - m_ColliderAwakeColor: {r: 0.5686275, g: 0.95686275, b: 0.54509807, a: 0.7529412} - m_ColliderAsleepColor: {r: 0.5686275, g: 0.95686275, b: 0.54509807, a: 0.36078432} - m_ColliderContactColor: {r: 1, g: 0, b: 1, a: 0.6862745} - m_ColliderAABBColor: {r: 1, g: 1, b: 0, a: 0.2509804} - m_LayerCollisionMatrix: ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff diff --git a/ProjectSettings/PresetManager.asset b/ProjectSettings/PresetManager.asset deleted file mode 100644 index 67a94dae..00000000 --- a/ProjectSettings/PresetManager.asset +++ /dev/null @@ -1,7 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!1386491679 &1 -PresetManager: - m_ObjectHideFlags: 0 - serializedVersion: 2 - m_DefaultPresets: {} diff --git a/ProjectSettings/ProjectSettings.asset b/ProjectSettings/ProjectSettings.asset deleted file mode 100644 index ac0d6ada..00000000 --- a/ProjectSettings/ProjectSettings.asset +++ /dev/null @@ -1,812 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!129 &1 -PlayerSettings: - m_ObjectHideFlags: 0 - serializedVersion: 24 - productGUID: dd117d38d745844fc8480950f2558604 - AndroidProfiler: 0 - AndroidFilterTouchesWhenObscured: 0 - AndroidEnableSustainedPerformanceMode: 0 - defaultScreenOrientation: 4 - targetDevice: 2 - useOnDemandResources: 0 - accelerometerFrequency: 60 - companyName: mapzen - productName: tangramunity - defaultCursor: {fileID: 0} - cursorHotspot: {x: 0, y: 0} - m_SplashScreenBackgroundColor: {r: 0.12156863, g: 0.12156863, b: 0.1254902, a: 1} - m_ShowUnitySplashScreen: 1 - m_ShowUnitySplashLogo: 1 - m_SplashScreenOverlayOpacity: 1 - m_SplashScreenAnimation: 1 - m_SplashScreenLogoStyle: 1 - m_SplashScreenDrawMode: 0 - m_SplashScreenBackgroundAnimationZoom: 1 - m_SplashScreenLogoAnimationZoom: 1 - m_SplashScreenBackgroundLandscapeAspect: 1 - m_SplashScreenBackgroundPortraitAspect: 1 - m_SplashScreenBackgroundLandscapeUvs: - serializedVersion: 2 - x: 0 - y: 0 - width: 1 - height: 1 - m_SplashScreenBackgroundPortraitUvs: - serializedVersion: 2 - x: 0 - y: 0 - width: 1 - height: 1 - m_SplashScreenLogos: [] - m_VirtualRealitySplashScreen: {fileID: 0} - m_HolographicTrackingLossScreen: {fileID: 0} - defaultScreenWidth: 1024 - defaultScreenHeight: 768 - defaultScreenWidthWeb: 960 - defaultScreenHeightWeb: 600 - m_StereoRenderingPath: 0 - m_ActiveColorSpace: 0 - m_MTRendering: 1 - mipStripping: 0 - numberOfMipsStripped: 0 - m_StackTraceTypes: 010000000100000001000000010000000100000001000000 - iosShowActivityIndicatorOnLoading: -1 - androidShowActivityIndicatorOnLoading: -1 - iosUseCustomAppBackgroundBehavior: 0 - iosAllowHTTPDownload: 1 - allowedAutorotateToPortrait: 1 - allowedAutorotateToPortraitUpsideDown: 1 - allowedAutorotateToLandscapeRight: 1 - allowedAutorotateToLandscapeLeft: 1 - useOSAutorotation: 1 - use32BitDisplayBuffer: 1 - preserveFramebufferAlpha: 0 - disableDepthAndStencilBuffers: 0 - androidStartInFullscreen: 1 - androidRenderOutsideSafeArea: 1 - androidUseSwappy: 0 - androidBlitType: 0 - androidResizableWindow: 0 - androidDefaultWindowWidth: 1920 - androidDefaultWindowHeight: 1080 - androidMinimumWindowWidth: 400 - androidMinimumWindowHeight: 300 - androidFullscreenMode: 1 - defaultIsNativeResolution: 1 - macRetinaSupport: 1 - runInBackground: 0 - captureSingleScreen: 0 - muteOtherAudioSources: 0 - Prepare IOS For Recording: 0 - Force IOS Speakers When Recording: 0 - deferSystemGesturesMode: 0 - hideHomeButton: 0 - submitAnalytics: 1 - usePlayerLog: 1 - bakeCollisionMeshes: 0 - forceSingleInstance: 0 - useFlipModelSwapchain: 1 - resizableWindow: 0 - useMacAppStoreValidation: 0 - macAppStoreCategory: public.app-category.games - gpuSkinning: 0 - xboxPIXTextureCapture: 0 - xboxEnableAvatar: 0 - xboxEnableKinect: 0 - xboxEnableKinectAutoTracking: 0 - xboxEnableFitness: 0 - visibleInBackground: 0 - allowFullscreenSwitch: 1 - fullscreenMode: 1 - xboxSpeechDB: 0 - xboxEnableHeadOrientation: 0 - xboxEnableGuest: 0 - xboxEnablePIXSampling: 0 - metalFramebufferOnly: 0 - xboxOneResolution: 0 - xboxOneSResolution: 0 - xboxOneXResolution: 3 - xboxOneMonoLoggingLevel: 0 - xboxOneLoggingLevel: 1 - xboxOneDisableEsram: 0 - xboxOneEnableTypeOptimization: 0 - xboxOnePresentImmediateThreshold: 0 - switchQueueCommandMemory: 1048576 - switchQueueControlMemory: 16384 - switchQueueComputeMemory: 262144 - switchNVNShaderPoolsGranularity: 33554432 - switchNVNDefaultPoolsGranularity: 16777216 - switchNVNOtherPoolsGranularity: 16777216 - switchNVNMaxPublicTextureIDCount: 0 - switchNVNMaxPublicSamplerIDCount: 0 - stadiaPresentMode: 0 - stadiaTargetFramerate: 0 - vulkanNumSwapchainBuffers: 3 - vulkanEnableSetSRGBWrite: 0 - vulkanEnablePreTransform: 0 - vulkanEnableLateAcquireNextImage: 0 - vulkanEnableCommandBufferRecycling: 1 - m_SupportedAspectRatios: - 4:3: 1 - 5:4: 1 - 16:10: 1 - 16:9: 1 - Others: 1 - bundleVersion: 1.0 - preloadedAssets: [] - metroInputSource: 0 - wsaTransparentSwapchain: 0 - m_HolographicPauseOnTrackingLoss: 1 - xboxOneDisableKinectGpuReservation: 0 - xboxOneEnable7thCore: 0 - vrSettings: - enable360StereoCapture: 0 - isWsaHolographicRemotingEnabled: 0 - enableFrameTimingStats: 0 - enableOpenGLProfilerGPURecorders: 1 - useHDRDisplay: 0 - D3DHDRBitDepth: 0 - m_ColorGamuts: 00000000 - targetPixelDensity: 30 - resolutionScalingMode: 0 - resetResolutionOnWindowResize: 0 - androidSupportedAspectRatio: 1 - androidMaxAspectRatio: 2.1 - applicationIdentifier: - Android: com.mapzen.tangramunity - Standalone: unity.DefaultCompany.mapzen - Tizen: com.Company.ProductName - iPhone: com.Company.ProductName - tvOS: com.Company.ProductName - buildNumber: - Standalone: 0 - iPhone: 0 - tvOS: 0 - overrideDefaultApplicationIdentifier: 1 - AndroidBundleVersionCode: 1 - AndroidMinSdkVersion: 22 - AndroidTargetSdkVersion: 0 - AndroidPreferredInstallLocation: 1 - aotOptions: - stripEngineCode: 1 - iPhoneStrippingLevel: 0 - iPhoneScriptCallOptimization: 0 - ForceInternetPermission: 0 - ForceSDCardPermission: 0 - CreateWallpaper: 0 - APKExpansionFiles: 0 - keepLoadedShadersAlive: 0 - StripUnusedMeshComponents: 0 - VertexChannelCompressionMask: 214 - iPhoneSdkVersion: 988 - iOSTargetOSVersionString: 12.0 - tvOSSdkVersion: 0 - tvOSRequireExtendedGameController: 0 - tvOSTargetOSVersionString: 12.0 - uIPrerenderedIcon: 0 - uIRequiresPersistentWiFi: 0 - uIRequiresFullScreen: 1 - uIStatusBarHidden: 1 - uIExitOnSuspend: 0 - uIStatusBarStyle: 0 - appleTVSplashScreen: {fileID: 0} - appleTVSplashScreen2x: {fileID: 0} - tvOSSmallIconLayers: [] - tvOSSmallIconLayers2x: [] - tvOSLargeIconLayers: [] - tvOSLargeIconLayers2x: [] - tvOSTopShelfImageLayers: [] - tvOSTopShelfImageLayers2x: [] - tvOSTopShelfImageWideLayers: [] - tvOSTopShelfImageWideLayers2x: [] - iOSLaunchScreenType: 0 - iOSLaunchScreenPortrait: {fileID: 0} - iOSLaunchScreenLandscape: {fileID: 0} - iOSLaunchScreenBackgroundColor: - serializedVersion: 2 - rgba: 0 - iOSLaunchScreenFillPct: 100 - iOSLaunchScreenSize: 100 - iOSLaunchScreenCustomXibPath: - iOSLaunchScreeniPadType: 0 - iOSLaunchScreeniPadImage: {fileID: 0} - iOSLaunchScreeniPadBackgroundColor: - serializedVersion: 2 - rgba: 0 - iOSLaunchScreeniPadFillPct: 100 - iOSLaunchScreeniPadSize: 100 - iOSLaunchScreeniPadCustomXibPath: - iOSLaunchScreenCustomStoryboardPath: - iOSLaunchScreeniPadCustomStoryboardPath: - iOSDeviceRequirements: [] - iOSURLSchemes: [] - macOSURLSchemes: [] - iOSBackgroundModes: 0 - iOSMetalForceHardShadows: 0 - metalEditorSupport: 0 - metalAPIValidation: 1 - iOSRenderExtraFrameOnPause: 1 - iosCopyPluginsCodeInsteadOfSymlink: 0 - appleDeveloperTeamID: - iOSManualSigningProvisioningProfileID: - tvOSManualSigningProvisioningProfileID: - iOSManualSigningProvisioningProfileType: 0 - tvOSManualSigningProvisioningProfileType: 0 - appleEnableAutomaticSigning: 0 - iOSRequireARKit: 0 - iOSAutomaticallyDetectAndAddCapabilities: 1 - appleEnableProMotion: 0 - shaderPrecisionModel: 0 - clonedFromGUID: 00000000000000000000000000000000 - templatePackageId: - templateDefaultScene: - useCustomMainManifest: 0 - useCustomLauncherManifest: 0 - useCustomMainGradleTemplate: 0 - useCustomLauncherGradleManifest: 0 - useCustomBaseGradleTemplate: 0 - useCustomGradlePropertiesTemplate: 0 - useCustomProguardFile: 0 - AndroidTargetArchitectures: 1 - AndroidTargetDevices: 0 - AndroidSplashScreenScale: 0 - androidSplashScreen: {fileID: 0} - AndroidKeystoreName: '{inproject}: ' - AndroidKeyaliasName: - AndroidBuildApkPerCpuArchitecture: 0 - AndroidTVCompatibility: 1 - AndroidIsGame: 1 - AndroidEnableTango: 0 - androidEnableBanner: 1 - androidUseLowAccuracyLocation: 0 - androidUseCustomKeystore: 0 - m_AndroidBanners: - - width: 320 - height: 180 - banner: {fileID: 0} - androidGamepadSupportLevel: 0 - chromeosInputEmulation: 1 - AndroidMinifyWithR8: 0 - AndroidMinifyRelease: 0 - AndroidMinifyDebug: 0 - AndroidValidateAppBundleSize: 1 - AndroidAppBundleSizeToValidate: 150 - m_BuildTargetIcons: [] - m_BuildTargetPlatformIcons: - - m_BuildTarget: Android - m_Icons: - - m_Textures: [] - m_Width: 432 - m_Height: 432 - m_Kind: 2 - m_SubKind: - - m_Textures: [] - m_Width: 324 - m_Height: 324 - m_Kind: 2 - m_SubKind: - - m_Textures: [] - m_Width: 216 - m_Height: 216 - m_Kind: 2 - m_SubKind: - - m_Textures: [] - m_Width: 162 - m_Height: 162 - m_Kind: 2 - m_SubKind: - - m_Textures: [] - m_Width: 108 - m_Height: 108 - m_Kind: 2 - m_SubKind: - - m_Textures: [] - m_Width: 81 - m_Height: 81 - m_Kind: 2 - m_SubKind: - - m_Textures: [] - m_Width: 192 - m_Height: 192 - m_Kind: 1 - m_SubKind: - - m_Textures: [] - m_Width: 144 - m_Height: 144 - m_Kind: 1 - m_SubKind: - - m_Textures: [] - m_Width: 96 - m_Height: 96 - m_Kind: 1 - m_SubKind: - - m_Textures: [] - m_Width: 72 - m_Height: 72 - m_Kind: 1 - m_SubKind: - - m_Textures: [] - m_Width: 48 - m_Height: 48 - m_Kind: 1 - m_SubKind: - - m_Textures: [] - m_Width: 36 - m_Height: 36 - m_Kind: 1 - m_SubKind: - - m_Textures: [] - m_Width: 192 - m_Height: 192 - m_Kind: 0 - m_SubKind: - - m_Textures: [] - m_Width: 144 - m_Height: 144 - m_Kind: 0 - m_SubKind: - - m_Textures: [] - m_Width: 96 - m_Height: 96 - m_Kind: 0 - m_SubKind: - - m_Textures: [] - m_Width: 72 - m_Height: 72 - m_Kind: 0 - m_SubKind: - - m_Textures: [] - m_Width: 48 - m_Height: 48 - m_Kind: 0 - m_SubKind: - - m_Textures: [] - m_Width: 36 - m_Height: 36 - m_Kind: 0 - m_SubKind: - m_BuildTargetBatching: [] - m_BuildTargetShaderSettings: [] - m_BuildTargetGraphicsJobs: - - m_BuildTarget: WindowsStandaloneSupport - m_GraphicsJobs: 0 - - m_BuildTarget: MacStandaloneSupport - m_GraphicsJobs: 0 - - m_BuildTarget: LinuxStandaloneSupport - m_GraphicsJobs: 0 - - m_BuildTarget: AndroidPlayer - m_GraphicsJobs: 0 - - m_BuildTarget: iOSSupport - m_GraphicsJobs: 0 - - m_BuildTarget: PS4Player - m_GraphicsJobs: 0 - - m_BuildTarget: PS5Player - m_GraphicsJobs: 0 - - m_BuildTarget: XboxOnePlayer - m_GraphicsJobs: 0 - - m_BuildTarget: GameCoreXboxOneSupport - m_GraphicsJobs: 0 - - m_BuildTarget: GameCoreScarlettSupport - m_GraphicsJobs: 0 - - m_BuildTarget: Switch - m_GraphicsJobs: 0 - - m_BuildTarget: WebGLSupport - m_GraphicsJobs: 0 - - m_BuildTarget: MetroSupport - m_GraphicsJobs: 0 - - m_BuildTarget: AppleTVSupport - m_GraphicsJobs: 0 - - m_BuildTarget: BJMSupport - m_GraphicsJobs: 0 - - m_BuildTarget: LuminSupport - m_GraphicsJobs: 0 - - m_BuildTarget: CloudRendering - m_GraphicsJobs: 0 - - m_BuildTarget: EmbeddedLinux - m_GraphicsJobs: 0 - m_BuildTargetGraphicsJobMode: - - m_BuildTarget: PS4Player - m_GraphicsJobMode: 0 - - m_BuildTarget: XboxOnePlayer - m_GraphicsJobMode: 0 - m_BuildTargetGraphicsAPIs: - - m_BuildTarget: iOSSupport - m_APIs: 10000000 - m_Automatic: 1 - - m_BuildTarget: AndroidPlayer - m_APIs: 0b00000008000000 - m_Automatic: 0 - m_BuildTargetVRSettings: [] - m_DefaultShaderChunkSizeInMB: 16 - m_DefaultShaderChunkCount: 0 - openGLRequireES31: 0 - openGLRequireES31AEP: 0 - openGLRequireES32: 0 - m_TemplateCustomTags: {} - mobileMTRendering: - iPhone: 1 - tvOS: 1 - m_BuildTargetGroupLightmapEncodingQuality: - - m_BuildTarget: Standalone - m_EncodingQuality: 1 - - m_BuildTarget: XboxOne - m_EncodingQuality: 1 - - m_BuildTarget: PS4 - m_EncodingQuality: 1 - - m_BuildTarget: GameCoreScarlett - m_EncodingQuality: 1 - - m_BuildTarget: GameCoreXboxOne - m_EncodingQuality: 1 - m_BuildTargetGroupLightmapSettings: [] - m_BuildTargetNormalMapEncoding: [] - m_BuildTargetDefaultTextureCompressionFormat: [] - playModeTestRunnerEnabled: 0 - runPlayModeTestAsEditModeTest: 0 - actionOnDotNetUnhandledException: 1 - enableInternalProfiler: 0 - logObjCUncaughtExceptions: 1 - enableCrashReportAPI: 0 - cameraUsageDescription: - locationUsageDescription: - microphoneUsageDescription: - bluetoothUsageDescription: - switchNMETAOverride: - switchNetLibKey: - switchSocketMemoryPoolSize: 6144 - switchSocketAllocatorPoolSize: 128 - switchSocketConcurrencyLimit: 14 - switchScreenResolutionBehavior: 2 - switchUseCPUProfiler: 0 - switchUseGOLDLinker: 0 - switchLTOSetting: 0 - switchApplicationID: 0x0005000C10000001 - switchNSODependencies: - switchTitleNames_0: - switchTitleNames_1: - switchTitleNames_2: - switchTitleNames_3: - switchTitleNames_4: - switchTitleNames_5: - switchTitleNames_6: - switchTitleNames_7: - switchTitleNames_8: - switchTitleNames_9: - switchTitleNames_10: - switchTitleNames_11: - switchTitleNames_12: - switchTitleNames_13: - switchTitleNames_14: - switchTitleNames_15: - switchPublisherNames_0: - switchPublisherNames_1: - switchPublisherNames_2: - switchPublisherNames_3: - switchPublisherNames_4: - switchPublisherNames_5: - switchPublisherNames_6: - switchPublisherNames_7: - switchPublisherNames_8: - switchPublisherNames_9: - switchPublisherNames_10: - switchPublisherNames_11: - switchPublisherNames_12: - switchPublisherNames_13: - switchPublisherNames_14: - switchPublisherNames_15: - switchIcons_0: {fileID: 0} - switchIcons_1: {fileID: 0} - switchIcons_2: {fileID: 0} - switchIcons_3: {fileID: 0} - switchIcons_4: {fileID: 0} - switchIcons_5: {fileID: 0} - switchIcons_6: {fileID: 0} - switchIcons_7: {fileID: 0} - switchIcons_8: {fileID: 0} - switchIcons_9: {fileID: 0} - switchIcons_10: {fileID: 0} - switchIcons_11: {fileID: 0} - switchIcons_12: {fileID: 0} - switchIcons_13: {fileID: 0} - switchIcons_14: {fileID: 0} - switchIcons_15: {fileID: 0} - switchSmallIcons_0: {fileID: 0} - switchSmallIcons_1: {fileID: 0} - switchSmallIcons_2: {fileID: 0} - switchSmallIcons_3: {fileID: 0} - switchSmallIcons_4: {fileID: 0} - switchSmallIcons_5: {fileID: 0} - switchSmallIcons_6: {fileID: 0} - switchSmallIcons_7: {fileID: 0} - switchSmallIcons_8: {fileID: 0} - switchSmallIcons_9: {fileID: 0} - switchSmallIcons_10: {fileID: 0} - switchSmallIcons_11: {fileID: 0} - switchSmallIcons_12: {fileID: 0} - switchSmallIcons_13: {fileID: 0} - switchSmallIcons_14: {fileID: 0} - switchSmallIcons_15: {fileID: 0} - switchManualHTML: - switchAccessibleURLs: - switchLegalInformation: - switchMainThreadStackSize: 1048576 - switchPresenceGroupId: 0x0005000C10000001 - switchLogoHandling: 0 - switchReleaseVersion: 0 - switchDisplayVersion: 1.0.0 - switchStartupUserAccount: 0 - switchSupportedLanguagesMask: 0 - switchLogoType: 0 - switchApplicationErrorCodeCategory: - switchUserAccountSaveDataSize: 0 - switchUserAccountSaveDataJournalSize: 0 - switchApplicationAttribute: 0 - switchCardSpecSize: 4 - switchCardSpecClock: 25 - switchRatingsMask: 0 - switchRatingsInt_0: 0 - switchRatingsInt_1: 0 - switchRatingsInt_2: 0 - switchRatingsInt_3: 0 - switchRatingsInt_4: 0 - switchRatingsInt_5: 0 - switchRatingsInt_6: 0 - switchRatingsInt_7: 0 - switchRatingsInt_8: 0 - switchRatingsInt_9: 0 - switchRatingsInt_10: 0 - switchRatingsInt_11: 0 - switchRatingsInt_12: 0 - switchLocalCommunicationIds_0: 0x0005000C10000001 - switchLocalCommunicationIds_1: - switchLocalCommunicationIds_2: - switchLocalCommunicationIds_3: - switchLocalCommunicationIds_4: - switchLocalCommunicationIds_5: - switchLocalCommunicationIds_6: - switchLocalCommunicationIds_7: - switchParentalControl: 0 - switchAllowsScreenshot: 1 - switchAllowsVideoCapturing: 1 - switchAllowsRuntimeAddOnContentInstall: 0 - switchDataLossConfirmation: 0 - switchUserAccountLockEnabled: 0 - switchSystemResourceMemory: 16777216 - switchSupportedNpadStyles: 22 - switchNativeFsCacheSize: 32 - switchIsHoldTypeHorizontal: 0 - switchSupportedNpadCount: 8 - switchEnableTouchScreen: 1 - switchSocketConfigEnabled: 0 - switchTcpInitialSendBufferSize: 32 - switchTcpInitialReceiveBufferSize: 64 - switchTcpAutoSendBufferSizeMax: 256 - switchTcpAutoReceiveBufferSizeMax: 256 - switchUdpSendBufferSize: 9 - switchUdpReceiveBufferSize: 42 - switchSocketBufferEfficiency: 4 - switchSocketInitializeEnabled: 1 - switchNetworkInterfaceManagerInitializeEnabled: 1 - switchPlayerConnectionEnabled: 1 - switchUseNewStyleFilepaths: 0 - switchUseLegacyFmodPriorities: 1 - switchUseMicroSleepForYield: 1 - switchEnableRamDiskSupport: 0 - switchMicroSleepForYieldTime: 25 - switchRamDiskSpaceSize: 12 - ps4NPAgeRating: 12 - ps4NPTitleSecret: - ps4NPTrophyPackPath: - ps4ParentalLevel: 1 - ps4ContentID: ED1633-NPXX51362_00-0000000000000000 - ps4Category: 0 - ps4MasterVersion: 01.00 - ps4AppVersion: 01.00 - ps4AppType: 0 - ps4ParamSfxPath: - ps4VideoOutPixelFormat: 0 - ps4VideoOutInitialWidth: 1920 - ps4VideoOutBaseModeInitialWidth: 1920 - ps4VideoOutReprojectionRate: 120 - ps4PronunciationXMLPath: - ps4PronunciationSIGPath: - ps4BackgroundImagePath: - ps4StartupImagePath: - ps4StartupImagesFolder: - ps4IconImagesFolder: - ps4SaveDataImagePath: - ps4SdkOverride: - ps4BGMPath: - ps4ShareFilePath: - ps4ShareOverlayImagePath: - ps4PrivacyGuardImagePath: - ps4ExtraSceSysFile: - ps4NPtitleDatPath: - ps4RemotePlayKeyAssignment: -1 - ps4RemotePlayKeyMappingDir: - ps4PlayTogetherPlayerCount: 0 - ps4EnterButtonAssignment: 1 - ps4ApplicationParam1: 0 - ps4ApplicationParam2: 0 - ps4ApplicationParam3: 0 - ps4ApplicationParam4: 0 - ps4DownloadDataSize: 0 - ps4GarlicHeapSize: 2048 - ps4ProGarlicHeapSize: 2560 - playerPrefsMaxSize: 32768 - ps4Passcode: 5PN2qmWqBlQ9wQj99nsQzldVI5ZuGXbE - ps4pnSessions: 1 - ps4pnPresence: 1 - ps4pnFriends: 1 - ps4pnGameCustomData: 1 - playerPrefsSupport: 0 - enableApplicationExit: 0 - resetTempFolder: 1 - restrictedAudioUsageRights: 0 - ps4UseResolutionFallback: 0 - ps4ReprojectionSupport: 0 - ps4UseAudio3dBackend: 0 - ps4UseLowGarlicFragmentationMode: 1 - ps4SocialScreenEnabled: 0 - ps4ScriptOptimizationLevel: 3 - ps4Audio3dVirtualSpeakerCount: 14 - ps4attribCpuUsage: 0 - ps4PatchPkgPath: - ps4PatchLatestPkgPath: - ps4PatchChangeinfoPath: - ps4PatchDayOne: 0 - ps4attribUserManagement: 0 - ps4attribMoveSupport: 0 - ps4attrib3DSupport: 0 - ps4attribShareSupport: 0 - ps4attribExclusiveVR: 0 - ps4disableAutoHideSplash: 0 - ps4videoRecordingFeaturesUsed: 0 - ps4contentSearchFeaturesUsed: 0 - ps4CompatibilityPS5: 0 - ps4AllowPS5Detection: 0 - ps4GPU800MHz: 1 - ps4attribEyeToEyeDistanceSettingVR: 0 - ps4IncludedModules: [] - ps4attribVROutputEnabled: 0 - monoEnv: - splashScreenBackgroundSourceLandscape: {fileID: 0} - splashScreenBackgroundSourcePortrait: {fileID: 0} - blurSplashScreenBackground: 1 - spritePackerPolicy: - webGLMemorySize: 256 - webGLExceptionSupport: 1 - webGLNameFilesAsHashes: 0 - webGLDataCaching: 0 - webGLDebugSymbols: 0 - webGLEmscriptenArgs: - webGLModulesDirectory: - webGLTemplate: APPLICATION:Default - webGLAnalyzeBuildSize: 0 - webGLUseEmbeddedResources: 0 - webGLCompressionFormat: 1 - webGLWasmArithmeticExceptions: 0 - webGLLinkerTarget: 1 - webGLThreadsSupport: 0 - webGLDecompressionFallback: 0 - webGLPowerPreference: 2 - scriptingDefineSymbols: {} - additionalCompilerArguments: {} - platformArchitecture: {} - scriptingBackend: {} - il2cppCompilerConfiguration: {} - managedStrippingLevel: - EmbeddedLinux: 1 - GameCoreScarlett: 1 - GameCoreXboxOne: 1 - Lumin: 1 - Nintendo Switch: 1 - PS4: 1 - PS5: 1 - Stadia: 1 - WebGL: 1 - Windows Store Apps: 1 - XboxOne: 1 - iPhone: 1 - tvOS: 1 - incrementalIl2cppBuild: {} - suppressCommonWarnings: 1 - allowUnsafeCode: 0 - useDeterministicCompilation: 1 - enableRoslynAnalyzers: 1 - selectedPlatform: 0 - additionalIl2CppArgs: - scriptingRuntimeVersion: 1 - gcIncremental: 1 - assemblyVersionValidation: 1 - gcWBarrierValidation: 0 - apiCompatibilityLevelPerPlatform: {} - m_RenderingPath: 1 - m_MobileRenderingPath: 1 - metroPackageName: mapzen - metroPackageVersion: - metroCertificatePath: - metroCertificatePassword: - metroCertificateSubject: - metroCertificateIssuer: - metroCertificateNotAfter: 0000000000000000 - metroApplicationDescription: mapzen - wsaImages: {} - metroTileShortName: - metroTileShowName: 0 - metroMediumTileShowName: 0 - metroLargeTileShowName: 0 - metroWideTileShowName: 0 - metroSupportStreamingInstall: 0 - metroLastRequiredScene: 0 - metroDefaultTileSize: 1 - metroTileForegroundText: 2 - metroTileBackgroundColor: {r: 0.13333334, g: 0.17254902, b: 0.21568628, a: 0} - metroSplashScreenBackgroundColor: {r: 0.12941177, g: 0.17254902, b: 0.21568628, - a: 1} - metroSplashScreenUseBackgroundColor: 0 - platformCapabilities: {} - metroTargetDeviceFamilies: {} - metroFTAName: - metroFTAFileTypes: [] - metroProtocolName: - vcxProjDefaultLanguage: - XboxOneProductId: - XboxOneUpdateKey: - XboxOneSandboxId: - XboxOneContentId: - XboxOneTitleId: - XboxOneSCId: - XboxOneGameOsOverridePath: - XboxOnePackagingOverridePath: - XboxOneAppManifestOverridePath: - XboxOneVersion: 1.0.0.0 - XboxOnePackageEncryption: 0 - XboxOnePackageUpdateGranularity: 2 - XboxOneDescription: - XboxOneLanguage: - - enus - XboxOneCapability: [] - XboxOneGameRating: {} - XboxOneIsContentPackage: 0 - XboxOneEnhancedXboxCompatibilityMode: 0 - XboxOneEnableGPUVariability: 0 - XboxOneSockets: {} - XboxOneSplashScreen: {fileID: 0} - XboxOneAllowedProductIds: [] - XboxOnePersistentLocalStorageSize: 0 - XboxOneXTitleMemory: 8 - XboxOneOverrideIdentityName: - XboxOneOverrideIdentityPublisher: - vrEditorSettings: {} - cloudServicesEnabled: - Build: 0 - Collab: 0 - ErrorHub: 0 - Hub: 0 - UNet: 1 - luminIcon: - m_Name: - m_ModelFolderPath: - m_PortalFolderPath: - luminCert: - m_CertPath: - m_SignPackage: 1 - luminIsChannelApp: 0 - luminVersion: - m_VersionCode: 1 - m_VersionName: - apiCompatibilityLevel: 6 - activeInputHandler: 0 - windowsGamepadBackendHint: 0 - cloudProjectId: ffc4f172-52c7-47d7-b4e6-0179e0a5c24d - framebufferDepthMemorylessMode: 0 - qualitySettingsNames: [] - projectName: mapzen - organizationId: karim-naaji-gmail-com - cloudEnabled: 0 - legacyClampBlendShapeWeights: 1 - playerDataPath: - forceSRGBBlit: 1 - virtualTexturingSupportEnabled: 0 diff --git a/ProjectSettings/ProjectVersion.txt b/ProjectSettings/ProjectVersion.txt deleted file mode 100644 index f8251a7a..00000000 --- a/ProjectSettings/ProjectVersion.txt +++ /dev/null @@ -1,2 +0,0 @@ -m_EditorVersion: 2021.3.22f1 -m_EditorVersionWithRevision: 2021.3.22f1 (b6c551784ba3) diff --git a/ProjectSettings/QualitySettings.asset b/ProjectSettings/QualitySettings.asset deleted file mode 100644 index 86132303..00000000 --- a/ProjectSettings/QualitySettings.asset +++ /dev/null @@ -1,165 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!47 &1 -QualitySettings: - m_ObjectHideFlags: 0 - serializedVersion: 5 - m_CurrentQuality: 5 - m_QualitySettings: - - serializedVersion: 2 - name: Fastest - pixelLightCount: 0 - shadows: 0 - shadowResolution: 0 - shadowProjection: 1 - shadowCascades: 1 - shadowDistance: 15 - shadowNearPlaneOffset: 3 - shadowCascade2Split: 0.33333334 - shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} - blendWeights: 1 - textureQuality: 1 - anisotropicTextures: 0 - antiAliasing: 0 - softParticles: 0 - softVegetation: 0 - realtimeReflectionProbes: 0 - billboardsFaceCameraPosition: 0 - vSyncCount: 0 - lodBias: 0.3 - maximumLODLevel: 0 - particleRaycastBudget: 4 - asyncUploadTimeSlice: 2 - asyncUploadBufferSize: 4 - excludedTargetPlatforms: [] - - serializedVersion: 2 - name: Fast - pixelLightCount: 0 - shadows: 0 - shadowResolution: 0 - shadowProjection: 1 - shadowCascades: 1 - shadowDistance: 20 - shadowNearPlaneOffset: 3 - shadowCascade2Split: 0.33333334 - shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} - blendWeights: 2 - textureQuality: 0 - anisotropicTextures: 0 - antiAliasing: 0 - softParticles: 0 - softVegetation: 0 - realtimeReflectionProbes: 0 - billboardsFaceCameraPosition: 0 - vSyncCount: 0 - lodBias: 0.4 - maximumLODLevel: 0 - particleRaycastBudget: 16 - asyncUploadTimeSlice: 2 - asyncUploadBufferSize: 4 - excludedTargetPlatforms: [] - - serializedVersion: 2 - name: Simple - pixelLightCount: 1 - shadows: 1 - shadowResolution: 0 - shadowProjection: 1 - shadowCascades: 1 - shadowDistance: 20 - shadowNearPlaneOffset: 3 - shadowCascade2Split: 0.33333334 - shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} - blendWeights: 2 - textureQuality: 0 - anisotropicTextures: 1 - antiAliasing: 0 - softParticles: 0 - softVegetation: 0 - realtimeReflectionProbes: 0 - billboardsFaceCameraPosition: 0 - vSyncCount: 1 - lodBias: 0.7 - maximumLODLevel: 0 - particleRaycastBudget: 64 - asyncUploadTimeSlice: 2 - asyncUploadBufferSize: 4 - excludedTargetPlatforms: [] - - serializedVersion: 2 - name: Good - pixelLightCount: 2 - shadows: 2 - shadowResolution: 1 - shadowProjection: 1 - shadowCascades: 2 - shadowDistance: 40 - shadowNearPlaneOffset: 3 - shadowCascade2Split: 0.33333334 - shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} - blendWeights: 2 - textureQuality: 0 - anisotropicTextures: 1 - antiAliasing: 0 - softParticles: 0 - softVegetation: 1 - realtimeReflectionProbes: 1 - billboardsFaceCameraPosition: 1 - vSyncCount: 1 - lodBias: 1 - maximumLODLevel: 0 - particleRaycastBudget: 256 - asyncUploadTimeSlice: 2 - asyncUploadBufferSize: 4 - excludedTargetPlatforms: [] - - serializedVersion: 2 - name: Beautiful - pixelLightCount: 3 - shadows: 2 - shadowResolution: 2 - shadowProjection: 1 - shadowCascades: 2 - shadowDistance: 70 - shadowNearPlaneOffset: 3 - shadowCascade2Split: 0.33333334 - shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} - blendWeights: 4 - textureQuality: 0 - anisotropicTextures: 2 - antiAliasing: 2 - softParticles: 1 - softVegetation: 1 - realtimeReflectionProbes: 1 - billboardsFaceCameraPosition: 1 - vSyncCount: 1 - lodBias: 1.5 - maximumLODLevel: 0 - particleRaycastBudget: 1024 - asyncUploadTimeSlice: 2 - asyncUploadBufferSize: 4 - excludedTargetPlatforms: [] - - serializedVersion: 2 - name: Fantastic - pixelLightCount: 4 - shadows: 2 - shadowResolution: 2 - shadowProjection: 1 - shadowCascades: 4 - shadowDistance: 150 - shadowNearPlaneOffset: 3 - shadowCascade2Split: 0.33333334 - shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} - blendWeights: 4 - textureQuality: 0 - anisotropicTextures: 2 - antiAliasing: 2 - softParticles: 1 - softVegetation: 1 - realtimeReflectionProbes: 1 - billboardsFaceCameraPosition: 1 - vSyncCount: 1 - lodBias: 2 - maximumLODLevel: 0 - particleRaycastBudget: 4096 - asyncUploadTimeSlice: 2 - asyncUploadBufferSize: 4 - excludedTargetPlatforms: [] - m_PerPlatformDefaultQuality: {} diff --git a/ProjectSettings/TagManager.asset b/ProjectSettings/TagManager.asset deleted file mode 100644 index 1c92a784..00000000 --- a/ProjectSettings/TagManager.asset +++ /dev/null @@ -1,43 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!78 &1 -TagManager: - serializedVersion: 2 - tags: [] - layers: - - Default - - TransparentFX - - Ignore Raycast - - - - Water - - UI - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - m_SortingLayers: - - name: Default - uniqueID: 0 - locked: 0 diff --git a/ProjectSettings/TimeManager.asset b/ProjectSettings/TimeManager.asset deleted file mode 100644 index 558a017e..00000000 --- a/ProjectSettings/TimeManager.asset +++ /dev/null @@ -1,9 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!5 &1 -TimeManager: - m_ObjectHideFlags: 0 - Fixed Timestep: 0.02 - Maximum Allowed Timestep: 0.33333334 - m_TimeScale: 1 - Maximum Particle Timestep: 0.03 diff --git a/ProjectSettings/UnityConnectSettings.asset b/ProjectSettings/UnityConnectSettings.asset deleted file mode 100644 index e6c9fd7a..00000000 --- a/ProjectSettings/UnityConnectSettings.asset +++ /dev/null @@ -1,32 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!310 &1 -UnityConnectSettings: - m_ObjectHideFlags: 0 - m_Enabled: 0 - m_TestMode: 0 - m_TestEventUrl: - m_TestConfigUrl: - m_TestInitMode: 0 - CrashReportingSettings: - m_EventUrl: https://perf-events.cloud.unity3d.com/api/events/crashes - m_Enabled: 0 - m_CaptureEditorExceptions: 1 - UnityPurchasingSettings: - m_Enabled: 0 - m_TestMode: 0 - UnityAnalyticsSettings: - m_Enabled: 1 - m_InitializeOnStartup: 1 - m_TestMode: 0 - m_TestEventUrl: - m_TestConfigUrl: - UnityAdsSettings: - m_Enabled: 0 - m_InitializeOnStartup: 1 - m_TestMode: 0 - m_EnabledPlatforms: 4294967295 - m_IosGameId: - m_AndroidGameId: - PerformanceReportingSettings: - m_Enabled: 0 diff --git a/ProjectSettings/VFXManager.asset b/ProjectSettings/VFXManager.asset deleted file mode 100644 index 3a95c98b..00000000 --- a/ProjectSettings/VFXManager.asset +++ /dev/null @@ -1,12 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!937362698 &1 -VFXManager: - m_ObjectHideFlags: 0 - m_IndirectShader: {fileID: 0} - m_CopyBufferShader: {fileID: 0} - m_SortShader: {fileID: 0} - m_StripUpdateShader: {fileID: 0} - m_RenderPipeSettingsPath: - m_FixedTimeStep: 0.016666668 - m_MaxDeltaTime: 0.05 diff --git a/ProjectSettings/VersionControlSettings.asset b/ProjectSettings/VersionControlSettings.asset deleted file mode 100644 index dca28814..00000000 --- a/ProjectSettings/VersionControlSettings.asset +++ /dev/null @@ -1,8 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!890905787 &1 -VersionControlSettings: - m_ObjectHideFlags: 0 - m_Mode: Visible Meta Files - m_CollabEditorSettings: - inProgressEnabled: 1 diff --git a/ProjectSettings/XRSettings.asset b/ProjectSettings/XRSettings.asset deleted file mode 100644 index 482590c1..00000000 --- a/ProjectSettings/XRSettings.asset +++ /dev/null @@ -1,10 +0,0 @@ -{ - "m_SettingKeys": [ - "VR Device Disabled", - "VR Device User Alert" - ], - "m_SettingValues": [ - "False", - "False" - ] -} \ No newline at end of file diff --git a/ProjectSettings/boot.config b/ProjectSettings/boot.config deleted file mode 100644 index e69de29b..00000000 diff --git a/README.md.meta b/README.md.meta new file mode 100644 index 00000000..8ec40498 --- /dev/null +++ b/README.md.meta @@ -0,0 +1,7 @@ +fileFormatVersion: 2 +guid: f7f473adde5c00547bead58e083b26b9 +TextScriptImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Runtime.meta b/Runtime.meta new file mode 100644 index 00000000..5a0cae57 --- /dev/null +++ b/Runtime.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: cc74a1df977a502438cac375b3a77c5a +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/Dependencies.meta b/Runtime/Dependencies.meta similarity index 79% rename from Assets/Dependencies.meta rename to Runtime/Dependencies.meta index 2c0b5e09..66a0feaa 100644 --- a/Assets/Dependencies.meta +++ b/Runtime/Dependencies.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 2ea18a9966b474f3a9a057ae78e8b9d0 +guid: 37119badbb0313741bc0c7adf77de540 folderAsset: yes timeCreated: 1509659270 licenseType: Free diff --git a/Assets/Dependencies/Mapbox.meta b/Runtime/Dependencies/Mapbox.meta similarity index 79% rename from Assets/Dependencies/Mapbox.meta rename to Runtime/Dependencies/Mapbox.meta index 00bf7183..ad735645 100644 --- a/Assets/Dependencies/Mapbox.meta +++ b/Runtime/Dependencies/Mapbox.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 294f938dffad34b689513de743ea3801 +guid: 6665a2514cc428948b192bd91b7d1bac folderAsset: yes timeCreated: 1509659270 licenseType: Free diff --git a/Assets/Dependencies/Mapbox/Earcut.cs b/Runtime/Dependencies/Mapbox/Earcut.cs similarity index 100% rename from Assets/Dependencies/Mapbox/Earcut.cs rename to Runtime/Dependencies/Mapbox/Earcut.cs diff --git a/Assets/Dependencies/Mapbox/Earcut.cs.meta b/Runtime/Dependencies/Mapbox/Earcut.cs.meta similarity index 85% rename from Assets/Dependencies/Mapbox/Earcut.cs.meta rename to Runtime/Dependencies/Mapbox/Earcut.cs.meta index 57d3250a..16147a7c 100644 --- a/Assets/Dependencies/Mapbox/Earcut.cs.meta +++ b/Runtime/Dependencies/Mapbox/Earcut.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: f911b5e0c11794f92961f24fe5400cba +guid: 059b16d7af1539c4b9dc1982046795aa timeCreated: 1509659270 licenseType: Free MonoImporter: diff --git a/Assets/Dependencies/SimpleJSON.meta b/Runtime/Dependencies/SimpleJSON.meta similarity index 79% rename from Assets/Dependencies/SimpleJSON.meta rename to Runtime/Dependencies/SimpleJSON.meta index 3d593535..8f2deead 100644 --- a/Assets/Dependencies/SimpleJSON.meta +++ b/Runtime/Dependencies/SimpleJSON.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: cad0ae470f2fa497592cf6123dfcaa70 +guid: 540c7725a92ff2a47a4abb81d578b381 folderAsset: yes timeCreated: 1509664159 licenseType: Free diff --git a/Assets/Dependencies/SimpleJSON/SimpleJSON.cs b/Runtime/Dependencies/SimpleJSON/SimpleJSON.cs similarity index 100% rename from Assets/Dependencies/SimpleJSON/SimpleJSON.cs rename to Runtime/Dependencies/SimpleJSON/SimpleJSON.cs diff --git a/Assets/Dependencies/SimpleJSON/SimpleJSON.cs.meta b/Runtime/Dependencies/SimpleJSON/SimpleJSON.cs.meta similarity index 85% rename from Assets/Dependencies/SimpleJSON/SimpleJSON.cs.meta rename to Runtime/Dependencies/SimpleJSON/SimpleJSON.cs.meta index a2fe0b59..0d932707 100644 --- a/Assets/Dependencies/SimpleJSON/SimpleJSON.cs.meta +++ b/Runtime/Dependencies/SimpleJSON/SimpleJSON.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 3327ec0365ed141d4ba6edf5d3c197d8 +guid: 1f2a0c2e50bb3134d8c143c6741aa81b timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen.meta b/Runtime/Mapzen.meta similarity index 79% rename from Assets/Mapzen.meta rename to Runtime/Mapzen.meta index ad9953db..7501c403 100644 --- a/Assets/Mapzen.meta +++ b/Runtime/Mapzen.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 997d5f223ca71414bbc5a93c75e5fd69 +guid: f885b21b97994f44b9e370848a798b47 folderAsset: yes timeCreated: 1490324407 licenseType: Free diff --git a/Assets/Mapzen/Geo.cs b/Runtime/Mapzen/Geo.cs similarity index 100% rename from Assets/Mapzen/Geo.cs rename to Runtime/Mapzen/Geo.cs diff --git a/Assets/Mapzen/Geo.cs.meta b/Runtime/Mapzen/Geo.cs.meta similarity index 85% rename from Assets/Mapzen/Geo.cs.meta rename to Runtime/Mapzen/Geo.cs.meta index 0c00b405..202db69e 100644 --- a/Assets/Mapzen/Geo.cs.meta +++ b/Runtime/Mapzen/Geo.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 478ca6b2a5aa5439ebf3db354d49eb8c +guid: a3e04a7f8c7a67541aaa73d854f5740c timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/LngLat.cs b/Runtime/Mapzen/LngLat.cs similarity index 100% rename from Assets/Mapzen/LngLat.cs rename to Runtime/Mapzen/LngLat.cs diff --git a/Assets/Mapzen/LngLat.cs.meta b/Runtime/Mapzen/LngLat.cs.meta similarity index 85% rename from Assets/Mapzen/LngLat.cs.meta rename to Runtime/Mapzen/LngLat.cs.meta index 6178513a..b1e8ffd6 100644 --- a/Assets/Mapzen/LngLat.cs.meta +++ b/Runtime/Mapzen/LngLat.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 49eea154d173d4b7ea9429978a9a34ae +guid: 097e33861a25a1048a30d85000e25ea2 timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/MercatorMeters.cs b/Runtime/Mapzen/MercatorMeters.cs similarity index 100% rename from Assets/Mapzen/MercatorMeters.cs rename to Runtime/Mapzen/MercatorMeters.cs diff --git a/Assets/Mapzen/MercatorMeters.cs.meta b/Runtime/Mapzen/MercatorMeters.cs.meta similarity index 85% rename from Assets/Mapzen/MercatorMeters.cs.meta rename to Runtime/Mapzen/MercatorMeters.cs.meta index 2b8d228a..ad7260a5 100644 --- a/Assets/Mapzen/MercatorMeters.cs.meta +++ b/Runtime/Mapzen/MercatorMeters.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 953d89e5d8e1e4067b22e8261d3ea279 +guid: dfc463e8ba7fce64fae3d1ed4f266000 timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/SceneGroupType.cs b/Runtime/Mapzen/SceneGroupType.cs similarity index 100% rename from Assets/Mapzen/SceneGroupType.cs rename to Runtime/Mapzen/SceneGroupType.cs diff --git a/Assets/Mapzen/SceneGroupType.cs.meta b/Runtime/Mapzen/SceneGroupType.cs.meta similarity index 85% rename from Assets/Mapzen/SceneGroupType.cs.meta rename to Runtime/Mapzen/SceneGroupType.cs.meta index af072b2c..4423d2d2 100644 --- a/Assets/Mapzen/SceneGroupType.cs.meta +++ b/Runtime/Mapzen/SceneGroupType.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 95714141fbe84441ab760ad08b5194ff +guid: 23455847b2d3f71429e83dd18aab8e9d timeCreated: 1510952398 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/TileAddress.cs b/Runtime/Mapzen/TileAddress.cs similarity index 100% rename from Assets/Mapzen/TileAddress.cs rename to Runtime/Mapzen/TileAddress.cs diff --git a/Assets/Mapzen/TileAddress.cs.meta b/Runtime/Mapzen/TileAddress.cs.meta similarity index 85% rename from Assets/Mapzen/TileAddress.cs.meta rename to Runtime/Mapzen/TileAddress.cs.meta index dde4331b..1c6e16a0 100644 --- a/Assets/Mapzen/TileAddress.cs.meta +++ b/Runtime/Mapzen/TileAddress.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 5a116049764ab43748e9b6727eee91e2 +guid: d733361dc54f6744b8e4d08bbc88f62a timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/TileBounds.cs b/Runtime/Mapzen/TileBounds.cs similarity index 100% rename from Assets/Mapzen/TileBounds.cs rename to Runtime/Mapzen/TileBounds.cs diff --git a/Assets/Mapzen/TileBounds.cs.meta b/Runtime/Mapzen/TileBounds.cs.meta similarity index 85% rename from Assets/Mapzen/TileBounds.cs.meta rename to Runtime/Mapzen/TileBounds.cs.meta index 0687c796..9e552155 100644 --- a/Assets/Mapzen/TileBounds.cs.meta +++ b/Runtime/Mapzen/TileBounds.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 09e0371421afc429db4439b5e186c79a +guid: 39238860eaa0f96458095c92a82bc20c timeCreated: 1498683135 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity.meta b/Runtime/Mapzen/Unity.meta similarity index 79% rename from Assets/Mapzen/Unity.meta rename to Runtime/Mapzen/Unity.meta index 36da9342..bb2265fd 100644 --- a/Assets/Mapzen/Unity.meta +++ b/Runtime/Mapzen/Unity.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 0f7e005d222b74109bc7e27644b85d32 +guid: e90b116f00dcab448a33ec9855dfd7ed folderAsset: yes timeCreated: 1504292054 licenseType: Free diff --git a/Assets/Mapzen/Unity/AsyncWorker.cs b/Runtime/Mapzen/Unity/AsyncWorker.cs similarity index 100% rename from Assets/Mapzen/Unity/AsyncWorker.cs rename to Runtime/Mapzen/Unity/AsyncWorker.cs diff --git a/Assets/Mapzen/Unity/AsyncWorker.cs.meta b/Runtime/Mapzen/Unity/AsyncWorker.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/AsyncWorker.cs.meta rename to Runtime/Mapzen/Unity/AsyncWorker.cs.meta index f3280649..471abb61 100644 --- a/Assets/Mapzen/Unity/AsyncWorker.cs.meta +++ b/Runtime/Mapzen/Unity/AsyncWorker.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 7947694d47dcf494e876d6b30e227eb0 +guid: 5ac9c6333ef239b409d568048208e449 timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/Editor.meta b/Runtime/Mapzen/Unity/Editor.meta similarity index 79% rename from Assets/Mapzen/Unity/Editor.meta rename to Runtime/Mapzen/Unity/Editor.meta index 8a14f96f..825d7eb4 100644 --- a/Assets/Mapzen/Unity/Editor.meta +++ b/Runtime/Mapzen/Unity/Editor.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 1b9a4d06661cc4c82b396e5631506eb1 +guid: 06d2733a42e5f6c45a7f422c581b4aa3 folderAsset: yes timeCreated: 1510775324 licenseType: Free diff --git a/Assets/Mapzen/Unity/Editor/EditorConfig.cs b/Runtime/Mapzen/Unity/Editor/EditorConfig.cs similarity index 100% rename from Assets/Mapzen/Unity/Editor/EditorConfig.cs rename to Runtime/Mapzen/Unity/Editor/EditorConfig.cs diff --git a/Assets/Mapzen/Unity/Editor/EditorConfig.cs.meta b/Runtime/Mapzen/Unity/Editor/EditorConfig.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/Editor/EditorConfig.cs.meta rename to Runtime/Mapzen/Unity/Editor/EditorConfig.cs.meta index be07c3f5..e813aa02 100644 --- a/Assets/Mapzen/Unity/Editor/EditorConfig.cs.meta +++ b/Runtime/Mapzen/Unity/Editor/EditorConfig.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: abfeb1610103f46fea50a8692fdc913b +guid: 00618d0ab35dcbd4bb712723be67f1b8 timeCreated: 1504127335 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/Editor/FeatureLayerTreeView.cs b/Runtime/Mapzen/Unity/Editor/FeatureLayerTreeView.cs similarity index 100% rename from Assets/Mapzen/Unity/Editor/FeatureLayerTreeView.cs rename to Runtime/Mapzen/Unity/Editor/FeatureLayerTreeView.cs diff --git a/Assets/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta b/Runtime/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta rename to Runtime/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta index def318e2..e2e75fe5 100644 --- a/Assets/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta +++ b/Runtime/Mapzen/Unity/Editor/FeatureLayerTreeView.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 7eb87b0f05c5f490795fb6f12004b1d9 +guid: 855f8f02025a9eb4083c6cee29739f4b timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/Editor/LayerMatcherDrawer.cs b/Runtime/Mapzen/Unity/Editor/LayerMatcherDrawer.cs similarity index 100% rename from Assets/Mapzen/Unity/Editor/LayerMatcherDrawer.cs rename to Runtime/Mapzen/Unity/Editor/LayerMatcherDrawer.cs diff --git a/Assets/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta b/Runtime/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta rename to Runtime/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta index 6f144644..1d7969c9 100644 --- a/Assets/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta +++ b/Runtime/Mapzen/Unity/Editor/LayerMatcherDrawer.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: a4d38da4bca9d49c9836163934fd0df9 +guid: 23f845cf021bfad478cd2e41266d6d23 timeCreated: 1510281580 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/Editor/MapStyleEditor.cs b/Runtime/Mapzen/Unity/Editor/MapStyleEditor.cs similarity index 100% rename from Assets/Mapzen/Unity/Editor/MapStyleEditor.cs rename to Runtime/Mapzen/Unity/Editor/MapStyleEditor.cs diff --git a/Assets/Mapzen/Unity/Editor/MapStyleEditor.cs.meta b/Runtime/Mapzen/Unity/Editor/MapStyleEditor.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/Editor/MapStyleEditor.cs.meta rename to Runtime/Mapzen/Unity/Editor/MapStyleEditor.cs.meta index 604b4fc9..292ac493 100644 --- a/Assets/Mapzen/Unity/Editor/MapStyleEditor.cs.meta +++ b/Runtime/Mapzen/Unity/Editor/MapStyleEditor.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 3d69dbdb2fae34889b02197a0a1517f8 +guid: 1d018be29ac1eba49bf71acd0077cbfe timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs b/Runtime/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs similarity index 100% rename from Assets/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs rename to Runtime/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs diff --git a/Assets/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta b/Runtime/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta rename to Runtime/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta index 776f3c5f..293146ed 100644 --- a/Assets/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta +++ b/Runtime/Mapzen/Unity/Editor/PolygonPolylineOptionsDrawer.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 66c4dd2ac9620420abb948558d0c5cdd +guid: 136750d923d7a0449a2589ea14b64872 timeCreated: 1510278010 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/Editor/RegionMapEditor.cs b/Runtime/Mapzen/Unity/Editor/RegionMapEditor.cs similarity index 100% rename from Assets/Mapzen/Unity/Editor/RegionMapEditor.cs rename to Runtime/Mapzen/Unity/Editor/RegionMapEditor.cs diff --git a/Assets/Mapzen/Unity/Editor/RegionMapEditor.cs.meta b/Runtime/Mapzen/Unity/Editor/RegionMapEditor.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/Editor/RegionMapEditor.cs.meta rename to Runtime/Mapzen/Unity/Editor/RegionMapEditor.cs.meta index 7e83e2c9..f89785c8 100644 --- a/Assets/Mapzen/Unity/Editor/RegionMapEditor.cs.meta +++ b/Runtime/Mapzen/Unity/Editor/RegionMapEditor.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 928281946bbb749c4895d359cca52332 +guid: 5b7f91981aba06048b5da573141d0703 timeCreated: 1510952701 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/ExtrusionType.cs b/Runtime/Mapzen/Unity/ExtrusionType.cs similarity index 100% rename from Assets/Mapzen/Unity/ExtrusionType.cs rename to Runtime/Mapzen/Unity/ExtrusionType.cs diff --git a/Assets/Mapzen/Unity/ExtrusionType.cs.meta b/Runtime/Mapzen/Unity/ExtrusionType.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/ExtrusionType.cs.meta rename to Runtime/Mapzen/Unity/ExtrusionType.cs.meta index 9d192b26..1d9f9784 100644 --- a/Assets/Mapzen/Unity/ExtrusionType.cs.meta +++ b/Runtime/Mapzen/Unity/ExtrusionType.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 975579684f7ef4b37b9a5888a6728549 +guid: a6c57b551162f5e47804b33ac072af62 timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/FeatureLayer.cs b/Runtime/Mapzen/Unity/FeatureLayer.cs similarity index 100% rename from Assets/Mapzen/Unity/FeatureLayer.cs rename to Runtime/Mapzen/Unity/FeatureLayer.cs diff --git a/Assets/Mapzen/Unity/FeatureLayer.cs.meta b/Runtime/Mapzen/Unity/FeatureLayer.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/FeatureLayer.cs.meta rename to Runtime/Mapzen/Unity/FeatureLayer.cs.meta index d7152836..affbf65d 100644 --- a/Assets/Mapzen/Unity/FeatureLayer.cs.meta +++ b/Runtime/Mapzen/Unity/FeatureLayer.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 70e324aae3a0d4d268de84d346147cf4 +guid: f1855068ffb72224a976509f099649d9 timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/FeatureMesh.cs b/Runtime/Mapzen/Unity/FeatureMesh.cs similarity index 100% rename from Assets/Mapzen/Unity/FeatureMesh.cs rename to Runtime/Mapzen/Unity/FeatureMesh.cs diff --git a/Assets/Mapzen/Unity/FeatureMesh.cs.meta b/Runtime/Mapzen/Unity/FeatureMesh.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/FeatureMesh.cs.meta rename to Runtime/Mapzen/Unity/FeatureMesh.cs.meta index c4233964..2bddf47b 100644 --- a/Assets/Mapzen/Unity/FeatureMesh.cs.meta +++ b/Runtime/Mapzen/Unity/FeatureMesh.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: bed85d1900f8044119a9252c8def25b8 +guid: f277598373d895e4ebae4dbdc5455c1e timeCreated: 1510613129 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/GameObjectOptions.cs b/Runtime/Mapzen/Unity/GameObjectOptions.cs similarity index 100% rename from Assets/Mapzen/Unity/GameObjectOptions.cs rename to Runtime/Mapzen/Unity/GameObjectOptions.cs diff --git a/Assets/Mapzen/Unity/GameObjectOptions.cs.meta b/Runtime/Mapzen/Unity/GameObjectOptions.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/GameObjectOptions.cs.meta rename to Runtime/Mapzen/Unity/GameObjectOptions.cs.meta index c04adc17..0a719ce9 100644 --- a/Assets/Mapzen/Unity/GameObjectOptions.cs.meta +++ b/Runtime/Mapzen/Unity/GameObjectOptions.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 5d7cee0bbce184326869839a84d891ad +guid: 07d0129b22e3f8c43a54ac458512e6b2 timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/IO.cs b/Runtime/Mapzen/Unity/IO.cs similarity index 100% rename from Assets/Mapzen/Unity/IO.cs rename to Runtime/Mapzen/Unity/IO.cs diff --git a/Assets/Mapzen/Unity/IO.cs.meta b/Runtime/Mapzen/Unity/IO.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/IO.cs.meta rename to Runtime/Mapzen/Unity/IO.cs.meta index 4e11bec7..ba22eb5f 100644 --- a/Assets/Mapzen/Unity/IO.cs.meta +++ b/Runtime/Mapzen/Unity/IO.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 9e14c57d974e840b8a79ebd30bab9b93 +guid: afeadfc12783f494e868c555ed150fc5 timeCreated: 1504292171 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/LayerMatcher.cs b/Runtime/Mapzen/Unity/LayerMatcher.cs similarity index 100% rename from Assets/Mapzen/Unity/LayerMatcher.cs rename to Runtime/Mapzen/Unity/LayerMatcher.cs diff --git a/Assets/Mapzen/Unity/LayerMatcher.cs.meta b/Runtime/Mapzen/Unity/LayerMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/LayerMatcher.cs.meta rename to Runtime/Mapzen/Unity/LayerMatcher.cs.meta index cedf5238..352ebdd0 100644 --- a/Assets/Mapzen/Unity/LayerMatcher.cs.meta +++ b/Runtime/Mapzen/Unity/LayerMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 3a7555319008e423ca7afa958d0392b2 +guid: 750adf2bce485bb418d696c8fad29b4f timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/LayerStyle.cs b/Runtime/Mapzen/Unity/LayerStyle.cs similarity index 100% rename from Assets/Mapzen/Unity/LayerStyle.cs rename to Runtime/Mapzen/Unity/LayerStyle.cs diff --git a/Assets/Mapzen/Unity/LayerStyle.cs.meta b/Runtime/Mapzen/Unity/LayerStyle.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/LayerStyle.cs.meta rename to Runtime/Mapzen/Unity/LayerStyle.cs.meta index 70d8eb2c..44942cef 100644 --- a/Assets/Mapzen/Unity/LayerStyle.cs.meta +++ b/Runtime/Mapzen/Unity/LayerStyle.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: b1880cf7906474adfaa92b643269b06e +guid: c6abd28e2f7f8cc4c94ce3e96001b2ee timeCreated: 1510184777 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/MapStyle.cs b/Runtime/Mapzen/Unity/MapStyle.cs similarity index 100% rename from Assets/Mapzen/Unity/MapStyle.cs rename to Runtime/Mapzen/Unity/MapStyle.cs diff --git a/Assets/Mapzen/Unity/MapStyle.cs.meta b/Runtime/Mapzen/Unity/MapStyle.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/MapStyle.cs.meta rename to Runtime/Mapzen/Unity/MapStyle.cs.meta index c05ca365..de120ea1 100644 --- a/Assets/Mapzen/Unity/MapStyle.cs.meta +++ b/Runtime/Mapzen/Unity/MapStyle.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: a4edcc12ded754f86bc8b9ea3b3c3ee6 +guid: d91aa7a1bdb09f24588e1473c8fc72da timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/MeshData.cs b/Runtime/Mapzen/Unity/MeshData.cs similarity index 100% rename from Assets/Mapzen/Unity/MeshData.cs rename to Runtime/Mapzen/Unity/MeshData.cs diff --git a/Assets/Mapzen/Unity/MeshData.cs.meta b/Runtime/Mapzen/Unity/MeshData.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/MeshData.cs.meta rename to Runtime/Mapzen/Unity/MeshData.cs.meta index 1681b1ad..19d5e5d4 100644 --- a/Assets/Mapzen/Unity/MeshData.cs.meta +++ b/Runtime/Mapzen/Unity/MeshData.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: bf2770cf1171b4486988f0a6cfb0763f +guid: a5ff07ed899c54d40bc3a3b265d23347 timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/PolygonBuilder.cs b/Runtime/Mapzen/Unity/PolygonBuilder.cs similarity index 100% rename from Assets/Mapzen/Unity/PolygonBuilder.cs rename to Runtime/Mapzen/Unity/PolygonBuilder.cs diff --git a/Assets/Mapzen/Unity/PolygonBuilder.cs.meta b/Runtime/Mapzen/Unity/PolygonBuilder.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/PolygonBuilder.cs.meta rename to Runtime/Mapzen/Unity/PolygonBuilder.cs.meta index d5f3175a..53f136f5 100644 --- a/Assets/Mapzen/Unity/PolygonBuilder.cs.meta +++ b/Runtime/Mapzen/Unity/PolygonBuilder.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 4e59cd67dccdb4578bca5785208849c8 +guid: c80fe3be0352b0e44927c4896108dd63 timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/PolygonOptions.cs b/Runtime/Mapzen/Unity/PolygonOptions.cs similarity index 100% rename from Assets/Mapzen/Unity/PolygonOptions.cs rename to Runtime/Mapzen/Unity/PolygonOptions.cs diff --git a/Assets/Mapzen/Unity/PolygonOptions.cs.meta b/Runtime/Mapzen/Unity/PolygonOptions.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/PolygonOptions.cs.meta rename to Runtime/Mapzen/Unity/PolygonOptions.cs.meta index c8767b47..910d5cf5 100644 --- a/Assets/Mapzen/Unity/PolygonOptions.cs.meta +++ b/Runtime/Mapzen/Unity/PolygonOptions.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 846d4f74d07d34b0a9a2a3f6a1fec1b3 +guid: 4121331f0e501764892bb78908d6dcb3 timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/PolylineBuilder.cs b/Runtime/Mapzen/Unity/PolylineBuilder.cs similarity index 100% rename from Assets/Mapzen/Unity/PolylineBuilder.cs rename to Runtime/Mapzen/Unity/PolylineBuilder.cs diff --git a/Assets/Mapzen/Unity/PolylineBuilder.cs.meta b/Runtime/Mapzen/Unity/PolylineBuilder.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/PolylineBuilder.cs.meta rename to Runtime/Mapzen/Unity/PolylineBuilder.cs.meta index f5497e68..2e23e3e2 100644 --- a/Assets/Mapzen/Unity/PolylineBuilder.cs.meta +++ b/Runtime/Mapzen/Unity/PolylineBuilder.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 3c09a2ce335e646aa8f114093e019d88 +guid: 7323784cbe13b624f950b5a164de25e9 timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/PolylineOptions.cs b/Runtime/Mapzen/Unity/PolylineOptions.cs similarity index 100% rename from Assets/Mapzen/Unity/PolylineOptions.cs rename to Runtime/Mapzen/Unity/PolylineOptions.cs diff --git a/Assets/Mapzen/Unity/PolylineOptions.cs.meta b/Runtime/Mapzen/Unity/PolylineOptions.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/PolylineOptions.cs.meta rename to Runtime/Mapzen/Unity/PolylineOptions.cs.meta index bd5f1b2a..12ba8481 100644 --- a/Assets/Mapzen/Unity/PolylineOptions.cs.meta +++ b/Runtime/Mapzen/Unity/PolylineOptions.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 148d786044f0e4727ac43e1698ab2b3a +guid: 92af8862466c012448519e7b60c96479 timeCreated: 1510192555 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/SceneGraph.cs b/Runtime/Mapzen/Unity/SceneGraph.cs similarity index 100% rename from Assets/Mapzen/Unity/SceneGraph.cs rename to Runtime/Mapzen/Unity/SceneGraph.cs diff --git a/Assets/Mapzen/Unity/SceneGraph.cs.meta b/Runtime/Mapzen/Unity/SceneGraph.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/SceneGraph.cs.meta rename to Runtime/Mapzen/Unity/SceneGraph.cs.meta index a22b8f92..ae5f55b5 100644 --- a/Assets/Mapzen/Unity/SceneGraph.cs.meta +++ b/Runtime/Mapzen/Unity/SceneGraph.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 0fe0296740b9744c29b14463256e4b82 +guid: ecbb43d6834d01547996727c336a368c timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/TileTask.cs b/Runtime/Mapzen/Unity/TileTask.cs similarity index 100% rename from Assets/Mapzen/Unity/TileTask.cs rename to Runtime/Mapzen/Unity/TileTask.cs diff --git a/Assets/Mapzen/Unity/TileTask.cs.meta b/Runtime/Mapzen/Unity/TileTask.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/TileTask.cs.meta rename to Runtime/Mapzen/Unity/TileTask.cs.meta index 1f8f9bf6..8bc76472 100644 --- a/Assets/Mapzen/Unity/TileTask.cs.meta +++ b/Runtime/Mapzen/Unity/TileTask.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 5392c1502bca34312b8aa62ef1534924 +guid: 5ccc57e2eee05be47acb011851089838 timeCreated: 1504291857 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Unity/UVMode.cs b/Runtime/Mapzen/Unity/UVMode.cs similarity index 100% rename from Assets/Mapzen/Unity/UVMode.cs rename to Runtime/Mapzen/Unity/UVMode.cs diff --git a/Assets/Mapzen/Unity/UVMode.cs.meta b/Runtime/Mapzen/Unity/UVMode.cs.meta similarity index 85% rename from Assets/Mapzen/Unity/UVMode.cs.meta rename to Runtime/Mapzen/Unity/UVMode.cs.meta index 63ad6079..abb132b0 100644 --- a/Assets/Mapzen/Unity/UVMode.cs.meta +++ b/Runtime/Mapzen/Unity/UVMode.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 4d064f44b5a654f38849ed45bef59393 +guid: afc9d2e4703489c4eb3b245e3a4e8a15 timeCreated: 1509662197 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/Util.cs b/Runtime/Mapzen/Util.cs similarity index 100% rename from Assets/Mapzen/Util.cs rename to Runtime/Mapzen/Util.cs diff --git a/Assets/Mapzen/Util.cs.meta b/Runtime/Mapzen/Util.cs.meta similarity index 85% rename from Assets/Mapzen/Util.cs.meta rename to Runtime/Mapzen/Util.cs.meta index aae84349..fb14cbbe 100644 --- a/Assets/Mapzen/Util.cs.meta +++ b/Runtime/Mapzen/Util.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: a3fae40e25035474986b4cdb0eb31ef8 +guid: 1af9f18122822504fb83a1419500d34d timeCreated: 1499447211 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData.meta b/Runtime/Mapzen/VectorData.meta similarity index 79% rename from Assets/Mapzen/VectorData.meta rename to Runtime/Mapzen/VectorData.meta index cd3f7d32..0ced3d94 100644 --- a/Assets/Mapzen/VectorData.meta +++ b/Runtime/Mapzen/VectorData.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: fce089365cdf04812aaf8c2b96471842 +guid: e3faff1ab72477540a8ad25054943e30 folderAsset: yes timeCreated: 1490324407 licenseType: Free diff --git a/Assets/Mapzen/VectorData/Feature.cs b/Runtime/Mapzen/VectorData/Feature.cs similarity index 100% rename from Assets/Mapzen/VectorData/Feature.cs rename to Runtime/Mapzen/VectorData/Feature.cs diff --git a/Assets/Mapzen/VectorData/Feature.cs.meta b/Runtime/Mapzen/VectorData/Feature.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Feature.cs.meta rename to Runtime/Mapzen/VectorData/Feature.cs.meta index bd2a0baf..8922f115 100644 --- a/Assets/Mapzen/VectorData/Feature.cs.meta +++ b/Runtime/Mapzen/VectorData/Feature.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: f2f9b017091844622a489a7005e345d8 +guid: 0fcde377dd4adba45861426f5660783d timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/FeatureCollection.cs b/Runtime/Mapzen/VectorData/FeatureCollection.cs similarity index 100% rename from Assets/Mapzen/VectorData/FeatureCollection.cs rename to Runtime/Mapzen/VectorData/FeatureCollection.cs diff --git a/Assets/Mapzen/VectorData/FeatureCollection.cs.meta b/Runtime/Mapzen/VectorData/FeatureCollection.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/FeatureCollection.cs.meta rename to Runtime/Mapzen/VectorData/FeatureCollection.cs.meta index 5d74bbee..05f63f09 100644 --- a/Assets/Mapzen/VectorData/FeatureCollection.cs.meta +++ b/Runtime/Mapzen/VectorData/FeatureCollection.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 4bf93ba32f5164a25a311796cdce3487 +guid: 8792aab20ee8c6d429b974a75c65db4f timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters.meta b/Runtime/Mapzen/VectorData/Filters.meta similarity index 79% rename from Assets/Mapzen/VectorData/Filters.meta rename to Runtime/Mapzen/VectorData/Filters.meta index 0858b73f..8d4e484d 100644 --- a/Assets/Mapzen/VectorData/Filters.meta +++ b/Runtime/Mapzen/VectorData/Filters.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 9d2635cb6f1e5f14fbb49f77b1ade43b +guid: f8bb4f1d83d56814eaea1f5e62d889f7 folderAsset: yes timeCreated: 1495654846 licenseType: Free diff --git a/Assets/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta index b072e4d7..1c09d2ef 100644 --- a/Assets/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/CompoundFeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: f9c16e956a8b4438fa5cef0a1f0ccba1 +guid: fa255298b6a213146aef0ff07360d472 timeCreated: 1495773131 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/FeatureFilter.cs b/Runtime/Mapzen/VectorData/Filters/FeatureFilter.cs similarity index 96% rename from Assets/Mapzen/VectorData/Filters/FeatureFilter.cs rename to Runtime/Mapzen/VectorData/Filters/FeatureFilter.cs index 5a2b0182..ce736c9d 100644 --- a/Assets/Mapzen/VectorData/Filters/FeatureFilter.cs +++ b/Runtime/Mapzen/VectorData/Filters/FeatureFilter.cs @@ -1,41 +1,41 @@ -using System; -using System.Collections.Generic; -using System.Linq; - -namespace Mapzen.VectorData.Filters -{ - [Serializable] - public class FeatureFilter : IFeatureFilter - { - public IFeatureMatcher Matcher; - - public List CollectionNameSet; - - public FeatureFilter() - { - Matcher = new FeatureMatcher(); - CollectionNameSet = new List(); - } - - public virtual IEnumerable Filter(FeatureCollection collection) - { - if (CollectionNameSet.Contains(collection.Name)) - { - return collection.Features.Where(Matcher.MatchesFeature); - } - return Enumerable.Empty(); - } - - public FeatureFilter TakeAllFromCollections(params string[] collectionNames) - { - CollectionNameSet.AddRange(collectionNames); - return this; - } - - public FeatureFilter Where(IFeatureMatcher predicate) - { - Matcher = predicate; - return this; - } - } -} +using System; +using System.Collections.Generic; +using System.Linq; + +namespace Mapzen.VectorData.Filters +{ + [Serializable] + public class FeatureFilter : IFeatureFilter + { + public IFeatureMatcher Matcher; + + public List CollectionNameSet; + + public FeatureFilter() + { + Matcher = new FeatureMatcher(); + CollectionNameSet = new List(); + } + + public virtual IEnumerable Filter(FeatureCollection collection) + { + if (CollectionNameSet.Contains(collection.Name)) + { + return collection.Features.Where(Matcher.MatchesFeature); + } + return Enumerable.Empty(); + } + + public FeatureFilter TakeAllFromCollections(params string[] collectionNames) + { + CollectionNameSet.AddRange(collectionNames); + return this; + } + + public FeatureFilter Where(IFeatureMatcher predicate) + { + Matcher = predicate; + return this; + } + } +} diff --git a/Assets/Mapzen/VectorData/Filters/FeatureFilter.cs.meta b/Runtime/Mapzen/VectorData/Filters/FeatureFilter.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/FeatureFilter.cs.meta rename to Runtime/Mapzen/VectorData/Filters/FeatureFilter.cs.meta index 68dd656a..4f6cfc3f 100644 --- a/Assets/Mapzen/VectorData/Filters/FeatureFilter.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/FeatureFilter.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 9859d8473f63e4f66922dfa78a22e70c +guid: ac412159b2c37bb44839b3e9d2ec26e7 timeCreated: 1496276574 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/FeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/FeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/FeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/FeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta index 7014ef77..ab89da73 100644 --- a/Assets/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/FeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 3117395e4f2768140b9d3dfa4262ece7 +guid: 2a25fa7736b8c9641a6abf0a2b243503 timeCreated: 1496379894 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/IFeatureFilter.cs b/Runtime/Mapzen/VectorData/Filters/IFeatureFilter.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/IFeatureFilter.cs rename to Runtime/Mapzen/VectorData/Filters/IFeatureFilter.cs diff --git a/Assets/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta b/Runtime/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta rename to Runtime/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta index e7c72837..1c25f82c 100644 --- a/Assets/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/IFeatureFilter.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: bb4e26c5995514101965d8167170884f +guid: ca42265ca1959a142bb4bd91cc3e38b8 timeCreated: 1495765883 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/IFeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/IFeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/IFeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/IFeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta index e7dd4a34..01f9a433 100644 --- a/Assets/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/IFeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 61d7f078d3eb74e0ea582845fbb43935 +guid: 388ff14b53cadb648a2523e0862f4f30 timeCreated: 1495765883 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta index 51498c0f..59b4e534 100644 --- a/Assets/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/PropertyFeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 0403e2c2a2ece4a4ea5be1d3b568cbe0 +guid: 09b6ae63becacd4498614f090e21eb46 timeCreated: 1496276574 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta index 938d015f..2ffd58a2 100644 --- a/Assets/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/PropertyRangeFeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 67847ec510398462b9c1fbf657467050 +guid: a1906217f62e6b944af4a97fc50fe405 timeCreated: 1495661631 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta index eef7e888..d3ab546b 100644 --- a/Assets/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/PropertyRegexFeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 2a279433f246c45eaabbb7b96075e6fb +guid: 500769225f34c834d93114ce18ca7c51 timeCreated: 1496276574 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs b/Runtime/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs similarity index 100% rename from Assets/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs rename to Runtime/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs diff --git a/Assets/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta b/Runtime/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta rename to Runtime/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta index d24f4ec9..8e0d6831 100644 --- a/Assets/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta +++ b/Runtime/Mapzen/VectorData/Filters/PropertyValueFeatureMatcher.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 9e19b8d988633674f8bd8b49e000316f +guid: f8a16f13937a98947b30851a244e37d7 timeCreated: 1495656130 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats.meta b/Runtime/Mapzen/VectorData/Formats.meta similarity index 79% rename from Assets/Mapzen/VectorData/Formats.meta rename to Runtime/Mapzen/VectorData/Formats.meta index dda8db32..e7cdab0d 100644 --- a/Assets/Mapzen/VectorData/Formats.meta +++ b/Runtime/Mapzen/VectorData/Formats.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: c85cb1c6a324e451891439a23dbada6e +guid: 47991b60727cd614f817576a48872b90 folderAsset: yes timeCreated: 1496292759 licenseType: Free diff --git a/Assets/Mapzen/VectorData/Formats/GeoJsonFeature.cs b/Runtime/Mapzen/VectorData/Formats/GeoJsonFeature.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/GeoJsonFeature.cs rename to Runtime/Mapzen/VectorData/Formats/GeoJsonFeature.cs diff --git a/Assets/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta b/Runtime/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta rename to Runtime/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta index 5d7bdf06..d7b06311 100644 --- a/Assets/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/GeoJsonFeature.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 831e7edc61c404b7caf120d4289944c9 +guid: 1e1d30d31dd81eb4ba004c464fe791df timeCreated: 1496292759 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs b/Runtime/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs rename to Runtime/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs diff --git a/Assets/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta b/Runtime/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta rename to Runtime/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta index d96126f8..89925658 100644 --- a/Assets/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/GeoJsonFeatureCollection.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 3813f0d70275e4ad18e09d15faa06aff +guid: 7f5cd870b43183b4aba3a43843e66491 timeCreated: 1498252365 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats/GeoJsonTile.cs b/Runtime/Mapzen/VectorData/Formats/GeoJsonTile.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/GeoJsonTile.cs rename to Runtime/Mapzen/VectorData/Formats/GeoJsonTile.cs diff --git a/Assets/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta b/Runtime/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta rename to Runtime/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta index 78b94548..8c747124 100644 --- a/Assets/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/GeoJsonTile.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: e50ccc5411f4945c7b1d7d4f48fff6a2 +guid: 82f04bcdcdde2e5499cb60d2405b0c92 timeCreated: 1498257460 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats/Mvt.cs b/Runtime/Mapzen/VectorData/Formats/Mvt.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/Mvt.cs rename to Runtime/Mapzen/VectorData/Formats/Mvt.cs diff --git a/Assets/Mapzen/VectorData/Formats/Mvt.cs.meta b/Runtime/Mapzen/VectorData/Formats/Mvt.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/Mvt.cs.meta rename to Runtime/Mapzen/VectorData/Formats/Mvt.cs.meta index 66759bf5..6fe0f51a 100644 --- a/Assets/Mapzen/VectorData/Formats/Mvt.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/Mvt.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: e3760672254c49b40ab10a362117e061 +guid: a1ae6395e9c4c1b4aad92757127009e7 timeCreated: 1496619679 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats/MvtFeature.cs b/Runtime/Mapzen/VectorData/Formats/MvtFeature.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/MvtFeature.cs rename to Runtime/Mapzen/VectorData/Formats/MvtFeature.cs diff --git a/Assets/Mapzen/VectorData/Formats/MvtFeature.cs.meta b/Runtime/Mapzen/VectorData/Formats/MvtFeature.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/MvtFeature.cs.meta rename to Runtime/Mapzen/VectorData/Formats/MvtFeature.cs.meta index af605300..c93818e0 100644 --- a/Assets/Mapzen/VectorData/Formats/MvtFeature.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/MvtFeature.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 904feff21c0844a8782cd46a91f42cf8 +guid: 16aa87a914d66fc4cbebedbcb2839eff timeCreated: 1497490786 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats/MvtFeatureCollection.cs b/Runtime/Mapzen/VectorData/Formats/MvtFeatureCollection.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/MvtFeatureCollection.cs rename to Runtime/Mapzen/VectorData/Formats/MvtFeatureCollection.cs diff --git a/Assets/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta b/Runtime/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta rename to Runtime/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta index fb82464d..5870a6e3 100644 --- a/Assets/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/MvtFeatureCollection.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 649fc77f70c964aaa944f6c04d48b147 +guid: 50f0f388dd9ce474397f442d55119140 timeCreated: 1498503868 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Formats/MvtTile.cs b/Runtime/Mapzen/VectorData/Formats/MvtTile.cs similarity index 100% rename from Assets/Mapzen/VectorData/Formats/MvtTile.cs rename to Runtime/Mapzen/VectorData/Formats/MvtTile.cs diff --git a/Assets/Mapzen/VectorData/Formats/MvtTile.cs.meta b/Runtime/Mapzen/VectorData/Formats/MvtTile.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Formats/MvtTile.cs.meta rename to Runtime/Mapzen/VectorData/Formats/MvtTile.cs.meta index 1ef4d4b9..2469f5b0 100644 --- a/Assets/Mapzen/VectorData/Formats/MvtTile.cs.meta +++ b/Runtime/Mapzen/VectorData/Formats/MvtTile.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 09b335130fad54ae1b5563f5931fa7cc +guid: 2419e0d9dbbef244bbe571a4dabc5e5d timeCreated: 1498503868 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/GeometryContainer.cs b/Runtime/Mapzen/VectorData/GeometryContainer.cs similarity index 100% rename from Assets/Mapzen/VectorData/GeometryContainer.cs rename to Runtime/Mapzen/VectorData/GeometryContainer.cs diff --git a/Assets/Mapzen/VectorData/GeometryContainer.cs.meta b/Runtime/Mapzen/VectorData/GeometryContainer.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/GeometryContainer.cs.meta rename to Runtime/Mapzen/VectorData/GeometryContainer.cs.meta index a08d818b..9437f931 100644 --- a/Assets/Mapzen/VectorData/GeometryContainer.cs.meta +++ b/Runtime/Mapzen/VectorData/GeometryContainer.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 1b5fb7dfc697a42b0a35f26bad5b9799 +guid: 149cf361d301b4d4cb5dd63b4d76e022 timeCreated: 1498268030 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/GeometryType.cs b/Runtime/Mapzen/VectorData/GeometryType.cs similarity index 100% rename from Assets/Mapzen/VectorData/GeometryType.cs rename to Runtime/Mapzen/VectorData/GeometryType.cs diff --git a/Assets/Mapzen/VectorData/GeometryType.cs.meta b/Runtime/Mapzen/VectorData/GeometryType.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/GeometryType.cs.meta rename to Runtime/Mapzen/VectorData/GeometryType.cs.meta index 7dde0c87..7a4cce49 100644 --- a/Assets/Mapzen/VectorData/GeometryType.cs.meta +++ b/Runtime/Mapzen/VectorData/GeometryType.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: b396fc772ea75465cb4eed79a0a8eece +guid: cc29ab6c0e599bd488f369e1d1a220fd timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/IGeometryHandler.cs b/Runtime/Mapzen/VectorData/IGeometryHandler.cs similarity index 100% rename from Assets/Mapzen/VectorData/IGeometryHandler.cs rename to Runtime/Mapzen/VectorData/IGeometryHandler.cs diff --git a/Assets/Mapzen/VectorData/IGeometryHandler.cs.meta b/Runtime/Mapzen/VectorData/IGeometryHandler.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/IGeometryHandler.cs.meta rename to Runtime/Mapzen/VectorData/IGeometryHandler.cs.meta index c002e6c1..135fa014 100644 --- a/Assets/Mapzen/VectorData/IGeometryHandler.cs.meta +++ b/Runtime/Mapzen/VectorData/IGeometryHandler.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: ebcf5941c21ce489198d3b338deb2dd2 +guid: 330734718081ec94a8c9ee311126fcd7 timeCreated: 1498245508 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Layer.cs b/Runtime/Mapzen/VectorData/Layer.cs similarity index 100% rename from Assets/Mapzen/VectorData/Layer.cs rename to Runtime/Mapzen/VectorData/Layer.cs diff --git a/Assets/Mapzen/VectorData/Layer.cs.meta b/Runtime/Mapzen/VectorData/Layer.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Layer.cs.meta rename to Runtime/Mapzen/VectorData/Layer.cs.meta index 56d34fb4..a5f25f31 100644 --- a/Assets/Mapzen/VectorData/Layer.cs.meta +++ b/Runtime/Mapzen/VectorData/Layer.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 5e9e5ca3af08548ee96e5e54a9cbbd21 +guid: c42f44153e976b34e83e764652e4fb5d timeCreated: 1496292759 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Point.cs b/Runtime/Mapzen/VectorData/Point.cs similarity index 100% rename from Assets/Mapzen/VectorData/Point.cs rename to Runtime/Mapzen/VectorData/Point.cs diff --git a/Assets/Mapzen/VectorData/Point.cs.meta b/Runtime/Mapzen/VectorData/Point.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Point.cs.meta rename to Runtime/Mapzen/VectorData/Point.cs.meta index 4518a5da..8fb7b237 100644 --- a/Assets/Mapzen/VectorData/Point.cs.meta +++ b/Runtime/Mapzen/VectorData/Point.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: c72b9a5989fc344d6a22f313eb074a8f +guid: 8ee2211ae09f1f7468630c5e7e41e89e timeCreated: 1490324407 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/Tile.cs b/Runtime/Mapzen/VectorData/Tile.cs similarity index 100% rename from Assets/Mapzen/VectorData/Tile.cs rename to Runtime/Mapzen/VectorData/Tile.cs diff --git a/Assets/Mapzen/VectorData/Tile.cs.meta b/Runtime/Mapzen/VectorData/Tile.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/Tile.cs.meta rename to Runtime/Mapzen/VectorData/Tile.cs.meta index 8d2d2cfa..9aa53901 100644 --- a/Assets/Mapzen/VectorData/Tile.cs.meta +++ b/Runtime/Mapzen/VectorData/Tile.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 1c22f1f8f62904b5499fbda551547d3e +guid: 0a54f2d62499378428a6babf17e0542c timeCreated: 1498257460 licenseType: Free MonoImporter: diff --git a/Assets/Mapzen/VectorData/TileCache.cs b/Runtime/Mapzen/VectorData/TileCache.cs similarity index 100% rename from Assets/Mapzen/VectorData/TileCache.cs rename to Runtime/Mapzen/VectorData/TileCache.cs diff --git a/Assets/Mapzen/VectorData/TileCache.cs.meta b/Runtime/Mapzen/VectorData/TileCache.cs.meta similarity index 85% rename from Assets/Mapzen/VectorData/TileCache.cs.meta rename to Runtime/Mapzen/VectorData/TileCache.cs.meta index 5a8c079f..e697aa63 100644 --- a/Assets/Mapzen/VectorData/TileCache.cs.meta +++ b/Runtime/Mapzen/VectorData/TileCache.cs.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: acfc8f1bff66248f0bdf527927b2e19e +guid: 7fc6885342f3ce14a8729e44d268d7b4 timeCreated: 1512155402 licenseType: Free MonoImporter: diff --git a/Assets/Plugins.meta b/Runtime/Plugins.meta similarity index 79% rename from Assets/Plugins.meta rename to Runtime/Plugins.meta index f4048189..5374fcbf 100644 --- a/Assets/Plugins.meta +++ b/Runtime/Plugins.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 397c0fb65d3b7453c8b216f643291ca2 +guid: 64b0d86bcae1cc44f9c4b56eb8c2c33d folderAsset: yes timeCreated: 1489589171 licenseType: Free diff --git a/Assets/Plugins/Protobuf.meta b/Runtime/Plugins/Protobuf.meta similarity index 79% rename from Assets/Plugins/Protobuf.meta rename to Runtime/Plugins/Protobuf.meta index fffcb5e1..2443298a 100644 --- a/Assets/Plugins/Protobuf.meta +++ b/Runtime/Plugins/Protobuf.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: 4521ab97dbfcaff43b9722235a24f3d0 +guid: fd3426b2e741b4f49a615bd7a48c16f4 folderAsset: yes timeCreated: 1496624517 licenseType: Free diff --git a/Assets/Plugins/Protobuf/Google.Protobuf.dll.meta b/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta similarity index 94% rename from Assets/Plugins/Protobuf/Google.Protobuf.dll.meta rename to Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta index eb52b49e..43672dc3 100644 --- a/Assets/Plugins/Protobuf/Google.Protobuf.dll.meta +++ b/Runtime/Plugins/Protobuf/Google.Protobuf.dll.meta @@ -1,5 +1,5 @@ fileFormatVersion: 2 -guid: e76f5518a2ac94142a4fbdbbde8f8f39 +guid: 5ad31ad7e29cad14e933a09c5c84d9c4 timeCreated: 1496624518 licenseType: Free PluginImporter: diff --git a/Assets/Plugins/Protobuf/Google.Protobuf.xml b/Runtime/Plugins/Protobuf/Google.Protobuf.xml similarity index 98% rename from Assets/Plugins/Protobuf/Google.Protobuf.xml rename to Runtime/Plugins/Protobuf/Google.Protobuf.xml index d1319ac5..1a7bbd4b 100644 --- a/Assets/Plugins/Protobuf/Google.Protobuf.xml +++ b/Runtime/Plugins/Protobuf/Google.Protobuf.xml @@ -1,7028 +1,7028 @@ - - - - Google.Protobuf - - - -