Code:
/ DotNET / DotNET / 8.0 / untmp / whidbey / REDBITS / ndp / fx / src / xsp / System / Web / UI / UserControl.cs / 1 / UserControl.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
/*
* Page class definition
*
* Copyright (c) 1998 Microsoft Corporation
*/
namespace System.Web.UI {
using System;
using System.ComponentModel;
using System.ComponentModel.Design;
using System.ComponentModel.Design.Serialization;
using System.Web.SessionState;
using System.Web.Caching;
using System.Security.Permissions;
using System.Web.Util;
///
/// The ControlBuilder associated with a UserControl. If you want a custom ControlBuilder for your
/// derived UserControl, you should derive it from UserControlControlBuilder.
///
///
[AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)]
public class UserControlControlBuilder : ControlBuilder {
private string _innerText;
///
public override object BuildObject() {
object o = base.BuildObject();
if (InDesigner) {
IUserControlDesignerAccessor designerAccessor = (IUserControlDesignerAccessor)o;
designerAccessor.TagName = TagName;
if (_innerText != null) {
designerAccessor.InnerText = _innerText;
}
}
return o;
}
///
public override bool NeedsTagInnerText() {
// in design-mode, we need to hang on to the inner text
return InDesigner;
}
///
public override void SetTagInnerText(string text) {
Debug.Assert(InDesigner == true, "Should only be called in design-mode!");
_innerText = text;
}
}
///
/// Default ControlBuilder used to parse user controls files.
///
[AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)]
public class FileLevelUserControlBuilder: RootBuilder {
}
///
/// This class is not marked as abstract, because the VS designer
/// needs to instantiate it when opening .ascx files
///
[
ControlBuilder(typeof(UserControlControlBuilder)),
DefaultEvent("Load"),
Designer("System.Web.UI.Design.UserControlDesigner, " + AssemblyRef.SystemDesign, typeof(IDesigner)),
Designer("Microsoft.VisualStudio.Web.WebForms.WebFormDesigner, " + AssemblyRef.MicrosoftVisualStudioWeb, typeof(IRootDesigner)),
DesignerCategory("ASPXCodeBehind"),
DesignerSerializer("Microsoft.VisualStudio.Web.WebForms.WebFormCodeDomSerializer, " + AssemblyRef.MicrosoftVisualStudioWeb, "System.ComponentModel.Design.Serialization.TypeCodeDomSerializer, " + AssemblyRef.SystemDesign),
ParseChildren(true),
ToolboxItem(false)
]
[AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)]
public class UserControl : TemplateControl, IAttributeAccessor, INonBindingContainer, IUserControlDesignerAccessor {
private StateBag attributeStorage;
private AttributeCollection attributes;
private bool _fUserControlInitialized;
///
/// Gets the collection of attribute name/value pairs expressed on a UserControl but
/// not supported by the control's strongly typed properties.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public AttributeCollection Attributes {
get {
if (attributes == null) {
if (attributeStorage == null) {
attributeStorage = new StateBag(true);
if (IsTrackingViewState) {
attributeStorage.TrackViewState();
}
}
attributes = new AttributeCollection(attributeStorage);
}
return attributes;
}
}
// Delegate most things to the Page
///
/// Gets the object provided by
/// the HTTP Runtime.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public HttpApplicationState Application { get { return Page.Application;} }
/*
* Trace context for output of useful information to page during development
*/
///
/// Indicates the object for the current Web
/// request. Tracing tracks and presents the execution details about a Web request.
/// For trace data to be visible in a rendered page, you must turn tracing on for
/// that page. This property is read-only.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public TraceContext Trace { get { return Page.Trace; } }
///
///
/// Gets the object provided by the HTTP Runtime, which
/// allows developers to access data from incoming HTTP requests.
///
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public HttpRequest Request { get { return Page.Request; } }
///
/// Gets the object provided by the HTTP Runtime, which
/// allows developers to send HTTP response data to a client browser.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public HttpResponse Response { get { return Page.Response; } }
///
/// Gets the ASP-compatible object.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public HttpServerUtility Server { get { return Page.Server; } }
/*
* Cache intrinsic
*/
///
/// Retrieves a
/// object in which to store the user control's data for
/// subsequent requests. This property is read-only.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public Cache Cache { get { return Page.Cache; } }
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public ControlCachePolicy CachePolicy {
get {
// Check if we're inside a PartialCachingControl
BasePartialCachingControl pcc = Parent as BasePartialCachingControl;
// If so, return its CachePolicy
if (pcc != null)
return pcc.CachePolicy;
// Otherwise, return a stub, which returns SupportsCaching==false and throws
// on everything else.
return ControlCachePolicy.GetCachePolicyStub();
}
}
///
/// Gets a value indicating whether the user control is being loaded in response to a
/// client postback, or if it is being loaded and accessed for the first time.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public bool IsPostBack { get { return Page.IsPostBack; } }
///
/// Gets the object provided by the HTTP Runtime.
///
[
Browsable(false),
DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
]
public HttpSessionState Session { get { return Page.Session; } }
/*
* Performs intialization of the control required by the designer.
*/
///
/// Performs any initialization of the control that is required by RAD designers.
///
[EditorBrowsable(EditorBrowsableState.Never)]
public void DesignerInitialize() {
InitRecursive(null);
}
///
/// [To be supplied.]
///
protected internal override void OnInit(EventArgs e) {
// We want to avoid calling this when the user control is being used in the designer,
// regardless of whether it is a top-level control (DesignMode == true),
// or if its inside another control in design-mode (Page.Site.DesignMode == true)
bool designTime = DesignMode;
if (designTime == false) {
if ((Page != null) && (Page.Site != null)) {
designTime = Page.Site.DesignMode;
}
}
if (designTime == false) {
InitializeAsUserControlInternal();
}
base.OnInit(e);
}
/*
* Called on declarative controls to initialize them correctly
*/
///
/// Initializes the object. Since there are some
/// differences between pages and user controls, this method makes sure that the
/// user control is initialized properly.
///
[EditorBrowsable(EditorBrowsableState.Never)]
public void InitializeAsUserControl(Page page) {
_page = page;
InitializeAsUserControlInternal();
}
internal void InitializeAsUserControlInternal() {
// Make sure we only do this once
if (_fUserControlInitialized)
return;
_fUserControlInitialized = true;
// Hook up any automatic handler we may find (e.g. Page_Load)
HookUpAutomaticHandlers();
// Initialize the object and instantiate all the controls defined in the ascx file
FrameworkInitialize();
}
protected override void LoadViewState(object savedState) {
if (savedState != null) {
Pair myState = (Pair)savedState;
base.LoadViewState(myState.First);
if (myState.Second != null) {
if (attributeStorage == null) {
attributeStorage = new StateBag(true);
attributeStorage.TrackViewState();
}
attributeStorage.LoadViewState(myState.Second);
}
}
}
protected override object SaveViewState() {
Pair myState = null;
object baseState = base.SaveViewState();
object attrState = null;
if (attributeStorage != null) {
attrState = attributeStorage.SaveViewState();
}
if (baseState != null || attrState != null) {
myState = new Pair(baseState, attrState);
}
return myState;
}
///
///
/// Returns the attribute value of the UserControl having
/// the specified attribute name.
///
string IAttributeAccessor.GetAttribute(string name) {
return ((attributeStorage != null) ? (string)attributeStorage[name] : null);
}
///
///
/// Sets an attribute of the UserControl with the specified
/// name and value.
///
void IAttributeAccessor.SetAttribute(string name, string value) {
Attributes[name] = value;
}
/*
* Map virtual path (absolute or relative) to physical path
*/
///
/// Assigns a virtual path, either absolute or relative, to a physical path.
///
public string MapPath(string virtualPath) {
return Request.MapPath(VirtualPath.CreateAllowNull(virtualPath), TemplateControlVirtualDirectory,
true/*allowCrossAppMapping*/);
}
///
string IUserControlDesignerAccessor.TagName {
get {
string text = (string)ViewState["!DesignTimeTagName"];
if (text == null) {
return String.Empty;
}
return text;
}
set {
ViewState["!DesignTimeTagName"] = value;
}
}
///
string IUserControlDesignerAccessor.InnerText {
get {
string text = (string)ViewState["!DesignTimeInnerText"];
if (text == null) {
return String.Empty;
}
return text;
}
set {
ViewState["!DesignTimeInnerText"] = value;
}
}
}
}
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ObjectTag.cs
- ModuleElement.cs
- SettingsPropertyIsReadOnlyException.cs
- CollectionViewProxy.cs
- WebServiceReceive.cs
- CellQuery.cs
- MarkupObject.cs
- UserControlBuildProvider.cs
- Transform3DCollection.cs
- LineMetrics.cs
- TimeEnumHelper.cs
- RoleProviderPrincipal.cs
- IisTraceWebEventProvider.cs
- RecordBuilder.cs
- ChangeInterceptorAttribute.cs
- EventListener.cs
- UnionCqlBlock.cs
- DriveInfo.cs
- ConfigXmlText.cs
- XmlEntityReference.cs
- LinkArea.cs
- DataGridLength.cs
- XhtmlBasicPhoneCallAdapter.cs
- CharAnimationUsingKeyFrames.cs
- AnnotationDocumentPaginator.cs
- PointHitTestParameters.cs
- OdbcTransaction.cs
- DictionaryEntry.cs
- TextBoxAutoCompleteSourceConverter.cs
- QuarticEase.cs
- StylusPointCollection.cs
- ManagedIStream.cs
- CodeGroup.cs
- Comparer.cs
- RangeValidator.cs
- TransactionState.cs
- DrawingContextDrawingContextWalker.cs
- DashStyle.cs
- FigureParaClient.cs
- WebPageTraceListener.cs
- CreateBookmarkScope.cs
- ButtonBase.cs
- SizeConverter.cs
- RadioButton.cs
- RewritingSimplifier.cs
- NavigationWindow.cs
- Help.cs
- CryptoConfig.cs
- XPathNodePointer.cs
- TreeViewDesigner.cs
- XamlInt32CollectionSerializer.cs
- DataListCommandEventArgs.cs
- OdbcInfoMessageEvent.cs
- EventPrivateKey.cs
- ValidationHelper.cs
- DispatcherExceptionFilterEventArgs.cs
- Line.cs
- ClientConfigurationSystem.cs
- HttpDictionary.cs
- LinqDataSourceValidationException.cs
- OutputCacheSettings.cs
- MimeWriter.cs
- PropertyItemInternal.cs
- HtmlElementEventArgs.cs
- MergeExecutor.cs
- DefaultCommandConverter.cs
- TemplateGroupCollection.cs
- Stacktrace.cs
- WebControlsSection.cs
- PolicyManager.cs
- TransactionBehavior.cs
- WorkflowViewService.cs
- OperationSelectorBehavior.cs
- EncryptedPackageFilter.cs
- NativeCompoundFileAPIs.cs
- X509WindowsSecurityToken.cs
- HelpKeywordAttribute.cs
- Compiler.cs
- CheckableControlBaseAdapter.cs
- IndexOutOfRangeException.cs
- SafeHandle.cs
- SynchronizedInputProviderWrapper.cs
- RTLAwareMessageBox.cs
- TreeNodeEventArgs.cs
- PerformanceCounterPermissionEntryCollection.cs
- OutgoingWebRequestContext.cs
- SqlProviderServices.cs
- MSG.cs
- KnownTypes.cs
- Vector3DAnimationBase.cs
- GenericTypeParameterBuilder.cs
- Permission.cs
- DiscoveryClient.cs
- _Events.cs
- UnsafeNetInfoNativeMethods.cs
- StringBuilder.cs
- TypeUtils.cs
- Roles.cs
- TdsRecordBufferSetter.cs
- ZipIOLocalFileBlock.cs