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


C++ SampleInfoSeq::length方法代码示例

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


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

示例1:

    CORBA::ULong
    Reader_T<READER_TYPE, TYPED_DDS_READER, VALUE_TYPE, SEQ_VALUE_TYPE>::get_nr_valid_samples (
      const ::DDS::SampleInfoSeq& sample_infos,
      const bool determine_last)
    {
      DDS4CCM_TRACE ("Reader_T::get_nr_valid_samples");

      CORBA::ULong nr_of_samples = 0;
      if (determine_last)
        {
          for (::CORBA::ULong i = 0 ; i < sample_infos.length(); ++i)
            {
              if (sample_infos[i].valid_data &&
                  sample_infos[i].sample_rank == 0)
                {
                  ++nr_of_samples;
                }
            }
        }
      else
        {
          for (::CORBA::ULong i = 0 ; i < sample_infos.length(); ++i)
            {
              if (sample_infos[i].valid_data)
                {
                  ++nr_of_samples;
                }
            }
        }
      return nr_of_samples;
    }
开发者ID:CCJY,项目名称:ATCD,代码行数:31,代码来源:Reader_T.cpp

示例2: if

    ::DDS::ReturnCode_t
    DataReader_T <TYPED_DDS_READER, TYPED_READER_TYPE, VALUE_TYPE, SEQ_TYPE, RTI_SEQ_TYPE>::complete_read (
        RTI_SEQ_TYPE & dds_data_values,
        SEQ_TYPE & data_values,
        DDS_SampleInfoSeq & dds_sample_infos,
        ::DDS::SampleInfoSeq & sample_infos,
        const ::DDS::ReturnCode_t & retcode,
        const char * method_name)
    {
      if (retcode == ::DDS::RETCODE_OK)
        {
          data_values.length (dds_data_values.length ());
          sample_infos.length (dds_sample_infos.length ());

          for (::DDS_Long i = 0 ; i < dds_sample_infos.length(); ++i)
            {
              sample_infos[i] <<= dds_sample_infos[i];
              data_values[i] = dds_data_values[i];
            }
        }
      else if (retcode != ::DDS::RETCODE_NO_DATA)
        {
          DDS4CCM_ERROR (DDS4CCM_LOG_LEVEL_ERROR, (LM_ERROR, DDS4CCM_INFO
                        ACE_TEXT ("DataReader_T::%C - ")
                        ACE_TEXT ("Error while reading samples from DDS - <%C>\n"),
                        method_name,
                        ::CIAO::DDS4CCM::translate_retcode (retcode)));
        }
      ::DDS::ReturnCode_t const retcode_return_loan =
        this->rti_entity ()->return_loan (dds_data_values, dds_sample_infos);
      if (retcode_return_loan != ::DDS::RETCODE_OK)
        {
          DDS4CCM_ERROR (DDS4CCM_LOG_LEVEL_ERROR, (LM_ERROR, DDS4CCM_INFO
                        ACE_TEXT ("DataReader_T::%C - ")
                        ACE_TEXT ("Error returning loan to DDS - <%C>\n"),
                        method_name,
                        ::CIAO::DDS4CCM::translate_retcode (retcode_return_loan)));
          // In case a read action from DDS causes errors, the users wants to see
          // this error (and not the return loan error).
          if (retcode  == ::DDS::RETCODE_OK)
            return retcode_return_loan;
        }
      return retcode;
    }
开发者ID:CCJY,项目名称:ATCD,代码行数:44,代码来源:DataReader_T.cpp

示例3: run

