Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / Xml / System / Xml / Base64Encoder.cs / 1 / Base64Encoder.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System.Text; using System.Diagnostics; namespace System.Xml { internal abstract class Base64Encoder { byte[] leftOverBytes; int leftOverBytesCount; char[] charsLine; internal const int Base64LineSize = 76; internal const int LineSizeInBytes = Base64LineSize/4*3; internal Base64Encoder() { charsLine = new char[Base64LineSize]; } internal abstract void WriteChars( char[] chars, int index, int count ); internal void Encode( byte[] buffer, int index, int count ) { if ( buffer == null ) { throw new ArgumentNullException( "buffer" ); } if ( index < 0 ) { throw new ArgumentOutOfRangeException( "index" ); } if ( count < 0 ) { throw new ArgumentOutOfRangeException( "count" ); } if ( count > buffer.Length - index ) { throw new ArgumentOutOfRangeException( "count" ); } // encode left-over buffer if( leftOverBytesCount > 0 ) { int i = leftOverBytesCount; while ( i < 3 && count > 0 ) { leftOverBytes[i++] = buffer[index++]; count--; } // the total number of buffer we have is less than 3 -> return if ( count == 0 && i < 3 ) { leftOverBytesCount = i; return; } // encode the left-over buffer and write out int leftOverChars = Convert.ToBase64CharArray( leftOverBytes, 0, 3, charsLine, 0 ); WriteChars( charsLine, 0, leftOverChars ); } // store new left-over buffer leftOverBytesCount = count % 3; if ( leftOverBytesCount > 0 ) { count -= leftOverBytesCount; if ( leftOverBytes == null ) { leftOverBytes = new byte[3]; } for( int i = 0; i < leftOverBytesCount; i++ ) { leftOverBytes[i] = buffer[ index + count + i ]; } } // encode buffer in 76 character long chunks int endIndex = index + count; int chunkSize = LineSizeInBytes; while( index < endIndex ) { if ( index + chunkSize > endIndex ) { chunkSize = endIndex - index; } int charCount = Convert.ToBase64CharArray( buffer, index, chunkSize, charsLine, 0 ); WriteChars( charsLine, 0, charCount ); index += chunkSize; } } internal void Flush() { if ( leftOverBytesCount > 0 ) { int leftOverChars = Convert.ToBase64CharArray( leftOverBytes, 0, leftOverBytesCount, charsLine, 0 ); WriteChars( charsLine, 0, leftOverChars ); leftOverBytesCount = 0; } } } internal class XmlRawWriterBase64Encoder : Base64Encoder { XmlRawWriter rawWriter; internal XmlRawWriterBase64Encoder( XmlRawWriter rawWriter ) { this.rawWriter = rawWriter; } internal override void WriteChars( char[] chars, int index, int count ) { rawWriter.WriteRaw( chars, index, count ); } } internal class XmlTextWriterBase64Encoder : Base64Encoder { XmlTextEncoder xmlTextEncoder; internal XmlTextWriterBase64Encoder( XmlTextEncoder xmlTextEncoder ) { this.xmlTextEncoder = xmlTextEncoder; } internal override void WriteChars( char[] chars, int index, int count ) { xmlTextEncoder.WriteRaw( chars, index, count ); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //----------------------------------------------------------------------------- using System.Text; using System.Diagnostics; namespace System.Xml { internal abstract class Base64Encoder { byte[] leftOverBytes; int leftOverBytesCount; char[] charsLine; internal const int Base64LineSize = 76; internal const int LineSizeInBytes = Base64LineSize/4*3; internal Base64Encoder() { charsLine = new char[Base64LineSize]; } internal abstract void WriteChars( char[] chars, int index, int count ); internal void Encode( byte[] buffer, int index, int count ) { if ( buffer == null ) { throw new ArgumentNullException( "buffer" ); } if ( index < 0 ) { throw new ArgumentOutOfRangeException( "index" ); } if ( count < 0 ) { throw new ArgumentOutOfRangeException( "count" ); } if ( count > buffer.Length - index ) { throw new ArgumentOutOfRangeException( "count" ); } // encode left-over buffer if( leftOverBytesCount > 0 ) { int i = leftOverBytesCount; while ( i < 3 && count > 0 ) { leftOverBytes[i++] = buffer[index++]; count--; } // the total number of buffer we have is less than 3 -> return if ( count == 0 && i < 3 ) { leftOverBytesCount = i; return; } // encode the left-over buffer and write out int leftOverChars = Convert.ToBase64CharArray( leftOverBytes, 0, 3, charsLine, 0 ); WriteChars( charsLine, 0, leftOverChars ); } // store new left-over buffer leftOverBytesCount = count % 3; if ( leftOverBytesCount > 0 ) { count -= leftOverBytesCount; if ( leftOverBytes == null ) { leftOverBytes = new byte[3]; } for( int i = 0; i < leftOverBytesCount; i++ ) { leftOverBytes[i] = buffer[ index + count + i ]; } } // encode buffer in 76 character long chunks int endIndex = index + count; int chunkSize = LineSizeInBytes; while( index < endIndex ) { if ( index + chunkSize > endIndex ) { chunkSize = endIndex - index; } int charCount = Convert.ToBase64CharArray( buffer, index, chunkSize, charsLine, 0 ); WriteChars( charsLine, 0, charCount ); index += chunkSize; } } internal void Flush() { if ( leftOverBytesCount > 0 ) { int leftOverChars = Convert.ToBase64CharArray( leftOverBytes, 0, leftOverBytesCount, charsLine, 0 ); WriteChars( charsLine, 0, leftOverChars ); leftOverBytesCount = 0; } } } internal class XmlRawWriterBase64Encoder : Base64Encoder { XmlRawWriter rawWriter; internal XmlRawWriterBase64Encoder( XmlRawWriter rawWriter ) { this.rawWriter = rawWriter; } internal override void WriteChars( char[] chars, int index, int count ) { rawWriter.WriteRaw( chars, index, count ); } } internal class XmlTextWriterBase64Encoder : Base64Encoder { XmlTextEncoder xmlTextEncoder; internal XmlTextWriterBase64Encoder( XmlTextEncoder xmlTextEncoder ) { this.xmlTextEncoder = xmlTextEncoder; } internal override void WriteChars( char[] chars, int index, int count ) { xmlTextEncoder.WriteRaw( chars, index, count ); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SystemIPv6InterfaceProperties.cs
- NameTable.cs
- CustomAttributeBuilder.cs
- CodeDelegateInvokeExpression.cs
- Icon.cs
- XmlSchemaAttributeGroupRef.cs
- AssemblyBuilderData.cs
- LingerOption.cs
- XmlNode.cs
- Base64Encoding.cs
- ButtonColumn.cs
- ChangeTracker.cs
- _DisconnectOverlappedAsyncResult.cs
- WebMessageEncodingBindingElement.cs
- LogLogRecord.cs
- DocumentSequence.cs
- ClassImporter.cs
- XmlObjectSerializerWriteContextComplexJson.cs
- CodeAttachEventStatement.cs
- RequestCacheValidator.cs
- XslNumber.cs
- Misc.cs
- QueueProcessor.cs
- UnicodeEncoding.cs
- MouseGesture.cs
- XsltFunctions.cs
- Pair.cs
- ToolConsole.cs
- ProfileSection.cs
- WindowsFormsEditorServiceHelper.cs
- CodeSnippetTypeMember.cs
- DataServiceRequestException.cs
- TripleDES.cs
- RadioButton.cs
- ListViewSelectEventArgs.cs
- SafeMemoryMappedViewHandle.cs
- baseaxisquery.cs
- XmlSchemaType.cs
- NamespaceMapping.cs
- ViewSimplifier.cs
- TextBox.cs
- LogExtent.cs
- TypeBrowserDialog.cs
- safemediahandle.cs
- CloudCollection.cs
- ListParagraph.cs
- MessageContractImporter.cs
- ComContractElementCollection.cs
- MessageBuilder.cs
- WebPartConnectVerb.cs
- AssemblyGen.cs
- TransformerConfigurationWizardBase.cs
- BindToObject.cs
- HttpWriter.cs
- ConfigXmlComment.cs
- _DisconnectOverlappedAsyncResult.cs
- GlobalizationAssembly.cs
- VerificationAttribute.cs
- ColumnTypeConverter.cs
- ConfigurationLoader.cs
- WindowsGraphicsCacheManager.cs
- WebServiceEnumData.cs
- EntityDataSourceDataSelection.cs
- TextUtf8RawTextWriter.cs
- ConstrainedDataObject.cs
- TemplatePagerField.cs
- UseLicense.cs
- HeaderedContentControl.cs
- RegistrationServices.cs
- SafeNativeMethodsCLR.cs
- GenericIdentity.cs
- Menu.cs
- Int16Storage.cs
- Classification.cs
- MaterialGroup.cs
- ToolStripRenderEventArgs.cs
- CodeAttributeDeclarationCollection.cs
- OperationSelectorBehavior.cs
- CommonProperties.cs
- SafeSystemMetrics.cs
- _SingleItemRequestCache.cs
- SoapDocumentServiceAttribute.cs
- OrderedDictionaryStateHelper.cs
- SendMailErrorEventArgs.cs
- XmlHierarchyData.cs
- Int64Converter.cs
- AlignmentXValidation.cs
- CallInfo.cs
- WCFBuildProvider.cs
- NavigationCommands.cs
- QueryMatcher.cs
- RoleManagerSection.cs
- PublishLicense.cs
- CompilerTypeWithParams.cs
- ModelItemDictionary.cs
- NonPrimarySelectionGlyph.cs
- BoundsDrawingContextWalker.cs
- _SecureChannel.cs
- TraceContext.cs
- GeometryGroup.cs