Ignore:
Timestamp:
Aug 2, 2017, 6:46:15 PM (7 years ago)
Author:
alloc
Message:

Fixes update A16.2

Location:
binary-improvements/7dtd-server-fixes
Files:
1 deleted
6 edited

Legend:

Unmodified
Added
Removed
  • binary-improvements/7dtd-server-fixes/7dtd-server-fixes.csproj

    r279 r306  
    8383    <Compile Include="src\JSON\JSONNull.cs" />
    8484    <Compile Include="src\JSON\MalformedJSONException.cs" />
    85     <Compile Include="src\ItemList.cs" />
    8685    <Compile Include="src\FileCache\AbstractCache.cs" />
    8786    <Compile Include="src\FileCache\DirectAccess.cs" />
  • binary-improvements/7dtd-server-fixes/ModInfo.xml

    r300 r306  
    55                <Description value="Common functions" />
    66                <Author value="Christian 'Alloc' Illy" />
    7                 <Version value="14" />
     7                <Version value="15" />
    88                <Website value="http://7dtd.illy.bz" />
    99        </ModInfo>
  • binary-improvements/7dtd-server-fixes/src/JSON/JSONString.cs

    r279 r306  
    3333                                        case '\\':
    3434                                        case '"':
    35                                         case '/':
     35//                                      case '/':
    3636                                                sb.Append ('\\');
    3737                                                sb.Append (c);
  • binary-improvements/7dtd-server-fixes/src/LiveData/Animals.cs

    r252 r306  
    66    public class Animals
    77    {
    8         public static List<EntityAnimal> List {
    9             get {
    10                 List<EntityAnimal> lst = new List<EntityAnimal> ();
     8                public static void Get (List<EntityAnimal> _list) {
     9                        _list.Clear ();
     10                        try {
     11                                List<Entity> entities = GameManager.Instance.World.Entities.list;
     12                                for (int i = 0; i < entities.Count; i++) {
     13                                        Entity entity = entities [i];
    1114
    12                 try {
    13                     foreach (object base_entity in GameManager.Instance.World.Entities.list) {
    14                         try {
    15                             Entity entity = (Entity)base_entity;
     15                                        // Kind of hack-ish, but the game is legitimately setting the base type of animals ('entityType') to enum 0 ('EntityType.Unknown').
     16                                        if ((entity.entityType == EntityType.Animal) || (entity is EntityAnimal)) {
     17                                                EntityAnimal ea = (EntityAnimal)entity;
    1618
    17                             // Kind of hack-ish, but the game is legitimately setting the base type of animals ('entityType') to enum 0 ('EntityType.Unknown').
    18                             if ((entity.entityType == EntityType.Animal) || (base_entity.GetType ().ToString ().ToLower ().Contains ("animal"))) {
    19                                 EntityAnimal ea = (EntityAnimal)entity;
     19                                                if (ea.IsAlive ())
     20                                                        _list.Add (ea);
     21                                        }
     22                                }
     23                        }
     24                        catch (Exception e) {
     25                                Log.Exception (e);
     26                        }
     27                }
    2028
    21                                 if (ea.IsAlive ())
    22                                     lst.Add (ea);
    23                             }
    24                         }
    25                         catch { }
    26                     }
    27                 }
    28                 catch { }
     29                public static int GetCount () {
     30                        int count = 0;
     31                        try {
     32                                List<Entity> entities = GameManager.Instance.World.Entities.list;
     33                                for (int i = 0; i < entities.Count; i++) {
     34                                        Entity entity = entities [i];
    2935
    30                 return lst;
    31             }
    32         }
     36                                        // Kind of hack-ish, but the game is legitimately setting the base type of animals ('entityType') to enum 0 ('EntityType.Unknown').
     37                                        if ((entity.entityType == EntityType.Animal) || (entity is EntityAnimal)) {
     38                                                EntityAnimal ea = (EntityAnimal)entity;
    3339
     40                                                if (ea.IsAlive ())
     41                                                        count++;
     42                                        }
     43                                }
     44                        }
     45                        catch (Exception e) {
     46                                Log.Exception (e);
     47                        }
     48                        return count;
     49                }
    3450
    35         public static int Count {
    36             get { return List.Count; }
    37         }
    3851    }
    3952}
  • binary-improvements/7dtd-server-fixes/src/LiveData/Hostiles.cs

    r252 r306  
    44namespace AllocsFixes.LiveData
    55{
    6     public class Hostiles
    7     {
    8         public static List<EntityEnemy> List {
    9             get {
    10                 List<EntityEnemy> lst = new List<EntityEnemy> ();
     6        public class Hostiles
     7        {
     8                public static void Get (List<EntityEnemy> _list) {
     9                        _list.Clear ();
     10                        try {
     11                                List<Entity> entities = GameManager.Instance.World.Entities.list;
     12                                for (int i = 0; i < entities.Count; i++) {
     13                                        Entity entity = entities [i];
    1114
    12                 try {
    13                     foreach (int ent_id in GameManager.Instance.World.Entities.dict.Keys) {
    14                         try {
    15                             Entity entity = GameManager.Instance.World.Entities.dict [ent_id];
     15                                        if (entity is EntityEnemy) {
     16                                                if (entity.IsAlive ())
     17                                                        _list.Add (entity as EntityEnemy);
     18                                        }
     19                                }
     20                        }
     21                        catch (Exception e) {
     22                                Log.Exception (e);
     23                        }
     24                }
    1625
    17                             if (entity.entityType == EntityType.Zombie) {
    18                                 EntityEnemy ee = (EntityEnemy)entity;
     26                public static int GetCount () {
     27                        int count = 0;
     28                        try {
     29                                List<Entity> entities = GameManager.Instance.World.Entities.list;
     30                                for (int i = 0; i < entities.Count; i++) {
     31                                        Entity entity = entities [i];
    1932
    20                                 if (ee.IsAlive ())
    21                                     lst.Add (ee);
    22                             }
    23                         }
    24                         catch { }
    25                     }
    26                 }
    27                 catch { }
     33                                        if (entity.entityType == EntityType.Zombie) {
     34                                                EntityEnemy ee = (EntityEnemy)entity;
    2835
    29                 return lst;
    30             }
    31         }
    32 
    33         public static int Count {
    34             get { return List.Count; }
    35         }
    36     }
     36                                                if (ee.IsAlive ())
     37                                                        count++;
     38                                        }
     39                                }
     40                        }
     41                        catch (Exception e) {
     42                                Log.Exception (e);
     43                        }
     44                        return count;
     45                }
     46        }
    3747}
    3848
  • binary-improvements/7dtd-server-fixes/src/StateManager.cs

    r232 r306  
    99                {
    1010                        try {
    11                                 ItemList.Instance.Init ();
    12 
    1311                                PersistentData.PersistentContainer.Load ();
    1412                        } catch (Exception e) {
Note: See TracChangeset for help on using the changeset viewer.