void EBRouter::run() {

   DDSEventChannel::EventContainerSeq eventContainerSeq;
   DDSEventChannel::EventContainer rcvEventContainer;
   DDS::SampleInfoSeq infoSeq;

   init();

   while (!shutdownRequested) {

      eventContainerDataReader->take_w_condition(eventContainerSeq, infoSeq,
            DDS::LENGTH_UNLIMITED, readCondition);

      if (infoSeq.length() > 0) {

         for (unsigned int i = 0; i < eventContainerSeq.length(); i++) {

            if (infoSeq[i].valid_data) {

               EBEvent event;
               rcvEventContainer = eventContainerSeq[i];

               event.publisherID = rcvEventContainer.publisherID;
               event.eventID = rcvEventContainer.eventID;
               event.eventCatType = rcvEventContainer.eventCatType;
               event.eventDefType = rcvEventContainer.eventDefType;
               event.eventData = rcvEventContainer.eventData;

               notifySubscribers(event);
            }
         }
      }

      eventContainerDataReader->return_loan(eventContainerSeq, infoSeq);

      publishPending();

      boost::this_thread::sleep(boost::posix_time::milliseconds(30));
   }

   threadHasComplete = true;
}
开发者ID:d0f,项目名称:msg-blit,代码行数:42,代码来源:EBRouter.cpp

示例4:

::DDS::ReturnCode_t
ROSDDS::MsgDataReader_impl::check_preconditions(
    ROSDDS::MsgSeq & received_data,
    ::DDS::SampleInfoSeq & info_seq,
    ::DDS::Long max_samples)
{
    ::DDS::ReturnCode_t status = ::DDS::RETCODE_PRECONDITION_NOT_MET;

    if ( received_data.length() == info_seq.length() &&
         received_data.maximum() == info_seq.maximum() &&
         received_data.release() == info_seq.release() ) {
        if ( received_data.maximum() == 0 || received_data.release() ) {
            if (received_data.maximum() == 0 ||
                max_samples <= static_cast<DDS::Long>(received_data.maximum()) ||
                max_samples == ::DDS::LENGTH_UNLIMITED ) {
                status = ::DDS::RETCODE_OK;
            }
        }
    }
    return status;
}
开发者ID:Chiasung,项目名称:micROS-RT,代码行数:21,代码来源:dds_messageDcps_impl.cpp

示例5:

::DDS::ReturnCode_t
rcl_interfaces::srv::dds_::Sample_SetParameters_Request_DataReader_impl::check_preconditions(
    rcl_interfaces::srv::dds_::Sample_SetParameters_Request_Seq & received_data,
    ::DDS::SampleInfoSeq & info_seq,
    ::DDS::Long max_samples)
{
    ::DDS::ReturnCode_t status = ::DDS::RETCODE_PRECONDITION_NOT_MET;

    if ( received_data.length() == info_seq.length() &&
         received_data.maximum() == info_seq.maximum() &&
         received_data.release() == info_seq.release() ) {
        if ( received_data.maximum() == 0 || received_data.release() ) {
            if (received_data.maximum() == 0 ||
                max_samples <= static_cast<DDS::Long>(received_data.maximum()) ||
                max_samples == ::DDS::LENGTH_UNLIMITED ) {
                status = ::DDS::RETCODE_OK;
            }
        }
    }
    return status;
}
开发者ID:swift-nav,项目名称:ros_rover,代码行数:21,代码来源:Sample_SetParameters_Request_Dcps_impl.cpp

示例6:

::DDS::ReturnCode_t
geometry_msgs::msg::dds_::PoseWithCovariance_DataReader_impl::check_preconditions(
    geometry_msgs::msg::dds_::PoseWithCovariance_Seq & received_data,
    ::DDS::SampleInfoSeq & info_seq,
    ::DDS::Long max_samples)
{
    ::DDS::ReturnCode_t status = ::DDS::RETCODE_PRECONDITION_NOT_MET;

    if ( received_data.length() == info_seq.length() &&
         received_data.maximum() == info_seq.maximum() &&
         received_data.release() == info_seq.release() ) {
        if ( received_data.maximum() == 0 || received_data.release() ) {
            if (received_data.maximum() == 0 ||
                max_samples <= static_cast<DDS::Long>(received_data.maximum()) ||
                max_samples == ::DDS::LENGTH_UNLIMITED ) {
                status = ::DDS::RETCODE_OK;
            }
        }
    }
    return status;
}
开发者ID:swift-nav,项目名称:ros_rover,代码行数:21,代码来源:PoseWithCovariance_Dcps_impl.cpp

示例7:

 DDS::ReturnCode_t 
