File: system\reflection\emit\modulebuilderdata.cs
Project: ndp\clr\src\bcl\mscorlib.csproj (mscorlib)
// ==++==
// 
//   Copyright (c) Microsoft Corporation.  All rights reserved.
// 
// ==--==
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
// <OWNER>Microsoft</OWNER>
// 
 
namespace System.Reflection.Emit
{
    using System;
    using System.Diagnostics.Contracts;
    using System.Globalization;
    using System.IO;
    using System.Reflection;
    using System.Runtime.Versioning;
 
    // This is a package private class. This class hold all of the managed
    // data member for ModuleBuilder. Note that what ever data members added to
    // this class cannot be accessed from the EE.
    [Serializable]
    internal class ModuleBuilderData
    {
        [System.Security.SecurityCritical]  // auto-generated
        [ResourceExposure(ResourceScope.Machine)]
        [ResourceConsumption(ResourceScope.Machine)]
        internal ModuleBuilderData(ModuleBuilder module, String strModuleName, String strFileName, int tkFile)
        {
            m_globalTypeBuilder = new TypeBuilder(module);
            m_module = module;
            m_tkFile = tkFile;
 
            InitNames(strModuleName, strFileName);
        }
 
        // Initialize module and file names.
        [System.Security.SecurityCritical]  // auto-generated
        [ResourceExposure(ResourceScope.Machine)]
        [ResourceConsumption(ResourceScope.Machine)]
        private void InitNames(String strModuleName, String strFileName)
        {
            m_strModuleName = strModuleName;
            if (strFileName == null)
            {
                // fake a transient module file name
                m_strFileName = strModuleName;
            }
            else
            {
                String strExtension = Path.GetExtension(strFileName);
                if (strExtension == null || strExtension == String.Empty)
                {
                    // This is required by our loader. It cannot load module file that does not have file extension.
                    throw new ArgumentException(Environment.GetResourceString("Argument_NoModuleFileExtension", strFileName));
                }
                m_strFileName = strFileName;
            }
        }
 
        // This is a method for changing module and file name of the manifest module (created by default for 
        // each assembly).
        [System.Security.SecurityCritical]  // auto-generated
        [ResourceExposure(ResourceScope.Machine)]
        [ResourceConsumption(ResourceScope.Machine)]
        internal virtual void ModifyModuleName(String strModuleName)
        {
            Contract.Assert(m_strModuleName == AssemblyBuilder.MANIFEST_MODULE_NAME, "Changing names for non-manifest module");
            InitNames(strModuleName, null /*strFileName*/);
        }
 
        internal int FileToken
        {
            get
            {
                // Before save, the scope of m_tkFile is the in-memory assembly manifest
                // During save, the scope of m_tkFile is the on-disk assembly manifest
                // For transient modules m_tkFile never change. 
 
                // Theoretically no one should emit anything after a dynamic assembly has
                // been saved. So m_tkFile shouldn't used when m_isSaved is true.
                // But that was never completely enforced: you can still emit everything after 
                // the assembly has been saved (except for public types in persistent modules).
 
                return m_tkFile;
            }
 
            set
            {
                m_tkFile = value;
            }
        }
 
        internal String        m_strModuleName;     // scope name (can be different from file name)
        internal String        m_strFileName;
        internal bool          m_fGlobalBeenCreated;
        internal bool          m_fHasGlobal;   
        [NonSerialized]
        internal TypeBuilder   m_globalTypeBuilder;
        [NonSerialized]
        internal ModuleBuilder m_module;
 
        private int            m_tkFile;
        internal bool          m_isSaved;
        [NonSerialized]
        internal ResWriterData m_embeddedRes;
        internal const String MULTI_BYTE_VALUE_CLASS = "$ArrayType$";
        internal String        m_strResourceFileName;
        internal byte[]        m_resourceBytes;
    } // class ModuleBuilderData
}