Пример #1
0
Файл: Trade.cs Проект: Corne/VOC
        public void Accept(IPlayer player)
        {
            if (player == null)
                throw new ArgumentNullException(nameof(player));
            if (player == Owner)
                throw new ArgumentException("Can't accept a trade if owner == player");
            if (!player.HasResources(Request))
                throw new InvalidOperationException("Player should have the requested resources");
            if (!Owner.HasResources(Offer))
                throw new InvalidOperationException("Owner doesn't have the required resources (anymore)!");

            lock (tradeLock)
            {
                if (State != TradeState.Open)
                    throw new InvalidOperationException("Trade can no longer be accepted, because it's no longer open!");

                IRawMaterial[] requested = player.TakeResources(Request);
                IRawMaterial[] offered = Owner.TakeResources(Offer);
                Owner.AddResources(requested);
                player.AddResources(offered);

                State = TradeState.Processed;
            }
            logger.Info($"Trade accepted From {Owner.Name} To {player.Name}. Offer {string.Join(", ", Offer)}, Request {string.Join(", ", Request)}");
        }
Пример #2
0
Файл: Bank.cs Проект: Corne/VOC
        public void BuyResource(MaterialType request, MaterialType offer, IPlayer player)
        {
            if (request == offer)
                throw new ArgumentException("Can't request same material as you are offering");
            if (!VALID_RESOURCES.Contains(request))
                throw new ArgumentException($"Request ({request}) is not a valid material!");

            //GetInvestment also validates player != null, and offer is valid resource
            MaterialType[] investment = GetInvestmentCost(offer, player);
            if (!player.HasResources(investment))
                throw new InvalidOperationException("Player does not have the resources to buy");

            player.TakeResources(investment);
            player.AddResources(new RawMaterial(request));

            logger.Info($"{player.Name} bought {request} for {offer}({investment.Count()})");
        }