private InvestResult InvestInTech(string techName) { var side = ClientConnection.GetSide(); var buckets = side.GetBuckets(); var money = ClientConnection.GetMoney(); foreach (var bucket in buckets) { if (bucket.GetName().StartsWith(techName) == true && side.CanBuy(bucket) == true) { if (bucket.GetPercentComplete() <= 0) { if (money > bucket.GetPrice()) { Log($"Adding money to bucket {bucket.GetName()}. Bucket wants: {bucket.GetBuyable().GetPrice()}, we have: {money}"); ClientConnection.AddMoneyToBucket(bucket, bucket.GetPrice()); return(InvestResult.Succeeded); } else { Log($"Not enough money to buy {techName}, money: {money}, bucketPrice: {bucket.GetPrice()}"); //Log("Already building: " + bucket.GetPercentComplete()); return(InvestResult.InsufficientFunds); } } else { Log($"Bucket progress for {techName}: {bucket.GetPercentComplete()}%"); return(InvestResult.AlreadyInProgress); } } } Log($"A bucket was not found for tech: {techName}, removing this tech from the queue."); return(InvestResult.InvalidTechName); }