/**
   * 加载高铁数据
   *
   * @param bureuaName
   * @param bureuaCode
   * @param runDate
   * @return
   */
  public List<HighlineCrossCmd> loadHighlineData(
      String bureuaName, String bureuaCode, Date runDate, String runDateString) {
    // 20150202 调试临客命令查不到情况。何宇阳
    List<HighlineCrossCmd> highlineCrossList = new ArrayList<HighlineCrossCmd>();

    // step1: 查找加载日期及经由局相关的所有列车开行计划
    Map<String, Object> map = new HashMap<String, Object>();
    map.put("bureuaName", bureuaName);
    map.put("runDate", runDateString);
    List<PlanTrainCMD> trainList = cmdPlanDao.findPlanTrainListByBureauAndRunDate(map);

    StringBuffer messageInfo = new StringBuffer();
    messageInfo.append(
        "[交路加载:日期="
            + StringAndTimeUtil.yearMonthDaySdf.format(runDate)
            + ","
            + bureuaName
            + "局相关高铁运行线个数 ="
            + trainList.size()
            + "]");
    // 临客列车集合
    List<PlanTrainCMD> cmdTrainList = new ArrayList<PlanTrainCMD>();

    HashMap<String, List<PlanTrainCMD>> planCrossTrainMap =
        new HashMap<String, List<PlanTrainCMD>>();
    for (PlanTrainCMD train : trainList) {
      // @Test
      //			if(train.getPlanCrossId() != null &&
      // (train.getPlanCrossId().equals("21725376-4680-418e-8c2d-dd3c033173e6") ||
      // train.getPlanCrossId().equals("21725376-4680-418e-8c2d-dd3c033173e6"))){
      //				System.out.println(train.getRunDate() + "##[" + train.getPlanCrossId() + "]##[" +
      // train.getTrainNbr() + "]##" +
      // StringAndTimeUtil.yearMonthDayHourMinuteSdf.format(train.getStartTime()));
      //			}
      CompareModel compareModel = null;
      if (train.getBaseTrainId() == null || train.getBaseTrainId().equals("")) {
        // step2: 判定开行计划经由站是否符合条件
        //				Map<String,Object> map2 = new HashMap<String,Object>();
        map.clear();
        map.put("bureuaName", bureuaName);
        map.put("runDate", runDateString);
        map.put("planTrainId", train.getPlanTrainId());
        compareModel = cmdPlanDao.findCompareModelByBureauAndRunDate(map);
      } else {
        //				Map<String,Object> map3 = new HashMap<String,Object>();
        map.clear();
        map.put("bureuaName", bureuaName);
        map.put("runDate", train.getRunDate());
        map.put("baseTrainId", train.getBaseTrainId());
        compareModel = cmdPlanDao.findCompareModelByBureauAndRunDateBaseId(map);
      }
      if (compareModel == null) {
        continue;
      }

      if (!StringAndTimeUtil.isStartAndTargetDateInRunDate2(
          compareModel.getMinArriveDate(), runDate)) {
        continue;
      }

      // step3: 图定开行计划按交路分组
      if (train.getPlanCrossId() != null && !train.getPlanCrossId().trim().equals("")) {

        if (planCrossTrainMap.containsKey(train.getPlanCrossId())) {
          planCrossTrainMap.get(train.getPlanCrossId()).add(train);
        } else {
          List<PlanTrainCMD> tempList = new ArrayList<PlanTrainCMD>();
          tempList.add(train);
          planCrossTrainMap.put(train.getPlanCrossId(), tempList);
        }
      } else {
        cmdTrainList.add(train);
      }
    }
    /**
     * 特殊交路处理: 需要提前若干天加载的交路 首先配置交路线台关系字典表字段:提前加载天数LOADDATE_OFFSET 1:提前1天;默认0
     * 找到特殊交路的始发车名,并计算偏差日期,查找到始发车开行计划,加入到交路ID列车计划映射中。
     */
    List<DicRelaCrossPost> specialCrossList =
        cmdPlanDao.findCrossNameFromDicRelaCrossPostByOffset(bureuaCode);
    for (DicRelaCrossPost specialCross : specialCrossList) {

      int offset = specialCross.getLoaddateOffset();
      Calendar cal = Calendar.getInstance();
      cal.setTime(runDate);
      cal.add(Calendar.DAY_OF_MONTH, offset);
      //			Map<String,Object> map4 = new HashMap<String,Object>();
      map.clear();
      map.put(
          "trainNbr",
          StringAndTimeUtil.getSplitedString(
                  specialCross.getCrossName(), ConstantUtil.CROSSNAME_TOKEN)
              .get(0));
      // TODO
      map.put("time", StringAndTimeUtil.yearMonthDaySimpleSdf.format(cal.getTime()));
      PlanTrainCMD firstTrain = cmdPlanDao.findPlanTrainByCrossFirstTrainNbrAndRunDate(map);
      if (firstTrain != null) {

        List<PlanTrainCMD> listTemp = new ArrayList<PlanTrainCMD>();
        listTemp.add(firstTrain);
        planCrossTrainMap.put(firstTrain.getPlanCrossId(), listTemp);
      }
    }

    // step4: 查找交路中的始发车
    Iterator<String> iterator = planCrossTrainMap.keySet().iterator();
    int tdCount = 0;
    while (iterator.hasNext()) {

      String planCrossId = iterator.next();

      // @Test
      if (planCrossId.equals("21725376-4680-418e-8c2d-dd3c033173e6")
          || planCrossId.equals("21725376-4680-418e-8c2d-dd3c033173e6")) {
        System.out.println("TEST BBB");
      }
      map.clear();
      map.put("planCrossId", planCrossId);
      map.put("bureuaCode", bureuaCode);
      List<PlanCrossCmd> crossList = cmdPlanDao.findPlanCrossByPlanCrossId2(map);
      PlanCrossCmd cross = null;
      if (crossList != null && crossList.size() > 0) {
        cross = crossList.get(0);
      }
      for (PlanCrossCmd planCrossCmd : crossList) {
        if (bureuaCode.equals(planCrossCmd.getrBureau())) {
          cross = planCrossCmd;
        }
      }
      // 按照始发时间先后对列车排序
      List<PlanTrainCMD> mapTrainList =
          SortUtil.sortPlanTrainAsStartTime(planCrossTrainMap.get(planCrossId));

      HashMap<String, PlanTrainCMD> firstTrainMap = new HashMap<String, PlanTrainCMD>();
      if (cross != null) {

        String crossName = cross.getCrossName();
        List<String> trainNameList =
            StringAndTimeUtil.getSplitedString(crossName, ConstantUtil.CROSSNAME_TOKEN);
        String firstTrainName = trainNameList.get(0);
        // 临时列车内存集合
        List<PlanTrainCMD> tempTrainList = new ArrayList<PlanTrainCMD>();
        tempTrainList.addAll(mapTrainList);
        for (PlanTrainCMD mapTrain : mapTrainList) {
          // step5:查找始发车--先从临时内存集合中找,没有再从数据库中查找
          PlanTrainCMD firstTrain =
              this.searchPrePlanTrain(firstTrainName, 1, mapTrain, tempTrainList);

          if (firstTrain == null) {
            messageInfo.append("[交路加载:" + cross.getCrossName() + "数据有错,没有找到始发车]");
            continue;
          }
          if (!firstTrainMap.containsKey(firstTrain.getPlanTrainId())) {
            firstTrainMap.put(firstTrain.getPlanTrainId(), firstTrain);
          } else {
            continue;
          }
        }

        Iterator<String> iteTrain = firstTrainMap.keySet().iterator();
        while (iteTrain.hasNext()) {
          List<PlanTrainCMD> crossTrainList = new ArrayList<PlanTrainCMD>();
          PlanTrainCMD firstTrain = firstTrainMap.get(iteTrain.next());
          crossTrainList.add(firstTrain);
          PlanTrainCMD nowTrain = null;
          PlanTrainCMD nextTrain = null;
          // step6: 根据始发车依此查找出交路中的后续列车开行
          for (int j = 1; j < trainNameList.size(); j++) {

            if (j == 1) {
              nowTrain = firstTrain;
            }
            nextTrain = this.searchNextPlanTrain(nowTrain, tempTrainList);
            // 没有找到后续车,跳过本交路
            if (nextTrain == null) {
              messageInfo.append("[交路加载:" + cross.getCrossName() + "数据有错,没有找到后续车]");
              crossTrainList = null;
              break;
            }

            crossTrainList.add(nextTrain);
            nowTrain = nextTrain;
          }

          if (crossTrainList != null) {
            if (!isCrossSatisfy(crossTrainList, runDate, runDateString, bureuaName)) continue;

            cross.setTrainList(crossTrainList);
            // step7: 生成图定高铁计划
            HighlineCrossCmd highlineCross =
                generatorHighlineCrossByPlanCross(cross, bureuaCode, runDate);
            if (highlineCross != null) {
              tdCount++;
              highlineCrossList.add(highlineCross);
            } else {
              messageInfo.append("[交路加载:" + cross.getCrossName() + "数据有错,存库失败]");
            }
            highlineCross.setCrossTrain(
                generatorHighlineCrossTrainList(highlineCross, cross.getTrainList()));
          }
        }
      }
    }

    // step8: 生成临客高铁计划
    for (PlanTrainCMD planTrain : cmdTrainList) {
      HighlineCrossCmd highlineCross =
          generatorHighlineCrossByPlanTrain(planTrain, bureuaCode, runDate);
      highlineCrossList.add(highlineCross);
      List<PlanTrainCMD> list = new ArrayList<PlanTrainCMD>();
      list.add(planTrain);
      highlineCross.setCrossTrain(generatorHighlineCrossTrainList(highlineCross, list));
    }
    // step9: 更新车底信息。将历史车底信息带过来
    map.clear();
    map.put("runDate", StringAndTimeUtil.yearMonthDaySimpleSdf.format(runDate));
    map.put("bureuaCode", bureuaCode);
    //		cmdPlanDao.updateHighlineCrossVehicleByHistory(map);
    messageInfo.append("[交路加载:图定交路数=" + tdCount + ",临客交路数=" + cmdTrainList.size() + "]");

    // step10:关闭数据库资源
    //		DbUtilDdml.getInstance().closeConnection();
    messageInfo.append(
        "[交路加载:日期= "
            + StringAndTimeUtil.yearMonthDaySdf.format(runDate)
            + ","
            + bureuaName
            + "局成功交路数="
            + highlineCrossList.size()
            + "]");
    // 20150202 调试临客命令查不到情况。何宇阳
    //		JDomUtil.writeFile(messageInfo.toString(), "/lkmllog/", "highLineCross.txt");
    return highlineCrossList;
  }