Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / NetFx35 / System.ServiceModel.Web / System / UriTemplateLiteralPathSegment.cs / 2 / UriTemplateLiteralPathSegment.cs
//---------------------------------------------------------------- // Copyright (c) Microsoft Corporation. All rights reserved. //--------------------------------------------------------------- namespace System { using System.Collections.Specialized; using System.ServiceModel; using System.ServiceModel.Web; using System.Text; // thin wrapper around string; use type system to help ensure we // are doing canonicalization right/consistently class UriTemplateLiteralPathSegment : UriTemplatePathSegment, IComparable{ // segment doesn't store trailing slash readonly string segment; static Uri dummyUri = new Uri("http://localhost"); UriTemplateLiteralPathSegment(string segment) : base(segment, UriTemplatePartType.Literal, segment.EndsWith("/", StringComparison.Ordinal)) { Fx.Assert(segment != null, "bad literal segment"); if (this.EndsWithSlash) { this.segment = segment.Remove(segment.Length - 1); } else { this.segment = segment; } } public static new UriTemplateLiteralPathSegment CreateFromUriTemplate(string segment, UriTemplate template) { // run it through UriBuilder to escape-if-necessary it if (string.Compare(segment, "/", StringComparison.Ordinal) == 0) { // running an empty segment through UriBuilder has unexpected/wrong results return new UriTemplateLiteralPathSegment("/"); } if (segment.IndexOf(UriTemplate.WildcardPath, StringComparison.Ordinal) != -1) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new FormatException( SR2.GetString(SR2.UTInvalidWildcardInVariableOrLiteral, template.originalTemplate, UriTemplate.WildcardPath))); } // '*' is not usually escaped by the Uri\UriBuilder to %2a, since we forbid passing a // clear character and the workaroud is to pass the escaped form, we should replace the // escaped form with the regular one. segment = segment.Replace("%2a", "*").Replace("%2A", "*"); UriBuilder ub = new UriBuilder(dummyUri); ub.Path = segment; string escapedIfNecessarySegment = ub.Uri.AbsolutePath.Substring(1); if (escapedIfNecessarySegment == string.Empty) { // This path through UriBuilder will sometimes consume various segments // such as '../' and './'. When this happens and the result is an empty // string, we should just throw and tell the user we don't handle that. throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgument("segment", SR2.GetString(SR2.UTInvalidFormatSegmentOrQueryPart, segment)); } return new UriTemplateLiteralPathSegment(escapedIfNecessarySegment); } public static UriTemplateLiteralPathSegment CreateFromWireData(string segment) { return new UriTemplateLiteralPathSegment(segment); } public string AsUnescapedString() { Fx.Assert(this.segment != null, "this should only be called by Bind\\Lookup"); return Uri.UnescapeDataString(this.segment); } public override void Bind(string[] values, ref int valueIndex, StringBuilder path) { if (this.EndsWithSlash) { path.AppendFormat("{0}/", AsUnescapedString()); } else { path.Append(AsUnescapedString()); } } public int CompareTo(UriTemplateLiteralPathSegment other) { return StringComparer.OrdinalIgnoreCase.Compare(this.segment, other.segment); } public override bool Equals(object obj) { UriTemplateLiteralPathSegment lps = obj as UriTemplateLiteralPathSegment; if (lps == null) { Fx.Assert("why would we ever call this?"); return false; } else { return ((this.EndsWithSlash == lps.EndsWithSlash) && StringComparer.OrdinalIgnoreCase.Equals(this.segment, lps.segment)); } } public override int GetHashCode() { return StringComparer.OrdinalIgnoreCase.GetHashCode(this.segment); } public override bool IsEquivalentTo(UriTemplatePathSegment other, bool ignoreTrailingSlash) { if (other == null) { Fx.Assert("why would we ever call this?"); return false; } if (other.Nature != UriTemplatePartType.Literal) { return false; } UriTemplateLiteralPathSegment otherAsLiteral = other as UriTemplateLiteralPathSegment; Fx.Assert(otherAsLiteral != null, "The nature requires that this will be OK"); return IsMatch(otherAsLiteral, ignoreTrailingSlash); } public override bool IsMatch(UriTemplateLiteralPathSegment segment, bool ignoreTrailingSlash) { if (!ignoreTrailingSlash && (segment.EndsWithSlash != this.EndsWithSlash)) { return false; } return (CompareTo(segment) == 0); } public bool IsNullOrEmpty() { return string.IsNullOrEmpty(this.segment); } public override void Lookup(string segment, NameValueCollection boundParameters) { Fx.Assert(StringComparer.OrdinalIgnoreCase.Compare(AsUnescapedString(), segment) == 0, "How can that be? Lookup is expected to be called after IsMatch"); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- CompareValidator.cs
- RuleSetDialog.cs
- DataSvcMapFileSerializer.cs
- codemethodreferenceexpression.cs
- LogStore.cs
- SqlServices.cs
- SymbolResolver.cs
- ZipIOLocalFileBlock.cs
- DesignerInterfaces.cs
- SiteMapNodeItemEventArgs.cs
- XmlSchemaParticle.cs
- WebPartMenuStyle.cs
- HexParser.cs
- shaperfactoryquerycachekey.cs
- DateTimePickerDesigner.cs
- LinkTarget.cs
- NGCUIElementCollectionSerializerAsync.cs
- GeneralTransform3D.cs
- MeasurementDCInfo.cs
- ActivityExecutorSurrogate.cs
- Model3DGroup.cs
- ObjectParameterCollection.cs
- WindowsIdentity.cs
- PropertyOverridesDialog.cs
- CollectionConverter.cs
- ExtensibleClassFactory.cs
- mediaclock.cs
- ValidationPropertyAttribute.cs
- CodeVariableReferenceExpression.cs
- DropDownList.cs
- ToolStripDropDownItem.cs
- WebPartsSection.cs
- UnsafeNativeMethods.cs
- RuleRef.cs
- ConfigXmlText.cs
- InheritanceContextChangedEventManager.cs
- HitTestWithGeometryDrawingContextWalker.cs
- SoapCommonClasses.cs
- CompositeDataBoundControl.cs
- RightsManagementEncryptionTransform.cs
- DataGridViewSelectedColumnCollection.cs
- XmlILIndex.cs
- Error.cs
- PageClientProxyGenerator.cs
- ModuleBuilderData.cs
- DispatcherEventArgs.cs
- DataTableCollection.cs
- DataGridViewComboBoxEditingControl.cs
- IPCCacheManager.cs
- SqlConnectionPoolGroupProviderInfo.cs
- Registry.cs
- Int16Converter.cs
- TabletDevice.cs
- SizeValueSerializer.cs
- controlskin.cs
- ContextStack.cs
- NeedSkipTokenVisitor.cs
- ProviderManager.cs
- NavigationHelper.cs
- DrawingContextDrawingContextWalker.cs
- HotSpotCollection.cs
- ICollection.cs
- Point.cs
- InfiniteIntConverter.cs
- SecurityKeyType.cs
- HttpCacheVaryByContentEncodings.cs
- BaseTemplateCodeDomTreeGenerator.cs
- GraphicsState.cs
- TextTrailingCharacterEllipsis.cs
- PackageStore.cs
- Renderer.cs
- XamlGridLengthSerializer.cs
- Accessible.cs
- IndentedWriter.cs
- InvalidateEvent.cs
- PlatformCulture.cs
- Permission.cs
- XPathSelectionIterator.cs
- FormViewUpdatedEventArgs.cs
- IPHostEntry.cs
- PointLight.cs
- ObjectManager.cs
- HebrewNumber.cs
- RangeContentEnumerator.cs
- ContainerControl.cs
- MarkupCompilePass1.cs
- TextSimpleMarkerProperties.cs
- CultureMapper.cs
- UriParserTemplates.cs
- BamlVersionHeader.cs
- XsltInput.cs
- MenuItem.cs
- MarginsConverter.cs
- _ConnectOverlappedAsyncResult.cs
- RtfFormatStack.cs
- AdRotator.cs
- ImportDesigner.xaml.cs
- PassportAuthentication.cs
- DataServiceStreamResponse.cs
- Clause.cs