PoseWithCovarianceDataReader_impl::check_preconditions(
    PoseWithCovarianceSeq & received_data,
    DDS::SampleInfoSeq & info_seq,
    CORBA::Long max_samples)
{
    DDS::ReturnCode_t status = DDS::RETCODE_PRECONDITION_NOT_MET;
    
    if ( received_data.length() == info_seq.length() &&
         received_data.maximum() == info_seq.maximum() &&
         received_data.release() == info_seq.release() ) {
        if ( received_data.maximum() == 0 || received_data.release() ) {
            if (received_data.maximum() == 0 ||
				max_samples <= static_cast<CORBA::Long>(received_data.maximum()) ||
				max_samples == DDS::LENGTH_UNLIMITED ) {
                status = DDS::RETCODE_OK;
            }
        }
    }
    return status;
}
开发者ID:ronnyh,项目名称:ros_dds_proxies,代码行数:21,代码来源:PoseWithCovarianceDcps_impl.cpp

示例8: receiveUpdates

void KVStore::receiveUpdates() {

   DDSKVStore::TransactionSeq transactionSeq;
   DDSKVStore::Transaction rcvTransaction;
   DDS::SampleInfoSeq infoSeq;

   transactionDataReader->take_w_condition(transactionSeq, infoSeq,
         DDS::LENGTH_UNLIMITED, readCondition);

   if (infoSeq.length() > 0) {

      for (unsigned int i = 0; i < transactionSeq.length(); i++) {

         if (infoSeq[i].valid_data) {

            rcvTransaction = transactionSeq[i];

            // Only update the dataStore from transactions originating
            // from other kvstore publishers
            if ((rcvTransaction.action == DDSKVStore::DBASE_SET)
                  && rcvTransaction.publisherID != publisherID) {

               for (unsigned int j = 0; j < rcvTransaction.keyValueSet.length();
                     j++) {

                  int bufferLength =
                        rcvTransaction.keyValueSet[j].byteBuffer.length();
                  KVSObject kvsObject;

                  kvsObject.key = rcvTransaction.keyValueSet[j].key;
                  kvsObject.typeInfo = rcvTransaction.keyValueSet[j].typeInfo;
                  kvsObject.numberElements =
                        rcvTransaction.keyValueSet[j].numberElements;
                  kvsObject.byteBuffer.resize(bufferLength);
                  memcpy(&kvsObject.byteBuffer[0],
                        &rcvTransaction.keyValueSet[j].byteBuffer[0],
                        bufferLength);

                  // Perform byte swapping (if required)
                  if (rcvTransaction.systemByteOrder != systemByteOrder) {

                     int8_t* value_ptr = (int8_t *) &kvsObject.byteBuffer[0];

                     switch (kvsObject.typeInfo) {

                     case DDSKVStore::TYPE_INT16:

                        if (kvsObject.numberElements == 1)
                           ByteSwapper::swapTwoBytes(value_ptr);
                        else
                           ByteSwapper::swapTwoByteArray(value_ptr,
                                 kvsObject.numberElements);
                        break;

                     case DDSKVStore::TYPE_INT32:
                     case DDSKVStore::TYPE_FLOAT:

                        if (kvsObject.numberElements == 1)
                           ByteSwapper::swapFourBytes(value_ptr);
                        else
                           ByteSwapper::swapFourByteArray(value_ptr,
                                 kvsObject.numberElements);
                        break;

                     case DDSKVStore::TYPE_INT64:
                     case DDSKVStore::TYPE_DOUBLE:
                        if (kvsObject.numberElements == 1)
                           ByteSwapper::swapEightBytes(value_ptr);
                        else
                           ByteSwapper::swapEightByteArray(value_ptr,
                                 kvsObject.numberElements);
                        break;

                     default:
                        break;
                     }
                  }

                  dataStore[kvsObject.key] = kvsObject;
               }
            }
         }
      }
   }

   transactionDataReader->return_loan(transactionSeq, infoSeq);

}
开发者ID:d0f,项目名称:msg-blit,代码行数:88,代码来源:KVStore_RT.cpp


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