当前位置: 首页>>代码示例>>C#>>正文


C# POrder.ToString方法代码示例

本文整理汇总了C#中MadViper.POrder.ToString方法的典型用法代码示例。如果您正苦于以下问题:C# POrder.ToString方法的具体用法?C# POrder.ToString怎么用?C# POrder.ToString使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在MadViper.POrder的用法示例。


在下文中一共展示了POrder.ToString方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: IsOK

        public Boolean IsOK(POrder o)
        {
            if (_account == null)
            {
                logger.Error("[DefaultOrderLimit] account가 null이다. {0} != {1}", o.Code, o.RMDClone);
                Util.KillWithNotice("[DefaultOrderLimit] account가 null이다.");
                return false;
            }

            if (!Util.IsCorrectCodeMatch(o.Code, o.RMDClone))
            {
                logger.Error("[DefaultOrderLimit] Order.Code != RMD.Code, ({0} != {1})", o.Code, o.RMDClone);
                logger.Error("ERROR ORDER[{0}]", o.ToString());
                Util.KillWithNotice("[DefaultOrderLimit] error");

                return false;
            }

            if (!POrderLegalManager.Ins().IsLegalOrder(o, true))
            {
                logger.Error("[DefaultOrderLimit] Legal Problem ({0})", o.Code);
                logger.Error("ERROR ORDER[{0}]", o.ToString());
                Util.KillWithNotice("[DefaultOrderLimit] Legal Problem");

                return false;
            }

            return true;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:29,代码来源:DefaultOrderLimit.cs

示例2: IsOK

        public Boolean IsOK(POrder o)
        {
            RawMarketData rmd = o.RMDClone;
            double opa = ProductUtil.Ins().GetOnePointAmount(o.Code);

            double value = Math.Abs(opa * o.ReqCount * Math.Max(rmd.CurPrice, o.ReqPrice));

            if (_maxValue < _curValue + value)
            {
                try
                {
                    logger.Error("[ValuePerMinuteOrderLimit] {0} < {1} + {2}", _maxValue, _curValue, value);
                    Util.KillWithNotice("[ValuePerMinuteOrderLimit] error");
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("ERROR ORDER");
                }
                catch (System.Exception ex)
                {
                    logger.Error(ex.ToString());
                    Util.KillWithNotice(ex.ToString());
                }
                return false;
            }

            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:26,代码来源:ValuePerMinuteOrderLimit.cs

示例3: IsOK

        public Boolean IsOK(POrder o)
        {
            RawMarketData rmd = o.RMDClone;

            if (o.TargetAccount.LineType == Account.OrderLineType.StockSpotLine)
            {
                return _decorator.IsOK(o);
            }
            else if (o.TargetAccount.LineType == Account.OrderLineType.FutureOptionSpreadLine)
            {
                Detail.ProductType dpt = ProductUtil.Ins().GetProductType(o.Code);

                double downLimitPrice = 0;
                double upLimitPrice = 0;

                if (dpt == Detail.ProductType.KospiFuture)
                {
                    downLimitPrice = KospiFutureUtil.Ins().KFI.DownLimit;
                    upLimitPrice = KospiFutureUtil.Ins().KFI.UpLimit;
                }
                else if (dpt == Detail.ProductType.CallOption || dpt == Detail.ProductType.PutOption)
                {
                    downLimitPrice = OptionUtil.GetKOI(o.Code).DownLimit;
                    upLimitPrice = OptionUtil.GetKOI(o.Code).UpLimit;
                }
                else
                {
                    logger.Error("Unknown type {0}", dpt);
                    Util.KillWithNotice("Unknown type");
                    Trace.Assert(false);
                }

                if (o.ReqPrice < downLimitPrice)
                {
                    logger.Error("[UpDownLimitPriceOrderLimit] {0} < {1}", o.ReqPrice, downLimitPrice);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("[UpDownLimitPriceOrderLimit] error");

                    return false;
                }

                if (o.ReqPrice > upLimitPrice)
                {
                    logger.Error("[UpDownLimitPriceOrderLimit] {0} > {1}", o.ReqPrice, upLimitPrice);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("[UpDownLimitPriceOrderLimit] error");

                    return false;
                }
            }
            else
            {
                logger.Error("Invalid pt");
                Util.KillWithNotice("Invalid pt");
            }
            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:57,代码来源:UpDownLimitPriceOrderLimit.cs

示例4: IsOK

        public Boolean IsOK(POrder o)
        {
            double tickSize = ProductUtil.Ins().GetTickSize(o);

            double pivot = GetPivot(o);

            if (pivot == 0)
            {
                logger.Error("[LimOrderLimit] {0} > {1} + {2} * {3}", o.ReqPrice, pivot, tickSize, _tickRange);
                logger.Error("ERROR ORDER[{0}]", o.ToString());
                Util.KillWithNotice("[LimOrderLimit] error");

                return false;
            }

            if (o.LongShort == TradingDirection.Long)
            {
                // 작은 값으로 주문내는 것은 상관 없다. 높은 값으로 주문하는 것을 조심해야 한다.
                // 현재가보다 5틱 위에 매수 주문을 내려고 한다. 안된다.
                if (o.ReqPrice > pivot + tickSize * _tickRange)
                {
                    logger.Error("[LimOrderLimit] {0} > {1} + {2} * {3}", o.ReqPrice, pivot, tickSize, _tickRange);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("[LimOrderLimit] error");

                    return false;
                }
            }
            else
            {
                // 큰 값으로 매도 주문을 내는 것은 상관없다. 작은 값으로 주문하는 것을 조심해야 한다.
                // 현재가보다 5틱 아래 매도 주문을 내려고 한다. 안된다.
                if (o.ReqPrice < pivot - tickSize * _tickRange)
                {
                    logger.Error("[LimOrderLimit] {0} < {1} - {2} * {3}", o.ReqPrice, pivot, tickSize, _tickRange);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("[LimOrderLimit] error");

                    return false;
                }
            }

            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:44,代码来源:LimOrderLimit.cs

示例5: IsOK

        public Boolean IsOK(POrder o)
        {
            RawMarketData rmd = o.RMDClone;
            if (o.LongShort == TradingDirection.Long)
            {
                double askPrice = rmd.AskPrice1;

                // 사자주문이다. 사겠다는 가격이 존재하는 매도 호가보다도 높다면 이상한 경우이다.
                if (o.ReqPrice > askPrice)
                {
                    logger.Error("[PriceBidAskRangeOrderLimit] (ReqPrice({0}), AskPrice({1}), {2})", o.ReqPrice, askPrice, o.LongShort);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("[PriceBidAskRangeOrderLimit] error");

                    return false;
                }
            }
            else
            {
                double bidPrice = rmd.BidPrice1;

                // 팔자주문이다. 팔겠다는 가격이 존재하는 매수 호가보다도 낮다면 이상한 경우이다.
                if (o.ReqPrice < bidPrice)
                {
                    logger.Error("[PriceBidAskRangeOrderLimit] (ReqPrice({0}), BidPrice({1}), {2})", o.ReqPrice, bidPrice, o.LongShort);
                    Util.KillWithNotice("[PriceBidAskRangeOrderLimit] error");

                    try
                    {
                        logger.Error("ERROR ORDER[{0}]", o.ToString());
                        Util.KillWithNotice("ERROR ORDER");
                    }
                    catch (System.Exception ex)
                    {
                        logger.Error(ex.ToString());
                        Util.KillWithNotice(ex.ToString());
                    }

                    return false;
                }
            }

            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:44,代码来源:PriceBidAskRangeOrderLimit.cs

示例6: IsOK

        public Boolean IsOK(POrder o)
        {
            RawMarketData rmd = o.RMDClone;
            if (o.LongShort == TradingDirection.Long)
            {
                double bidPrice = GetPossibleMinBidPrice(rmd);

                // 사자주문이다. OOR의 경우 BidPrice 호가보다 큰 값으로 주문을 내면 이상한 것이다.
                if (o.ReqPrice > bidPrice)
                {
                    logger.Error("CRITICAL ERROR in OOROrderLimit ({0}, {1}, {2})", o.ReqPrice, bidPrice, o.LongShort);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("CRITICAL ERROR in OOROrderLimit");

                    return false;
                }
            }
            else
            {
                double askPrice = GetPossibleMaxAskPrice(rmd);

                // 팔자주문이다. OOR의 경우 AskPrice 호가보다 작은 값으로 주문을 내면 이상한 것이다.
                if (o.ReqPrice < askPrice)
                {
                    logger.Error("CRITICAL ERROR in OOROrderLimit ({0}, {1}, {2})", o.ReqPrice, askPrice, o.LongShort);
                    Util.KillWithNotice("CRITICAL ERROR in OOROrderLimit");
                    try
                    {
                        logger.Error("ERROR ORDER[{0}]", o.ToString());
                        Util.KillWithNotice("ERROR ORDER");
                    }
                    catch (System.Exception ex)
                    {
                        logger.Error(ex.ToString());
                        Util.KillWithNotice(ex.ToString());
                    }

                    return false;
                }
            }

            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:43,代码来源:OOROrderLimit.cs

示例7: IsOK

        public Boolean IsOK(POrder o)
        {
            if (IsOK_Raw(o))
            {
                return _decorator.IsOK(o);
            }

            logger.Error("[OutOfRangeOrderLimit] {0}", o.ToString());
            Util.KillWithNotice("[OutOfRangeOrderLimit]");

            return false;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:12,代码来源:OutOfRangeOrderLimit.cs

示例8: IsOK

        public Boolean IsOK(POrder o)
        {
            if (_maxCount < _curCount + o.ReqCount)
            {
                // Over Limit
                try
                {
                    logger.Error("[CountPerMinuteOrderLimit] {0} < {1} + {2}", _maxCount, _curCount, o.ReqCount);
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("ERROR ORDER");
                }
                catch (System.Exception ex)
                {
                    logger.Error(ex.ToString());
                    Util.KillWithNotice(ex.ToString());
                }

                return false;
            }

            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:22,代码来源:CountPerMinuteOrderLimit.cs

示例9: IsOK

        public Boolean IsOK(POrder o)
        {
            if (!Util.IsValidRMDTimeAndPrice(o.RMDClone))
            {
                logger.Error("Invalid RMD");
                Util.KillWithNotice("Invalid RMD");
                try
                {
                    logger.Error("ERROR ORDER[{0}]", o.ToString());
                    Util.KillWithNotice("ERROR ORDER");
                }
                catch (System.Exception ex)
                {
                    logger.Error(ex.ToString());
                    Util.KillWithNotice(ex.ToString());
                }

                return false;
            }

            return _decorator.IsOK(o);
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:22,代码来源:ValidRmdOrderLimit.cs

示例10: MakeOrder_Raw

        Boolean MakeOrder_Raw(RawMarketData rmd, long remainCount100k, Dictionary<String, long> blocksLB, ref List<POrder> newOrders, ref String log)
        {
            if (remainCount100k == 0)
            {
                log += "remainCount100k == 0";
                return true;
            }

            long signedRealCount = ElwOptionUtil.Convert100KToRealCount(rmd.Code, remainCount100k);

            if (signedRealCount == 0 || remainCount100k - ElwOptionUtil.ConvertRealToCount100k(rmd.Code, signedRealCount) != 0)
            {
                log += String.Format("signRealCount({0}) remainCount100k({1}) code({2})|", signedRealCount, remainCount100k, rmd.Code);
                return false;
            }

            long reqCount = Math.Abs(signedRealCount);

            TradingDirection ls = TradingDirection.Long;
            if (signedRealCount < 0)
            {
                ls = TradingDirection.Short;

                if (!blocksLB.ContainsKey(rmd.Code))
                {
                    log += String.Format("[22], {0}|", rmd.Code);

                    return false;
                }

                if (blocksLB[rmd.Code] < Math.Abs(signedRealCount))
                {
                    log += String.Format("[23] BlockLB[{2}]({0}) < signedRealCount({1})", blocksLB[rmd.Code], signedRealCount, rmd.Code);
                    return false;
                }

                reqCount = Math.Abs(signedRealCount);
                long tmp = ProductUtil.Ins().RoundProductCount(Math.Abs(reqCount), rmd.DPT);

                if (tmp != reqCount)
                {
                    logger.Error("tmp({0}) != reqCount({1}) in MakeOrder_Raw", tmp, reqCount);
                    Util.KillWithNotice("tmp != reqCount in MakeOrder_Raw");
                }
            }

            Account account = _accountFO;
            if (rmd.DPT == Detail.ProductType.ELW || rmd.DPT == Detail.ProductType.Stock)
            {
                account = _accountSpot;
            }

            double price = ProductUtil.Ins().GetMidPrice(rmd);
            price = AdjustPrice(ls, rmd, price);

            POrder o = new POrder(ls, rmd.Code, reqCount, price, account, rmd);
            o.AddComment("SweepUnit_OE.MakeOrder_Raw");

            log += String.Format("[23], {0}|", o.ToString());

            if (o.ReqCount > 0)
            {
                // 여기서 Reserve하고 법적 문제가 있는지 확인한다.
                o.SetAsLegalPrice();
                o.ConvertOverPriceToInRMDPriceIfNotZero();

                log += String.Format("[24], {0}|", o.ToString());

                newOrders.Add(o);
            }
            else
            {
                o.Free();

                log += String.Format("[24], ReqCount <= 0");
                return false;
            }

            long ret = remainCount100k - ElwOptionUtil.ConvertRealToCount100k(rmd.Code, signedRealCount);

            if (ret != 0)
            {
                logger.Error(
                    "CRITICAL ERROR!!! in MakeOrder_Raw ret != 0 ret({0}), remainCount100k({1}), signedRealCount({2}), Code({3})",
                    ret,
                    remainCount100k,
                    signedRealCount,
                    rmd.Code);
                Util.KillWithNotice("CRITICAL ERROR!!! in MakeOrder_Raw");

                return false;
            }

            return true;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:95,代码来源:XXX_SweepUnit_OE.cs

示例11: CancelRemains

 public void CancelRemains(POrder order)
 {
     logger.Debug("Cancel: {0}", order.ToString());
     this.Hts.CancelRemains(order);
 }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:5,代码来源:Account.cs

示例12: Remove

        public Boolean Remove(POrder o)
        {
            Boolean bRemoved = false;

            double price = Math.Round(ProductUtil.Ins().RoundProductPrice(o.Code, o.ReqPrice), 2);

            if (_data.ContainsKey(price))
            {
                List<POrder> arr = _data[price];

                if (arr.Contains(o))
                {
                    arr.Remove(o);
                    bRemoved = true;
                }

                if (arr.Count == 0)
                {
                    _data.Remove(price);
                }
            }

            if (!bRemoved)
            {
                logger.Debug("Does not removed.");
                logger.Debug(o.ToString());
                logger.Debug(ToString());
            }

            return bRemoved;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:31,代码来源:POrderLegalManager.cs

示例13: RequestOrder

        public static Boolean RequestOrder(POrder order, List<POrder> container)
        {
            try
            {
                order.SetAsLegalPrice();

                Boolean bSuccess = true;

                bSuccess = order.TargetAccount.RequestOrder(order);

                if (!bSuccess)
                {
                    logger.Error(order.ToString());
                    Util.KillWithNotice(order.ToString());
                    SoundManager.Ins().PlayExceptionSound();
                }
                else
                {
                    if (container != null)
                    {
                        // 성공했으면 담는다.
                        container.Add(order);
                    }
                }
                return bSuccess;
            }
            catch (System.Exception ex)
            {
                logger.Error(ex.ToString());
                Util.KillWithNotice(ex.ToString());
            }
            return false;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:33,代码来源:POrderUtil.cs

示例14: CancelDangerousOrders_Raw

        Boolean CancelDangerousOrders_Raw(POrder order)
        {
            String elwCode = order.Code;
            double reqPrice = order.ReqPrice;

            ElwInfo ei = ElwUtil.GetElwInfo(elwCode);

            if (ei == null)
            {
                Trace.Assert(false);
            }

            // 만기 확인
            OptionTribe ot = ElwOptionUtil.GetOptionTribeFromCode(elwCode);

            if (ot == null)
            {
                Trace.Assert(false);
            }

            double strike = ot.Strike;
            CallPutFlag cp = ot.CP;

            // 바로 옆 옵션을 reference로 사용한다.
            double doorStrike = GetDoorStrike(strike, cp, 1.0);

            KospiOptionInfo targetKOI = OptionUtil.GetKOI(strike, cp, ot.Maturity);
            KospiOptionInfo doorKOI = OptionUtil.GetKOI(doorStrike, cp, ot.Maturity);

            if (doorKOI == null)
            {
                Trace.Assert(false);
            }
            else
            {
                Boolean bDangerous = CancelDangerousOrders_Raw(order, ei, targetKOI, doorKOI);

                if (bDangerous)
                {
                    order.CancelRemains();
                    EmailManager.Ins().AddEmail(
                        String.Format("Dangerous Door Canceled... {0}", order.ToString()));
                }
                return bDangerous;
            }
            return false;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:47,代码来源:Monitor_Door_Entering.cs

示例15: Contract_CallBack

        public Boolean Contract_CallBack(POrder order)
        {
            if (IsFishingOrder(order))
            {
                if (GetFishingOrderType(order) == FishingOrderType.Active)
                {
                    // Fishing and no agroor상태이다.
                    // order가 일부 혹은 전부 체결이 되었다면 Agroor를 생성한다.
                    if (order.ContractedCount > 0 && order.CanceledCount == 0)
                    {
                        // 체결되었고 취소된 수량은 없는 상태이다. register해준다.
                        _sweeperController.RegisterContractedOrder(order);

                        // FishingOrderType을 변경한다.
                        Trace.Assert(_fishigOrders.ContainsKey(order) == true);
                        _fishigOrders[order] = FishingOrderType.Passive;

                        SoundManager.Ins().ForcedPlayContractSound();
                        EmailManager.Ins().AddEmail(
                            String.Format("Door Contracted... {0}", order.ToString()));
                    }
                }
            }
            else
            {
                // sweeper에서 낸 주문이거나 수동으로 파워베이스에서 낸 주문인 경우에 해당한다.
                // 특별히 해줄 일이 없다.
                logger.Info("Door에서 Fishing order가 아닌 주문에 의해 Contracted_CallBack을 호출함.");
                logger.Info(order.ToString());
            }
            return true;
        }
开发者ID:HongSeokHwan,项目名称:legacy,代码行数:32,代码来源:STR_Door.cs


注:本文中的MadViper.POrder.ToString方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。