Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / DynamicData / DynamicData / Util / TemplateFactory.cs / 1305376 / TemplateFactory.cs
using System.Collections; using System.Diagnostics; using System.Globalization; using System.Web.Compilation; using System.Web.Hosting; using System.Web.Resources; namespace System.Web.DynamicData { internal class TemplateFactory { // Use Hashtable instead of Dictionary<,> because it is more thread safe private Hashtable _fieldTemplateVirtualPathCache = new Hashtable(); private string _defaultLocation; private string _templateFolderVirtualPath; internal MetaModel Model { get; set; } private bool _needToResolveVirtualPath; private bool _trackFolderChanges; private bool _registeredForChangeNotifications; private VirtualPathProvider _vpp; private bool _usingCustomVpp; internal TemplateFactory(string defaultLocation) : this(defaultLocation, true) { } internal TemplateFactory(string defaultLocation, bool trackFolderChanges) { Debug.Assert(!String.IsNullOrEmpty(defaultLocation)); _defaultLocation = defaultLocation; _trackFolderChanges = trackFolderChanges; } internal string TemplateFolderVirtualPath { get { if (_templateFolderVirtualPath == null) { // If not set, set its default location TemplateFolderVirtualPath = _defaultLocation; } if (_needToResolveVirtualPath) { // Make sure it ends with a slash _templateFolderVirtualPath = VirtualPathUtility.AppendTrailingSlash(_templateFolderVirtualPath); // If it's relative, make it relative to the Model's path // Note can be null under Unit Testing if (Model != null) { _templateFolderVirtualPath = VirtualPathUtility.Combine(Model.DynamicDataFolderVirtualPath, _templateFolderVirtualPath); } _needToResolveVirtualPath = false; } return _templateFolderVirtualPath; } set { _templateFolderVirtualPath = value; // Make sure we register for change notifications, since we just got a new path _registeredForChangeNotifications = false; // It may be relative and need resolution, but let's not do it until we need it _needToResolveVirtualPath = true; } } internal VirtualPathProvider VirtualPathProvider { get { if (_vpp == null) { _vpp = HostingEnvironment.VirtualPathProvider; } return _vpp; } set { _vpp = value; _usingCustomVpp = value != null; } } internal string GetTemplatePath(long cacheKey, FunctemplatePathFactoryFunction) { // Check if we already have it cached string virtualPath = this[cacheKey]; // null is a valid value, so we also need to check whether the key exists if (virtualPath == null && !ContainsKey(cacheKey)) { // It's not cached, so compute it and cache it. Make sure multiple writers are serialized virtualPath = templatePathFactoryFunction(); this[cacheKey] = virtualPath; } return virtualPath; } private string this[long cacheKey] { get { EnsureRegisteredForChangeNotifications(); return (string)_fieldTemplateVirtualPathCache[cacheKey]; } set { EnsureRegisteredForChangeNotifications(); lock (_fieldTemplateVirtualPathCache) { _fieldTemplateVirtualPathCache[cacheKey] = value; } } } private bool ContainsKey(long cacheKey) { EnsureRegisteredForChangeNotifications(); return _fieldTemplateVirtualPathCache.ContainsKey(cacheKey); } private void EnsureRegisteredForChangeNotifications() { if (!_trackFolderChanges) { return; } if (!_registeredForChangeNotifications) { lock (this) { if (!_registeredForChangeNotifications) { // Make sure the folder exists if (!VirtualPathProvider.DirectoryExists(TemplateFolderVirtualPath)) { throw new InvalidOperationException(String.Format( CultureInfo.CurrentCulture, DynamicDataResources.FieldTemplateFactory_FolderNotFound, TemplateFolderVirtualPath)); } // Register for notifications if anything in that folder changes FileChangeNotifier.Register(TemplateFolderVirtualPath, delegate(string path) { // Something has changed, so clear our cache lock (_fieldTemplateVirtualPathCache) { _fieldTemplateVirtualPathCache.Clear(); } }); _registeredForChangeNotifications = true; } } } } internal bool FileExists(string virtualPath) { #if ORYX_VNEXT // Checking file existence is tricky, because in non-updatable precompiled apps, the ascx files are not // there at all. In that case, it's still possible to check existence by calling BuildManager.GetCompiledType // and seeing if it throws, but this can cause a lot of first chance exceptions, which affect the debugging experience. // As a compromise, we only use the BuildManager.GetCompiledType code path if we're in the non-updatable precomp case. // if (!Misc.IsNonUpdatablePrecompiledApp()) return VirtualPathProvider.FileExists(virtualPath); try { BuildManager.GetCompiledType(virtualPath); } catch { return false; } return true; #else if (_usingCustomVpp) { // for unit testing return VirtualPathProvider.FileExists(virtualPath); } else { // Use GetObjectFactory instead of GetCompiledType because it will not throw, which improves the debugging experience return BuildManager.GetObjectFactory(virtualPath, /* throwIfNotFound */ false) != null; } #endif } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System.Collections; using System.Diagnostics; using System.Globalization; using System.Web.Compilation; using System.Web.Hosting; using System.Web.Resources; namespace System.Web.DynamicData { internal class TemplateFactory { // Use Hashtable instead of Dictionary<,> because it is more thread safe private Hashtable _fieldTemplateVirtualPathCache = new Hashtable(); private string _defaultLocation; private string _templateFolderVirtualPath; internal MetaModel Model { get; set; } private bool _needToResolveVirtualPath; private bool _trackFolderChanges; private bool _registeredForChangeNotifications; private VirtualPathProvider _vpp; private bool _usingCustomVpp; internal TemplateFactory(string defaultLocation) : this(defaultLocation, true) { } internal TemplateFactory(string defaultLocation, bool trackFolderChanges) { Debug.Assert(!String.IsNullOrEmpty(defaultLocation)); _defaultLocation = defaultLocation; _trackFolderChanges = trackFolderChanges; } internal string TemplateFolderVirtualPath { get { if (_templateFolderVirtualPath == null) { // If not set, set its default location TemplateFolderVirtualPath = _defaultLocation; } if (_needToResolveVirtualPath) { // Make sure it ends with a slash _templateFolderVirtualPath = VirtualPathUtility.AppendTrailingSlash(_templateFolderVirtualPath); // If it's relative, make it relative to the Model's path // Note can be null under Unit Testing if (Model != null) { _templateFolderVirtualPath = VirtualPathUtility.Combine(Model.DynamicDataFolderVirtualPath, _templateFolderVirtualPath); } _needToResolveVirtualPath = false; } return _templateFolderVirtualPath; } set { _templateFolderVirtualPath = value; // Make sure we register for change notifications, since we just got a new path _registeredForChangeNotifications = false; // It may be relative and need resolution, but let's not do it until we need it _needToResolveVirtualPath = true; } } internal VirtualPathProvider VirtualPathProvider { get { if (_vpp == null) { _vpp = HostingEnvironment.VirtualPathProvider; } return _vpp; } set { _vpp = value; _usingCustomVpp = value != null; } } internal string GetTemplatePath(long cacheKey, Func templatePathFactoryFunction) { // Check if we already have it cached string virtualPath = this[cacheKey]; // null is a valid value, so we also need to check whether the key exists if (virtualPath == null && !ContainsKey(cacheKey)) { // It's not cached, so compute it and cache it. Make sure multiple writers are serialized virtualPath = templatePathFactoryFunction(); this[cacheKey] = virtualPath; } return virtualPath; } private string this[long cacheKey] { get { EnsureRegisteredForChangeNotifications(); return (string)_fieldTemplateVirtualPathCache[cacheKey]; } set { EnsureRegisteredForChangeNotifications(); lock (_fieldTemplateVirtualPathCache) { _fieldTemplateVirtualPathCache[cacheKey] = value; } } } private bool ContainsKey(long cacheKey) { EnsureRegisteredForChangeNotifications(); return _fieldTemplateVirtualPathCache.ContainsKey(cacheKey); } private void EnsureRegisteredForChangeNotifications() { if (!_trackFolderChanges) { return; } if (!_registeredForChangeNotifications) { lock (this) { if (!_registeredForChangeNotifications) { // Make sure the folder exists if (!VirtualPathProvider.DirectoryExists(TemplateFolderVirtualPath)) { throw new InvalidOperationException(String.Format( CultureInfo.CurrentCulture, DynamicDataResources.FieldTemplateFactory_FolderNotFound, TemplateFolderVirtualPath)); } // Register for notifications if anything in that folder changes FileChangeNotifier.Register(TemplateFolderVirtualPath, delegate(string path) { // Something has changed, so clear our cache lock (_fieldTemplateVirtualPathCache) { _fieldTemplateVirtualPathCache.Clear(); } }); _registeredForChangeNotifications = true; } } } } internal bool FileExists(string virtualPath) { #if ORYX_VNEXT // Checking file existence is tricky, because in non-updatable precompiled apps, the ascx files are not // there at all. In that case, it's still possible to check existence by calling BuildManager.GetCompiledType // and seeing if it throws, but this can cause a lot of first chance exceptions, which affect the debugging experience. // As a compromise, we only use the BuildManager.GetCompiledType code path if we're in the non-updatable precomp case. // if (!Misc.IsNonUpdatablePrecompiledApp()) return VirtualPathProvider.FileExists(virtualPath); try { BuildManager.GetCompiledType(virtualPath); } catch { return false; } return true; #else if (_usingCustomVpp) { // for unit testing return VirtualPathProvider.FileExists(virtualPath); } else { // Use GetObjectFactory instead of GetCompiledType because it will not throw, which improves the debugging experience return BuildManager.GetObjectFactory(virtualPath, /* throwIfNotFound */ false) != null; } #endif } } } // 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
- AuthStoreRoleProvider.cs
- MetadataReference.cs
- BindingValueChangedEventArgs.cs
- PagerStyle.cs
- ContractInferenceHelper.cs
- webeventbuffer.cs
- MobileControlsSectionHandler.cs
- RequestQueue.cs
- DocumentPageTextView.cs
- NavigationProperty.cs
- ProfilePropertySettingsCollection.cs
- StrokeCollectionDefaultValueFactory.cs
- HtmlEncodedRawTextWriter.cs
- DelimitedListTraceListener.cs
- ImageDrawing.cs
- OdbcDataReader.cs
- ServerValidateEventArgs.cs
- SafeBitVector32.cs
- DesignOnlyAttribute.cs
- DeviceContexts.cs
- ImageSourceConverter.cs
- AppDomainGrammarProxy.cs
- ProxyFragment.cs
- GiveFeedbackEvent.cs
- Crc32Helper.cs
- xamlnodes.cs
- VirtualPathUtility.cs
- SeekStoryboard.cs
- MultilineStringConverter.cs
- LongTypeConverter.cs
- AddInController.cs
- XmlSchemaSimpleTypeRestriction.cs
- RefExpr.cs
- PeerApplicationLaunchInfo.cs
- GB18030Encoding.cs
- DataGridRowDetailsEventArgs.cs
- SQLBytesStorage.cs
- X509CertificateTokenFactoryCredential.cs
- SerializationInfo.cs
- PolicyLevel.cs
- RowVisual.cs
- WebBrowser.cs
- HttpRuntimeSection.cs
- SqlServer2KCompatibilityAnnotation.cs
- ValidatedControlConverter.cs
- DataControlCommands.cs
- SerializationException.cs
- RIPEMD160Managed.cs
- JulianCalendar.cs
- ItemList.cs
- DataGridItemEventArgs.cs
- XhtmlBasicImageAdapter.cs
- BinaryQueryOperator.cs
- XmlSchemaChoice.cs
- MessageProtectionOrder.cs
- TraceListeners.cs
- DataControlField.cs
- InternalBase.cs
- MemberPath.cs
- HtmlInputPassword.cs
- VisualBasicReference.cs
- WriterOutput.cs
- PersistenceMetadataNamespace.cs
- DrawListViewColumnHeaderEventArgs.cs
- XmlSerializerOperationFormatter.cs
- StreamReader.cs
- QueryAccessibilityHelpEvent.cs
- DbConnectionHelper.cs
- KnownTypeHelper.cs
- Geometry3D.cs
- SafeHandle.cs
- ISAPIApplicationHost.cs
- MLangCodePageEncoding.cs
- EntityCommand.cs
- Binding.cs
- RotateTransform3D.cs
- PropertyDescriptorGridEntry.cs
- ObjectStateEntryDbDataRecord.cs
- Schema.cs
- SpotLight.cs
- ValueQuery.cs
- TargetException.cs
- RangeValueProviderWrapper.cs
- NameValuePair.cs
- ComponentResourceKey.cs
- DesignerDataView.cs
- parserscommon.cs
- ResXBuildProvider.cs
- SimpleMailWebEventProvider.cs
- HtmlInputRadioButton.cs
- FixedSOMTextRun.cs
- IOException.cs
- TextTreeTextNode.cs
- BaseCodeDomTreeGenerator.cs
- CommandHelpers.cs
- shaperfactoryquerycachekey.cs
- EventToken.cs
- COM2ExtendedUITypeEditor.cs
- __Error.cs
- TextRunCache.cs