Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Framework / System / Windows / Markup / XamlTreeBuilderBamlRecordWriter.cs / 1 / XamlTreeBuilderBamlRecordWriter.cs
/****************************************************************************\ * * File: XamlTreeBuilderBamlRecordWriter.cs * * Purpose: Class that writes baml records when building a tree directly * from xaml * * History: * 6/06/01: rogerg Created * 5/29/03: peterost Ported to wcp * 11/13/03: peterost split from XamlTreeBuilder.cs * * Copyright (C) 2003 by Microsoft Corporation. All rights reserved. * \***************************************************************************/ using System; using System.Xml; using System.IO; using System.Windows; using System.Text; using System.Collections; using System.ComponentModel; using System.Diagnostics; using System.Reflection; using System.Windows.Threading; using MS.Utility; namespace System.Windows.Markup { ////// Override class for BamlRecordWriter when building tree Directly from XAML. /// We do this so in the [....] case we can build the tree directly instead /// of writing to a BAMLStream. Note that building a tree directly from xaml /// DOES NOT support defer loaded content /// internal class XamlTreeBuilderBamlRecordWriter : BamlRecordWriter { #region Constructors internal XamlTreeBuilderBamlRecordWriter( XamlTreeBuilder treeBuilder, Stream stream, ParserContext parserContext, bool isSerializer ) : base(stream,parserContext,false) { _treeBuilder = treeBuilder; _writerStream = stream as WriterStream; // If we're in a nested parser, then we need to track it in our // _customSerializerNestingLevel counter. Otherwise we'll flush // Baml records to the reader thread too soon in WriteBamlRecord. if( isSerializer ) { _customSerializerNestingLevel = 1; } Debug.Assert(null != _writerStream,"Stream for Writer is not a WriterStream"); } #endregion Constructors #region Overrides internal override void WriteBamlRecord( BamlRecord bamlRecord, int lineNumber, int linePosition) { bool bamlRecordHandled = false; // Try to load the Baml record. This will work if we're in [....] mode // (default case), or if we're in async mode and processing the root. bamlRecordHandled = TreeBuilder.BamlRecordWriterSyncUpdate(bamlRecord, lineNumber, linePosition); // If it didn't get handled, write the baml record to the baml stream. if (!bamlRecordHandled) { // Write the record. base.WriteBamlRecord(bamlRecord, lineNumber, linePosition); // Nowe we see if we can let the reader see this record. We can't if we're within // a custom serializer. (This was added so that templates & styles wouldn't get sealed // before being fully loaded, an alternative would be to use ISupportInitialize.) // Is this a start record? BamlElementStartRecord bamlElementStartRecord = bamlRecord as BamlElementStartRecord; if (bamlElementStartRecord != null) { // Yes, it's a start record. If we're not already under a custom serializer, // but this element has one, then start nesting. if (_customSerializerNestingLevel == 0 && MapTable.HasSerializerForTypeId(bamlElementStartRecord.TypeId)) { _customSerializerNestingLevel = 1; } // Or, if we're already under a custom serializer, increment the nesting level. else if (_customSerializerNestingLevel > 0) { ++_customSerializerNestingLevel; } } // This isn't a start record. But if we're under a custom serializer, // we might need to update the nesting level. else if (_customSerializerNestingLevel != 0) { // If this is an end element record, decrement the nesting level. BamlElementEndRecord bamlElementEndRecord = bamlRecord as BamlElementEndRecord; if (bamlElementEndRecord != null) { --_customSerializerNestingLevel; } } // If we're not (now) under a custom serializer context, tell the reader // about all of the records we've written. if (_customSerializerNestingLevel == 0) { WriterStream.UpdateReaderLength(WriterStream.Length ); } } } ////// sets the number of Records that can be read at a time /// in async mode. main use is for debugging. /// /// number of Records we are allowed to read internal override void SetMaxAsyncRecords(int maxAsyncRecords) { TreeBuilder.MaxAsyncRecords = maxAsyncRecords; } ////// Called to determine if it is okay for ParentNodes to be updated /// since building the tree directly we can't seek back to update /// the parent nodes so false is always returned. /// internal override bool UpdateParentNodes { get { return false; } } // If building a tree directly, just store the strings directly in the BAML record. // Don't have to precreate the DP object, stream it out and then re-create it as this // is extra work, so custom serialization is not allowed. internal override void WriteProperty(XamlPropertyNode xamlPropertyNode) { BaseWriteProperty(xamlPropertyNode); } #endregion Overrides #region Properties ////// TreeBuilder associated with this class /// internal XamlTreeBuilder TreeBuilder { get { return _treeBuilder; } } ////// Writer stream records are written to. /// Hold onto this so we can updateThe Reader length to keep the /// BamlRecords class unaware of the ReaderWriter Stream /// private WriterStream WriterStream { get { return _writerStream; } } ////// When creating a tree directly from Xaml, use the record reader's /// BamlRecordManager, since its record releasing behavior is modified /// based on the markup it is reading in /// internal override BamlRecordManager BamlRecordManager { get { return _treeBuilder.RecordReader.BamlRecordManager; } } #endregion Properties #region Data XamlTreeBuilder _treeBuilder; WriterStream _writerStream; int _customSerializerNestingLevel = 0; #endregion Data } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. /****************************************************************************\ * * File: XamlTreeBuilderBamlRecordWriter.cs * * Purpose: Class that writes baml records when building a tree directly * from xaml * * History: * 6/06/01: rogerg Created * 5/29/03: peterost Ported to wcp * 11/13/03: peterost split from XamlTreeBuilder.cs * * Copyright (C) 2003 by Microsoft Corporation. All rights reserved. * \***************************************************************************/ using System; using System.Xml; using System.IO; using System.Windows; using System.Text; using System.Collections; using System.ComponentModel; using System.Diagnostics; using System.Reflection; using System.Windows.Threading; using MS.Utility; namespace System.Windows.Markup { ////// Override class for BamlRecordWriter when building tree Directly from XAML. /// We do this so in the [....] case we can build the tree directly instead /// of writing to a BAMLStream. Note that building a tree directly from xaml /// DOES NOT support defer loaded content /// internal class XamlTreeBuilderBamlRecordWriter : BamlRecordWriter { #region Constructors internal XamlTreeBuilderBamlRecordWriter( XamlTreeBuilder treeBuilder, Stream stream, ParserContext parserContext, bool isSerializer ) : base(stream,parserContext,false) { _treeBuilder = treeBuilder; _writerStream = stream as WriterStream; // If we're in a nested parser, then we need to track it in our // _customSerializerNestingLevel counter. Otherwise we'll flush // Baml records to the reader thread too soon in WriteBamlRecord. if( isSerializer ) { _customSerializerNestingLevel = 1; } Debug.Assert(null != _writerStream,"Stream for Writer is not a WriterStream"); } #endregion Constructors #region Overrides internal override void WriteBamlRecord( BamlRecord bamlRecord, int lineNumber, int linePosition) { bool bamlRecordHandled = false; // Try to load the Baml record. This will work if we're in [....] mode // (default case), or if we're in async mode and processing the root. bamlRecordHandled = TreeBuilder.BamlRecordWriterSyncUpdate(bamlRecord, lineNumber, linePosition); // If it didn't get handled, write the baml record to the baml stream. if (!bamlRecordHandled) { // Write the record. base.WriteBamlRecord(bamlRecord, lineNumber, linePosition); // Nowe we see if we can let the reader see this record. We can't if we're within // a custom serializer. (This was added so that templates & styles wouldn't get sealed // before being fully loaded, an alternative would be to use ISupportInitialize.) // Is this a start record? BamlElementStartRecord bamlElementStartRecord = bamlRecord as BamlElementStartRecord; if (bamlElementStartRecord != null) { // Yes, it's a start record. If we're not already under a custom serializer, // but this element has one, then start nesting. if (_customSerializerNestingLevel == 0 && MapTable.HasSerializerForTypeId(bamlElementStartRecord.TypeId)) { _customSerializerNestingLevel = 1; } // Or, if we're already under a custom serializer, increment the nesting level. else if (_customSerializerNestingLevel > 0) { ++_customSerializerNestingLevel; } } // This isn't a start record. But if we're under a custom serializer, // we might need to update the nesting level. else if (_customSerializerNestingLevel != 0) { // If this is an end element record, decrement the nesting level. BamlElementEndRecord bamlElementEndRecord = bamlRecord as BamlElementEndRecord; if (bamlElementEndRecord != null) { --_customSerializerNestingLevel; } } // If we're not (now) under a custom serializer context, tell the reader // about all of the records we've written. if (_customSerializerNestingLevel == 0) { WriterStream.UpdateReaderLength(WriterStream.Length ); } } } ////// sets the number of Records that can be read at a time /// in async mode. main use is for debugging. /// /// number of Records we are allowed to read internal override void SetMaxAsyncRecords(int maxAsyncRecords) { TreeBuilder.MaxAsyncRecords = maxAsyncRecords; } ////// Called to determine if it is okay for ParentNodes to be updated /// since building the tree directly we can't seek back to update /// the parent nodes so false is always returned. /// internal override bool UpdateParentNodes { get { return false; } } // If building a tree directly, just store the strings directly in the BAML record. // Don't have to precreate the DP object, stream it out and then re-create it as this // is extra work, so custom serialization is not allowed. internal override void WriteProperty(XamlPropertyNode xamlPropertyNode) { BaseWriteProperty(xamlPropertyNode); } #endregion Overrides #region Properties ////// TreeBuilder associated with this class /// internal XamlTreeBuilder TreeBuilder { get { return _treeBuilder; } } ////// Writer stream records are written to. /// Hold onto this so we can updateThe Reader length to keep the /// BamlRecords class unaware of the ReaderWriter Stream /// private WriterStream WriterStream { get { return _writerStream; } } ////// When creating a tree directly from Xaml, use the record reader's /// BamlRecordManager, since its record releasing behavior is modified /// based on the markup it is reading in /// internal override BamlRecordManager BamlRecordManager { get { return _treeBuilder.RecordReader.BamlRecordManager; } } #endregion Properties #region Data XamlTreeBuilder _treeBuilder; WriterStream _writerStream; int _customSerializerNestingLevel = 0; #endregion Data } } // 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
- DynamicUpdateCommand.cs
- ComponentTray.cs
- HttpFileCollectionBase.cs
- DecimalKeyFrameCollection.cs
- X509CertificateCollection.cs
- TaskFormBase.cs
- FormsAuthenticationConfiguration.cs
- ChangesetResponse.cs
- UnmanagedMemoryStream.cs
- Border.cs
- PropertyEmitterBase.cs
- CqlQuery.cs
- ConfigXmlCDataSection.cs
- PasswordPropertyTextAttribute.cs
- UnsafeNativeMethods.cs
- XmlQueryContext.cs
- cookiecontainer.cs
- PermissionSetTriple.cs
- SoapHeaderAttribute.cs
- ResourceReferenceExpression.cs
- XmlElementList.cs
- XmlIlGenerator.cs
- Matrix3D.cs
- ViewCellSlot.cs
- InkPresenter.cs
- SiblingIterators.cs
- FreeIndexList.cs
- DBConnectionString.cs
- TextControl.cs
- WsdlBuildProvider.cs
- ExtensibleClassFactory.cs
- PrintPreviewDialog.cs
- PolicyUnit.cs
- XmlValidatingReader.cs
- HyperLinkStyle.cs
- invalidudtexception.cs
- ServiceParser.cs
- ImageMap.cs
- QilExpression.cs
- Stack.cs
- SqlClientWrapperSmiStream.cs
- SwitchCase.cs
- ChannelSinkStacks.cs
- TcpClientCredentialType.cs
- TextParagraph.cs
- Int32.cs
- DSASignatureDeformatter.cs
- DescendentsWalker.cs
- ipaddressinformationcollection.cs
- LocalFileSettingsProvider.cs
- XsltInput.cs
- NotificationContext.cs
- ListenerElementsCollection.cs
- HtmlShimManager.cs
- CollectionsUtil.cs
- MaterialGroup.cs
- CryptoApi.cs
- PropertyRef.cs
- WorkerRequest.cs
- PrimitiveSchema.cs
- RelationshipNavigation.cs
- ClockController.cs
- Int64AnimationUsingKeyFrames.cs
- TemplateContentLoader.cs
- ProcessManager.cs
- Int32Converter.cs
- Scanner.cs
- EnumConverter.cs
- DataReaderContainer.cs
- Rules.cs
- ListViewGroupItemCollection.cs
- EasingKeyFrames.cs
- ConnectionStringEditor.cs
- WebPartZoneCollection.cs
- ProfileService.cs
- TreeViewImageIndexConverter.cs
- Header.cs
- ProfileProvider.cs
- SystemGatewayIPAddressInformation.cs
- StringBlob.cs
- InfoCardBaseException.cs
- SqlMethodCallConverter.cs
- AuthenticationManager.cs
- ListViewContainer.cs
- CommandSet.cs
- NotifyParentPropertyAttribute.cs
- WorkflowTransactionService.cs
- CodeEntryPointMethod.cs
- ControlParser.cs
- MailWebEventProvider.cs
- SplineKeyFrames.cs
- SpellerError.cs
- HotSpotCollection.cs
- TransformedBitmap.cs
- ExclusiveHandleList.cs
- JoinTreeNode.cs
- Drawing.cs
- MissingMethodException.cs
- WorkflowRuntime.cs
- SingleTagSectionHandler.cs