You've already forked linux-packaging-mono
Imported Upstream version 6.0.0.172
Former-commit-id: f3cc9b82f3e5bd8f0fd3ebc098f789556b44e9cd
This commit is contained in:
parent
8016999e4d
commit
64ac736ec5
275
mcs/class/corlib/System.Reflection/RuntimeAssembly.cs
Normal file
275
mcs/class/corlib/System.Reflection/RuntimeAssembly.cs
Normal file
@ -0,0 +1,275 @@
|
||||
//
|
||||
// System.Reflection/RuntimeAssembly.cs
|
||||
//
|
||||
// Author:
|
||||
// Rodrigo Kumpera (rkumpera@novell.com)
|
||||
//
|
||||
// Copyright (C) 2010 Novell, Inc (http://www.novell.com)
|
||||
//
|
||||
// Permission is hereby granted, free of charge, to any person obtaining
|
||||
// a copy of this software and associated documentation files (the
|
||||
// "Software"), to deal in the Software without restriction, including
|
||||
// without limitation the rights to use, copy, modify, merge, publish,
|
||||
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||
// permit persons to whom the Software is furnished to do so, subject to
|
||||
// the following conditions:
|
||||
//
|
||||
// The above copyright notice and this permission notice shall be
|
||||
// included in all copies or substantial portions of the Software.
|
||||
//
|
||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
//
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Globalization;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Runtime.CompilerServices;
|
||||
#if !FULL_AOT_RUNTIME
|
||||
using System.Reflection.Emit;
|
||||
#endif
|
||||
using System.Collections.Generic;
|
||||
using System.Runtime.Serialization;
|
||||
using System.Threading;
|
||||
using System.Diagnostics.Contracts;
|
||||
using System.Security;
|
||||
using System.Security.Policy;
|
||||
using System.Security.Permissions;
|
||||
|
||||
using Mono;
|
||||
|
||||
namespace System.Reflection {
|
||||
|
||||
[ComVisible (true)]
|
||||
[ComDefaultInterfaceAttribute (typeof (_Assembly))]
|
||||
[Serializable]
|
||||
[ClassInterface(ClassInterfaceType.None)]
|
||||
class RuntimeAssembly : Assembly
|
||||
{
|
||||
public override void GetObjectData (SerializationInfo info, StreamingContext context)
|
||||
{
|
||||
if (info == null)
|
||||
throw new ArgumentNullException ("info");
|
||||
|
||||
UnitySerializationHolder.GetUnitySerializationInfo (info,
|
||||
UnitySerializationHolder.AssemblyUnity,
|
||||
this.FullName,
|
||||
this);
|
||||
}
|
||||
|
||||
internal static RuntimeAssembly GetExecutingAssembly (ref StackCrawlMark stackMark)
|
||||
{
|
||||
// Mono runtime does not support StackCrawlMark, The easiest workaround is to replace use
|
||||
// of StackCrawlMark.LookForMyCaller with GetCallingAssembly
|
||||
throw new NotSupportedException ();
|
||||
}
|
||||
|
||||
// Creates AssemblyName. Fills assembly if AssemblyResolve event has been raised.
|
||||
[System.Security.SecurityCritical] // auto-generated
|
||||
internal static AssemblyName CreateAssemblyName(
|
||||
String assemblyString,
|
||||
bool forIntrospection,
|
||||
out RuntimeAssembly assemblyFromResolveEvent)
|
||||
{
|
||||
if (assemblyString == null)
|
||||
throw new ArgumentNullException("assemblyString");
|
||||
Contract.EndContractBlock();
|
||||
|
||||
if ((assemblyString.Length == 0) ||
|
||||
(assemblyString[0] == '\0'))
|
||||
throw new ArgumentException(Environment.GetResourceString("Format_StringZeroLength"));
|
||||
|
||||
if (forIntrospection)
|
||||
AppDomain.CheckReflectionOnlyLoadSupported();
|
||||
|
||||
AssemblyName an = new AssemblyName();
|
||||
|
||||
an.Name = assemblyString;
|
||||
assemblyFromResolveEvent = null; // instead of an.nInit(out assemblyFromResolveEvent, forIntrospection, true);
|
||||
return an;
|
||||
}
|
||||
|
||||
internal static RuntimeAssembly InternalLoadAssemblyName(
|
||||
AssemblyName assemblyRef,
|
||||
Evidence assemblySecurity,
|
||||
RuntimeAssembly reqAssembly,
|
||||
ref StackCrawlMark stackMark,
|
||||
#if FEATURE_HOSTED_BINDER
|
||||
IntPtr pPrivHostBinder,
|
||||
#endif
|
||||
bool throwOnFileNotFound,
|
||||
bool forIntrospection,
|
||||
bool suppressSecurityChecks)
|
||||
{
|
||||
if (assemblyRef == null)
|
||||
throw new ArgumentNullException("assemblyRef");
|
||||
Contract.EndContractBlock();
|
||||
|
||||
if (assemblyRef.CodeBase != null)
|
||||
{
|
||||
AppDomain.CheckLoadFromSupported();
|
||||
}
|
||||
|
||||
assemblyRef = (AssemblyName)assemblyRef.Clone();
|
||||
#if FEATURE_VERSIONING
|
||||
if (!forIntrospection &&
|
||||
(assemblyRef.ProcessorArchitecture != ProcessorArchitecture.None)) {
|
||||
// PA does not have a semantics for by-name binds for execution
|
||||
assemblyRef.ProcessorArchitecture = ProcessorArchitecture.None;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (assemblySecurity != null)
|
||||
{
|
||||
#if FEATURE_CAS_POLICY
|
||||
if (!AppDomain.CurrentDomain.IsLegacyCasPolicyEnabled)
|
||||
{
|
||||
throw new NotSupportedException(Environment.GetResourceString("NotSupported_RequiresCasPolicyImplicit"));
|
||||
}
|
||||
#endif // FEATURE_CAS_POLICY
|
||||
|
||||
if (!suppressSecurityChecks)
|
||||
{
|
||||
#if MONO_FEATURE_CAS
|
||||
#pragma warning disable 618
|
||||
new SecurityPermission(SecurityPermissionFlag.ControlEvidence).Demand();
|
||||
#pragma warning restore 618
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
return (RuntimeAssembly) Assembly.Load (assemblyRef);
|
||||
}
|
||||
|
||||
internal static RuntimeAssembly LoadWithPartialNameInternal (String partialName, Evidence securityEvidence, ref StackCrawlMark stackMark)
|
||||
{
|
||||
// Mono runtime does not support StackCrawlMark
|
||||
//FIXME stackMark should probably change method behavior in some cases.
|
||||
return (RuntimeAssembly) Assembly.LoadWithPartialName (partialName, securityEvidence);
|
||||
}
|
||||
|
||||
internal static RuntimeAssembly LoadWithPartialNameInternal (AssemblyName an, Evidence securityEvidence, ref StackCrawlMark stackMark)
|
||||
{
|
||||
return LoadWithPartialNameInternal (an.ToString (), securityEvidence, ref stackMark);
|
||||
}
|
||||
|
||||
// the security runtime requires access to the assemblyname (e.g. to get the strongname)
|
||||
public override AssemblyName GetName (bool copiedName)
|
||||
{
|
||||
|
||||
#if !MOBILE
|
||||
// CodeBase, which is restricted, will be copied into the AssemblyName object so...
|
||||
if (SecurityManager.SecurityEnabled) {
|
||||
var _ = CodeBase; // this will ensure the Demand is made
|
||||
}
|
||||
#endif
|
||||
return AssemblyName.Create (this, true);
|
||||
}
|
||||
|
||||
public
|
||||
override
|
||||
Type GetType (string name, bool throwOnError, bool ignoreCase)
|
||||
{
|
||||
Type res;
|
||||
if (name == null)
|
||||
throw new ArgumentNullException (name);
|
||||
if (name.Length == 0)
|
||||
throw new ArgumentException ("name", "Name cannot be empty");
|
||||
|
||||
res = InternalGetType (null, name, throwOnError, ignoreCase);
|
||||
return res;
|
||||
}
|
||||
|
||||
public
|
||||
override
|
||||
Module GetModule (String name)
|
||||
{
|
||||
if (name == null)
|
||||
throw new ArgumentNullException ("name");
|
||||
if (name.Length == 0)
|
||||
throw new ArgumentException ("Name can't be empty");
|
||||
|
||||
Module[] modules = GetModules (true);
|
||||
foreach (Module module in modules) {
|
||||
if (module.ScopeName == name)
|
||||
return module;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public
|
||||
override
|
||||
AssemblyName[] GetReferencedAssemblies () {
|
||||
return GetReferencedAssemblies (this);
|
||||
}
|
||||
|
||||
public
|
||||
override
|
||||
Module[] GetModules (bool getResourceModules) {
|
||||
Module[] modules = GetModulesInternal ();
|
||||
|
||||
if (!getResourceModules) {
|
||||
var result = new List<Module> (modules.Length);
|
||||
foreach (Module m in modules)
|
||||
if (!m.IsResource ())
|
||||
result.Add (m);
|
||||
return result.ToArray ();
|
||||
}
|
||||
else
|
||||
return modules;
|
||||
}
|
||||
|
||||
[MonoTODO ("Always returns the same as GetModules")]
|
||||
public
|
||||
override
|
||||
Module[] GetLoadedModules (bool getResourceModules)
|
||||
{
|
||||
return GetModules (getResourceModules);
|
||||
}
|
||||
|
||||
[MethodImplAttribute(MethodImplOptions.NoInlining)] // Methods containing StackCrawlMark local var has to be marked non-inlineable
|
||||
public
|
||||
override
|
||||
Assembly GetSatelliteAssembly (CultureInfo culture)
|
||||
{
|
||||
StackCrawlMark stackMark = StackCrawlMark.LookForMyCaller;
|
||||
return GetSatelliteAssembly (culture, null, true, ref stackMark);
|
||||
}
|
||||
|
||||
[MethodImplAttribute(MethodImplOptions.NoInlining)] // Methods containing StackCrawlMark local var has to be marked non-inlineable
|
||||
public
|
||||
override
|
||||
Assembly GetSatelliteAssembly (CultureInfo culture, Version version)
|
||||
{
|
||||
StackCrawlMark stackMark = StackCrawlMark.LookForMyCaller;
|
||||
return GetSatelliteAssembly (culture, version, true, ref stackMark);
|
||||
}
|
||||
|
||||
//FIXME remove GetManifestModule under v4, it's a v2 artifact
|
||||
[ComVisible (false)]
|
||||
public
|
||||
override
|
||||
Module ManifestModule {
|
||||
get {
|
||||
return GetManifestModule ();
|
||||
}
|
||||
}
|
||||
|
||||
public
|
||||
override
|
||||
bool GlobalAssemblyCache {
|
||||
get {
|
||||
return get_global_assembly_cache ();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user