當前位置: 首頁>>代碼示例>>Java>>正文


Java Query.setClass方法代碼示例

本文整理匯總了Java中javax.jdo.Query.setClass方法的典型用法代碼示例。如果您正苦於以下問題:Java Query.setClass方法的具體用法?Java Query.setClass怎麽用?Java Query.setClass使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.jdo.Query的用法示例。


在下文中一共展示了Query.setClass方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getShipmentsByOrderId

import javax.jdo.Query; //導入方法依賴的package包/類
/**
 * Get all shipment for a specific order
 *
 * @param orderId Order Id
 * @return -
 */
@Override
@SuppressWarnings("unchecked")
public List<IShipment> getShipmentsByOrderId(Long orderId, PersistenceManager pm) {
  Query query = null;
  try {
    query = pm.newQuery("javax.jdo.query.SQL", "SELECT * FROM SHIPMENT WHERE ORDERID = ?");
    query.setClass(JDOUtils.getImplClass(IShipment.class));
    List list = (List) query.executeWithArray(orderId);
    List<IShipment> shipments = new ArrayList<>(list.size());
    for (Object shipment : list) {
      shipments.add((IShipment) shipment);
    }
    return shipments;
  } catch (Exception e) {
    xLogger.severe("Error while fetching shipments by order id: {0}", orderId, e);
  } finally {
    if (query != null) {
      query.closeAll();
    }
  }
  return null;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:29,代碼來源:ShipmentService.java

示例2: fetchMinMaxLog

import javax.jdo.Query; //導入方法依賴的package包/類
/**
 * Fetch the List<IInventoryMinMaxLog> for a given inventoryId
 */
public List<IInventoryMinMaxLog> fetchMinMaxLog(String invId) {
  PersistenceManager pm = PMF.get().getPersistenceManager();
  Query query = null;
  List<IInventoryMinMaxLog> logs = null;
  try {
    String sqlQuery = "SELECT * FROM INVENTORYMINMAXLOG WHERE invId =? ORDER BY T DESC limit 50";
    query = pm.newQuery("javax.jdo.query.SQL", sqlQuery);
    query.setClass(JDOUtils.getImplClass(IInventoryMinMaxLog.class));
    logs = (List<IInventoryMinMaxLog>) query.executeWithArray(invId);
    logs = (List<IInventoryMinMaxLog>) pm.detachCopyAll(logs);

  } catch (Exception e) {
    xLogger.warn("Exception {0} when getting InvntryItem for invId {1}. Message: {2}",
        e.getClass().getName(), invId, e.getMessage());
    return null;
  } finally {
    if (query != null) {
      query.closeAll();
    }
    pm.close();
  }

  return logs;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:28,代碼來源:InventoryManagementServiceImpl.java

示例3: getQuery

import javax.jdo.Query; //導入方法依賴的package包/類
private static Query getQuery(QueryParams qp, PersistenceManager pm,
                              PageParams pageParams) {
  Query q;
  if (QueryParams.QTYPE.SQL.equals(qp.qType)) {
    String query = qp.query;
    if (query != null && pageParams != null && !query.contains(" LIMIT ")) {
      query +=
          " LIMIT " + pageParams.getOffset() + CharacterConstants.COMMA + pageParams
              .getSize();
    }
    q = pm.newQuery("javax.jdo.query.SQL", query);
    q.setClass(JDOUtils.getImplClass(qp.qClazz));
  } else {
    q = pm.newQuery(qp.query);
    if (pageParams != null) {
      QueryUtil.setPageParams(q, pageParams);
    }
  }
  return q;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:21,代碼來源:JDOUtils.java

示例4: searchMaterialsNoHU

import javax.jdo.Query; //導入方法依賴的package包/類
@Override
public Results searchMaterialsNoHU(Long domainId, String q) {
  PersistenceManager pm = PMF.get().getPersistenceManager();
  Query query = null;
  try {
    query =
        pm.newQuery("javax.jdo.query.SQL",
            "SELECT * FROM MATERIAL M, MATERIAL_DOMAINS MD WHERE MD.MATERIALID_OID = M.MATERIALID AND MD.DOMAIN_ID="
                + domainId +
                " AND UNAME LIKE '" + q.toLowerCase()
                + "%' AND NOT EXISTS(SELECT 1 FROM HANDLINGUNITCONTENT WHERE CNTID = MATERIALID AND TY=0) LIMIT 8");
    query.setClass(Material.class);
    List<Material> data = (List<Material>) query.execute();
    if (data != null) {
      data = (List<Material>) pm.detachCopyAll(data);
      return new Results(data, null);
    }
  } catch (Exception e) {
    xLogger.severe(
        "Error while fetching material with no handling unit from domain {0} and query {1}",
        domainId, q, e);
  } finally {
    if (query != null) {
      try {
        query.closeAll();
      } catch (Exception ignored) {
        xLogger.warn("Exception while closing query", ignored);
      }
    }
    pm.close();
  }
  return null;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:34,代碼來源:MaterialDao.java

示例5: getUsers

import javax.jdo.Query; //導入方法依賴的package包/類
/**
 * Get users given the offset and size
 *
 * @param offset Offset
 * @param size   Number of users
 */
public List<IUserAccount> getUsers(int offset, int size) {
  PersistenceManager pm = null;
  Query query = null;
  List<IUserAccount> users = null;
  try {
    pm = PMF.get().getPersistenceManager();
    String
        queryStr =
        "SELECT * FROM USERACCOUNT ORDER BY USERID ASC limit " + offset + CharacterConstants.COMMA
            + size;
    query = pm.newQuery("javax.jdo.query.SQL", queryStr);
    query.setClass(UserAccount.class);
    users = (List<IUserAccount>) query.execute();
    users = (List<IUserAccount>) pm.detachCopyAll(users);
  } catch (Exception e) {
    xLogger.warn("Error encountered during user id migrations", e);
  } finally {
    if (query != null) {
      query.closeAll();
    }
    if (pm != null) {
      pm.close();
    }
  }
  return users;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:33,代碼來源:UserDao.java

示例6: getUsersByIds

import javax.jdo.Query; //導入方法依賴的package包/類
/**
 * Method to fetch the user account details for the given userIds
 *
 * @param userIds User Id list
 * @return List<IUserAccount>
 */
public List<IUserAccount> getUsersByIds(List<String> userIds) {

  if (userIds == null || userIds.isEmpty()) {
    return null;
  }
  List<IUserAccount> results = null;
  PersistenceManager pm = PMF.get().getPersistenceManager();
  Query query = null;
  try {

    StringBuilder queryBuilder = new StringBuilder("SELECT * FROM `USERACCOUNT` ");
    queryBuilder.append("WHERE USERID IN (");
    for (String userId : userIds) {
      queryBuilder.append("'").append(userId).append("'").append(CharacterConstants.COMMA);
    }
    queryBuilder.setLength(queryBuilder.length() - 1);
    queryBuilder.append(" )");
    query = pm.newQuery("javax.jdo.query.SQL", queryBuilder.toString());
    query.setClass(JDOUtils.getImplClass(IUserAccount.class));
    results = (List<IUserAccount>) query.execute();
    results = (List<IUserAccount>) pm.detachCopyAll(results);
  } catch (Exception e) {
    xLogger.warn("Exception while fetching approval status", e);
  } finally {
    if (query != null) {
      try {
        query.closeAll();
      } catch (Exception ignored) {
        xLogger.warn("Exception while closing query", ignored);
      }
    }
    pm.close();
  }
  return results;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:42,代碼來源:UsersServiceImpl.java

示例7: getOrdersApprovalMapping

import javax.jdo.Query; //導入方法依賴的package包/類
public List<IOrderApprovalMapping> getOrdersApprovalMapping(Set<Long> orderIds,
                                                            int orderAppprovalType) {

  if (orderIds == null || orderIds.isEmpty()) {
    return null;
  }
  PersistenceManager pm = PMF.get().getPersistenceManager();
  Query query = null;
  List<IOrderApprovalMapping> results = null;
  try {

    StringBuilder queryBuilder = new StringBuilder("SELECT * FROM `ORDER_APPROVAL_MAPPING`");
    queryBuilder.append(" WHERE ORDER_ID IN (");
    for (Long orderId : orderIds) {
      queryBuilder.append(orderId).append(CharacterConstants.COMMA);
    }
    queryBuilder.setLength(queryBuilder.length() - 1);
    queryBuilder.append(" )");
    queryBuilder.append(" AND APPROVAL_TYPE=").append(orderAppprovalType);
    queryBuilder.append(" AND LATEST=1 ORDER BY ORDER_ID ASC");
    query = pm.newQuery("javax.jdo.query.SQL", queryBuilder.toString());
    query.setClass(OrderApprovalMapping.class);
    results = (List<IOrderApprovalMapping>) query.execute();
    results = (List<IOrderApprovalMapping>) pm.detachCopyAll(results);
  } catch (Exception e) {
    xLogger.warn("Exception while fetching approval status", e);
  } finally {
    if (query != null) {
      try {
        query.closeAll();
      } catch (Exception ignored) {
        xLogger.warn("Exception while closing query", ignored);
      }
    }
    pm.close();
  }
  return results;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:39,代碼來源:OrderApprovalsServiceImpl.java

示例8: getMigratoryOrders

import javax.jdo.Query; //導入方法依賴的package包/類
@Override
public List<IOrder> getMigratoryOrders(Integer offset, Integer size, String cutoffDate) {

  PersistenceManager pm = null;
  Query query = null;
  List<IOrder> retlist = null;
  List<String> params = new ArrayList<>();
  try {
    String
        squery =
        " SELECT * FROM  logistimo.ORDER ord LEFT JOIN logistimo.ORDER_JOB_STATUS ojs ON (ord.ID = ojs.ID) "
            +
            " WHERE ord.CON <= ? AND ojs.STATUS NOT IN ('COMPLETED','FAILED') OR ojs.STATUS is null "
            +
            " ORDER BY ord.ID ASC limit " + offset + CharacterConstants.COMMA + size;
    params.add(cutoffDate);
    pm = PMF.get().getPersistenceManager();
    query = pm.newQuery("javax.jdo.query.SQL", squery);
    query.setClass(Order.class);
    retlist = (List<IOrder>) query.executeWithArray(params.toArray());
    retlist = (List<IOrder>) pm.detachCopyAll(retlist);

  } catch (Exception e) {
    xlogger.warn("Error encountered during order migrations", e);
  } finally {
    if (query != null) {
      query.closeAll();
    }
    if (pm != null) {
      pm.close();
    }
  }
  return retlist;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:35,代碼來源:OrderDao.java

示例9: getDemandItems

import javax.jdo.Query; //導入方法依賴的package包/類
/**
 * Get all demand items by order Id
 *
 * @param orderId Order Id
 * @return -
 */
@Override
public List<IDemandItem> getDemandItems(Long orderId, PersistenceManager pm) {
  PersistenceManager localPM = pm;
  boolean useLocalPM = false;
  if (localPM == null) {
    localPM = PMF.get().getPersistenceManager();
    useLocalPM = true;
  }
  Query q = null;
  try {
    q = localPM.newQuery("javax.jdo.query.SQL", "SELECT * FROM DEMANDITEM WHERE OID=?");
    q.setClass(JDOUtils.getImplClass(IDemandItem.class));
    List<IDemandItem> items = (List<IDemandItem>) q.executeWithArray(orderId);
    if (items != null) {
      items = (List<IDemandItem>) localPM.detachCopyAll(items);
    }
    return items;
  } catch (Exception e) {
    xLogger.severe("Error while fetching demand items for order {0}", orderId, e);
  } finally {
    if (q != null) {
      q.closeAll();
    }
    if (useLocalPM) {
      localPM.close();
    }
  }
  return null;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:36,代碼來源:DemandService.java

示例10: includeShipmentItems

import javax.jdo.Query; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
private void includeShipmentItems(IShipment shipment, PersistenceManager pm) {
  if (shipment == null) {
    return;
  }
  Query src = null;
  try {
    src = pm.newQuery("javax.jdo.query.SQL", "SELECT * FROM SHIPMENTITEM WHERE sid = ?");
    src.setClass(JDOUtils.getImplClass(IShipmentItem.class));
    shipment
        .setShipmentItems((List<IShipmentItem>) src.executeWithArray(shipment.getShipmentId()));
    shipment
        .setShipmentItems((List<IShipmentItem>) pm.detachCopyAll(shipment.getShipmentItems()));
    src = pm.newQuery("javax.jdo.query.SQL", "SELECT * FROM SHIPMENTITEMBATCH WHERE siId = ?");
    src.setClass(JDOUtils.getImplClass(IShipmentItemBatch.class));
    for (IShipmentItem iShipmentItem : shipment.getShipmentItems()) {
      List<IShipmentItemBatch>
          sb =
          (List<IShipmentItemBatch>) src.executeWithArray(iShipmentItem.getShipmentItemId());
      iShipmentItem.setShipmentItemBatch((List<IShipmentItemBatch>) pm.detachCopyAll(sb));
    }
  } catch (Exception e) {
    xLogger
        .severe("Error while fetching shipment items for shipment: {0}", shipment.getShipmentId(),
            e);
  } finally {
    if (src != null) {
      src.closeAll();
    }
  }
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:32,代碼來源:ShipmentService.java

示例11: getInventory

import javax.jdo.Query; //導入方法依賴的package包/類
@Override
public Results getInventory(InventoryFilters inventoryFilters, PageParams pageParams,
                            PersistenceManager pm)
    throws ServiceException {
  Query query = null;
  Query cntQuery = null;
  List<Invntry> inventoryList = null;
  int count = 0;
  try {
    QueryParams
        sqlQueryModel = buildInventoryQuery(inventoryFilters, false);
    String executeQuery = sqlQueryModel.query;
    if (pageParams != null) {
      executeQuery += " LIMIT " + pageParams.getOffset() + CharacterConstants.COMMA
          + pageParams.getSize();
    }
    query = pm.newQuery("javax.jdo.query.SQL", executeQuery);
    query.setClass(Invntry.class);
    inventoryList = (List<Invntry>) query.executeWithArray(
        sqlQueryModel.listParams.toArray());
    inventoryList = (List<Invntry>) pm.detachCopyAll(inventoryList);
    QueryParams cntSqlQueryModel = buildInventoryQuery(inventoryFilters, true);
    cntQuery = pm.newQuery("javax.jdo.query.SQL", cntSqlQueryModel.query);
    count =
        ((Long) ((List) cntQuery.executeWithArray(cntSqlQueryModel.listParams.toArray())).iterator().next())
            .intValue();

  } catch (Exception e){
    xLogger.severe("Error while reading inventory data", e);
  } finally {
    if (query != null) {
      query.closeAll();
    }
    if (cntQuery != null) {
      cntQuery.closeAll();
    }
  }
  return new Results(inventoryList, null, count,
      pageParams == null ? 0 : pageParams.getOffset());
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:41,代碼來源:InvntryDao.java

示例12: closeOpenEvent

import javax.jdo.Query; //導入方法依賴的package包/類
private boolean closeOpenEvent(Long invId, PersistenceManager pm) {
  boolean useLocalPm = pm == null;
  if (useLocalPm) {
    pm = PMF.get().getPersistenceManager();
  }
  Query query = null;
  try {
    StringBuilder queryStr = new StringBuilder("SELECT * FROM INVNTRYEVNTLOG WHERE INVID = ");
    queryStr.append(invId);
    queryStr.append(" AND ED IS NULL");
    query =
        pm.newQuery("javax.jdo.query.SQL",
            queryStr.toString());
    query.setClass(JDOUtils.getImplClass(IInvntryEvntLog.class));
    query.setUnique(true);
    IInvntryEvntLog invntryEvntLog = (IInvntryEvntLog) query.execute();
    if (invntryEvntLog != null) {
      // Update the end date to now
      invntryEvntLog.setEndDate(new Date());
      pm.makePersistent(invntryEvntLog);
    }
  } catch (Exception e) {
    xLogger.warn(
        "Exception while closing open event for inventory item, invId: {0}", invId, e);
    return false;
  } finally {
    if (query != null) {
      query.closeAll();
    }
    if (useLocalPm) {
      pm.close();
    }
  }
  return true;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:36,代碼來源:InventoryManagementServiceImpl.java

示例13: getKiosksForUser

import javax.jdo.Query; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
private Results getKiosksForUser(IUserAccount user, String routeTag, PageParams pageParams,
                                 PersistenceManager pm) throws ServiceException {
  xLogger.fine("Entered getKiosks");
  if (user == null) {
    throw new IllegalArgumentException("Invalid user");
  }
  String
      query = "select UK.UserToKioskId as UserToKioskId, UK.* FROM USERTOKIOSK UK, KIOSK K where "
      + "UK.USERID = ? AND K.KIOSKID = UK.KIOSKID";
  List<String> parameters = new ArrayList<>(1);
  parameters.add(user.getUserId());
  if (StringUtils.isNotEmpty(routeTag)) {
    query += " AND UK.TG = ?";
    parameters.add(routeTag);
  }

  if(user.isRteEnabled() || routeTag != null){
    query += " ORDER BY UK.RI ASC";
  } else {
    query += " ORDER BY K.NAME ASC";
  }

  if (pageParams != null) {
    query  +=
        " LIMIT " + pageParams.getOffset() + CharacterConstants.COMMA + pageParams.getSize();
  }
  // Execute
  Query jdoQuery = pm.newQuery("javax.jdo.query.SQL", query);
  jdoQuery.setClass(UserToKiosk.class);
  List<UserToKiosk> results;
  List<IKiosk> kiosks = null;
  try {
    results = (List<UserToKiosk>) jdoQuery.executeWithArray(parameters.toArray());
    if (results != null && !results.isEmpty()) {
      kiosks = new ArrayList<>();
      for (IUserToKiosk uk : results) {
        try {
          IKiosk k = JDOUtils.getObjectById(IKiosk.class, uk.getKioskId(), pm);
          k = pm.detachCopy(k);
          k.setRouteIndex(uk.getRouteIndex());
          k.setRouteTag(uk.getTag());
          kiosks.add(k);
        } catch (JDOObjectNotFoundException e) {
          xLogger.warn("User's {0} kiosk {1} does not exist ", user.getUserId(), uk.getKioskId());
        }
      }
    }
  } finally {
    try {
      jdoQuery.closeAll();

    } catch (Exception ignored) {
      xLogger.warn("Exception while closing query", ignored);
    }
    pm.close();
  }
  return new Results(kiosks, null);
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:60,代碼來源:EntitiesServiceImpl.java

示例14: getLastMessage

import javax.jdo.Query; //導入方法依賴的package包/類
public IMessage getLastMessage(String convId, String objectType, String objectId){
  PersistenceManager pm = null;
  Query query = null;
  IMessage message = null;

  List<String> queryParamArray = new ArrayList<>();
  StringBuilder queryString = new StringBuilder("SELECT * FROM MESSAGE WHERE ");
  if (StringUtils.isNotBlank(convId)) {
    queryString.append("CONVERSATIONID = ").append(CharacterConstants.QUESTION);
    queryParamArray.add(convId);
  } else if (StringUtils.isNotBlank(objectType) && StringUtils.isNotBlank(objectId)) {
    queryString.append("CONVERSATIONID IN ( SELECT ID FROM CONVERSATION WHERE ")
            .append("OBJECTID = ").append(CharacterConstants.QUESTION)
            .append(" AND OBJECTTYPE = ").append(CharacterConstants.QUESTION)
            .append(" ) ");
    queryParamArray.add(objectId);
    queryParamArray.add(objectType);
  } else {
    throw new IllegalArgumentException(
            "One of conversation Id, and Object type/id combination is mandatory");
  }
  final String orderBy = " ORDER BY CREATEDATE DESC";
  queryString.append(orderBy);
  String limitStr = " LIMIT 1";
  queryString.append(limitStr);
  try {
    pm = PMF.get().getPersistenceManager();
    query = pm.newQuery("javax.jdo.query.SQL", queryString.toString());
    query.setClass(Message.class);

    List<Message> msgList = null;
    msgList = (List<Message>) query.executeWithArray(queryParamArray.toArray());
    msgList = (List<Message>) pm.detachCopyAll(msgList);
    if (msgList.size() > 0)
      message = msgList.get(0);
  } catch (Exception e){
    xLogger.severe("Exception while querying last message of conversation", e);
  } finally {
    if (query != null) {
      try {
        query.closeAll();
      } catch (Exception ignored) {
        xLogger.warn("Exception while closing query", ignored);
      }
    }
    if (pm != null) {
      pm.close();
    }
  }
  return message;
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:52,代碼來源:MessageDao.java

示例15: getReportData

import javax.jdo.Query; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
@Override
public ReportData getReportData(Date from, Date until, String frequency,
                                Map<String, Object> filters, Locale locale, String timezone,
                                PageParams pageParams, DomainConfig dc, String sourceUserId)
    throws ReportingDataException {
  xLogger.fine("Entered StockEventDataGenerator.getReportData");
  // Execute query
  PersistenceManager pm = PMF.get().getPersistenceManager();
  int count = 0;
  // Query q = pm.newQuery( queryStr );
  boolean isAbnormalStockReport =
      ((filters.get(ReportsConstants.FILTER_ABNORMALSTOCKVIEW) != null)
          && (boolean) filters.get(ReportsConstants.FILTER_ABNORMALSTOCKVIEW));
  List results = null;
  String cursor = null;

  QueryParams queryParams =
      getReportQuery(
          from, until, frequency, filters, locale, timezone, pageParams, dc, sourceUserId);
  Query q = null;
  if (isAbnormalStockReport) {
    q = pm.newQuery("javax.jdo.query.SQL", queryParams.query);
    q.setClass(JDOUtils.getImplClass(IInvntry.class));
  } else {
    q = pm.newQuery(queryParams.query);
  }
  if (pageParams != null) {
    QueryUtil.setPageParams(q, pageParams);
  }
  xLogger.fine("Query: {0}, QueryParams: {1}", q, queryParams.params);
  try {
    // results = (List<InvntryEvntLog>) q.executeWithMap( params );
      results = (List<IInvntryEvntLog>) q.executeWithMap(queryParams.params);
    if(isAbnormalStockReport) {
      queryParams =
          getReportQuery(
              from, until, frequency, filters, locale, timezone, pageParams, dc, sourceUserId,
              true);
      q = pm.newQuery("javax.jdo.query.SQL", queryParams.query);
      count = ((Long) ((List) q.executeWithMap(queryParams.params)).iterator().next()).intValue();
    }
    if (results != null) {
      results.size();
      cursor = QueryUtil.getCursor(results);
      results = (List<IInvntryEvntLog>) pm.detachCopyAll(results);
    }
  } finally {
    try {
      q.closeAll();
    } catch (Exception ignored) {
      xLogger.warn("Exception while closing query", ignored);
    }
    pm.close();
  }

  xLogger.fine("Exiting StockEventDataGenerator.getReportData");
  return new StockEventData(from, until, filters, locale, timezone, results, cursor, count);
}
 
開發者ID:logistimo,項目名稱:logistimo-web-service,代碼行數:60,代碼來源:StockEventDataGenerator.java


注:本文中的javax.jdo.Query.setClass方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。