Update
This commit is contained in:
parent
ddc6db59a1
commit
86237eb31d
@ -56,10 +56,10 @@ namespace SkinHide
|
|||||||
new PlayerModelViewPatch().Enable();
|
new PlayerModelViewPatch().Enable();
|
||||||
new PlayerPatch().Enable();
|
new PlayerPatch().Enable();
|
||||||
|
|
||||||
ReflectionDatas.RefSlotViews = RefHelp.FieldRef<PlayerBody, object>.Create("SlotViews");
|
ReflectionDatas.RefSlotViews = RefHelp.FieldRef<PlayerBody, object>.Create(new string[] { "SlotViews" });
|
||||||
ReflectionDatas.RefSlotList = RefHelp.FieldRef<object, IEnumerable<object>>.Create(ReflectionDatas.RefSlotViews.FieldType, "list_0");
|
ReflectionDatas.RefSlotList = RefHelp.FieldRef<object, IEnumerable<object>>.Create(ReflectionDatas.RefSlotViews.FieldType, new string[] { "list_0" });
|
||||||
ReflectionDatas.RefDresses = RefHelp.FieldRef<object, Dress[]>.Create(ReflectionDatas.RefSlotList.FieldType.GetGenericArguments()[0], "Dresses");
|
ReflectionDatas.RefDresses = RefHelp.FieldRef<object, Dress[]>.Create(ReflectionDatas.RefSlotList.FieldType.GetGenericArguments()[0], new string[] { "Dresses" });
|
||||||
ReflectionDatas.RefRenderers = RefHelp.FieldRef<Dress, Renderer[]>.Create("Renderers");
|
ReflectionDatas.RefRenderers = RefHelp.FieldRef<Dress, Renderer[]>.Create(new string[] { "Renderers" });
|
||||||
}
|
}
|
||||||
|
|
||||||
void Update()
|
void Update()
|
||||||
|
@ -139,12 +139,24 @@ namespace SkinHide.Utils
|
|||||||
|
|
||||||
public PropertyRef(PropertyInfo propertyinfo, object instance = null)
|
public PropertyRef(PropertyInfo propertyinfo, object instance = null)
|
||||||
{
|
{
|
||||||
|
if (propertyinfo == null)
|
||||||
|
{
|
||||||
|
throw new Exception("PropertyInfo is null");
|
||||||
|
}
|
||||||
|
|
||||||
Init(propertyinfo, instance);
|
Init(propertyinfo, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PropertyRef(Type type, string propertyname, object instance = null)
|
public PropertyRef(Type type, string[] propertynames, object instance = null)
|
||||||
{
|
{
|
||||||
Init(type.GetProperty(propertyname, AccessTools.all), instance);
|
PropertyInfo propertyInfo = propertynames.Select(x => type.GetProperty(x, AccessTools.all)).FirstOrDefault(x => x != null);
|
||||||
|
|
||||||
|
if (propertyInfo == null)
|
||||||
|
{
|
||||||
|
throw new Exception(propertynames.First() + " is null");
|
||||||
|
}
|
||||||
|
|
||||||
|
Init(propertyInfo, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Init(PropertyInfo propertyinfo, object instance)
|
private void Init(PropertyInfo propertyinfo, object instance)
|
||||||
@ -179,14 +191,14 @@ namespace SkinHide.Utils
|
|||||||
return new PropertyRef<T, F>(propertyinfo, instance);
|
return new PropertyRef<T, F>(propertyinfo, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PropertyRef<T, F> Create(string propertyname, object instance = null)
|
public static PropertyRef<T, F> Create(string[] propertynames, object instance = null)
|
||||||
{
|
{
|
||||||
return new PropertyRef<T, F>(typeof(T), propertyname, instance);
|
return new PropertyRef<T, F>(typeof(T), propertynames, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PropertyRef<T, F> Create(Type type, string propertyname, object instance = null)
|
public static PropertyRef<T, F> Create(Type type, string[] propertynames, object instance = null)
|
||||||
{
|
{
|
||||||
return new PropertyRef<T, F>(type, propertyname, instance);
|
return new PropertyRef<T, F>(type, propertynames, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public F GetValue(T instance)
|
public F GetValue(T instance)
|
||||||
@ -244,12 +256,24 @@ namespace SkinHide.Utils
|
|||||||
|
|
||||||
public FieldRef(FieldInfo fieldinfo, object instance = null)
|
public FieldRef(FieldInfo fieldinfo, object instance = null)
|
||||||
{
|
{
|
||||||
|
if (fieldinfo == null)
|
||||||
|
{
|
||||||
|
throw new Exception("FieldInfo is null");
|
||||||
|
}
|
||||||
|
|
||||||
Init(fieldinfo, instance);
|
Init(fieldinfo, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public FieldRef(Type type, string fieldname, object instance = null)
|
public FieldRef(Type type, string[] fieldnames, object instance = null)
|
||||||
{
|
{
|
||||||
Init(type.GetField(fieldname, AccessTools.all), instance);
|
FieldInfo fieldInfo = fieldnames.Select(x => type.GetField(x, AccessTools.all)).FirstOrDefault(x => x != null);
|
||||||
|
|
||||||
|
if (fieldInfo == null)
|
||||||
|
{
|
||||||
|
throw new Exception(fieldnames.First() + " is null");
|
||||||
|
}
|
||||||
|
|
||||||
|
Init(fieldInfo, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FieldRef<T, F> Create(FieldInfo fieldinfo, object instance = null)
|
public static FieldRef<T, F> Create(FieldInfo fieldinfo, object instance = null)
|
||||||
@ -257,14 +281,14 @@ namespace SkinHide.Utils
|
|||||||
return new FieldRef<T, F>(fieldinfo, instance);
|
return new FieldRef<T, F>(fieldinfo, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FieldRef<T, F> Create(string fieldname, object instance = null)
|
public static FieldRef<T, F> Create(string[] fieldnames, object instance = null)
|
||||||
{
|
{
|
||||||
return new FieldRef<T, F>(typeof(T), fieldname, instance);
|
return new FieldRef<T, F>(typeof(T), fieldnames, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FieldRef<T, F> Create(Type type, string fieldname, object instance = null)
|
public static FieldRef<T, F> Create(Type type, string[] fieldnames, object instance = null)
|
||||||
{
|
{
|
||||||
return new FieldRef<T, F>(type, fieldname, instance);
|
return new FieldRef<T, F>(type, fieldnames, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Init(FieldInfo fieldinfo, object instance = null)
|
private void Init(FieldInfo fieldinfo, object instance = null)
|
||||||
@ -336,4 +360,5 @@ namespace SkinHide.Utils
|
|||||||
return GetEftMethod(GetEftType(func), flags, func2);
|
return GetEftMethod(GetEftType(func), flags, func2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user