// Checked: 2010-09-28 (RLVa-1.1.3a) | Added: RLVa-1.2.1c RlvCommandOptionGetPath::RlvCommandOptionGetPath(const RlvCommand& rlvCmd) : m_fValid(true) // Assume the option will be a valid one until we find out otherwise { // @getpath[:<option>]=<channel> => <option> is transformed to a list of inventory item UUIDs to get the path of RlvCommandOptionGeneric rlvCmdOption(rlvCmd.getOption()); if (rlvCmdOption.isWearableType()) // <option> can be a clothing layer { EWearableType wtType = rlvCmdOption.getWearableType(); m_idItems.push_back(gAgent.getWearableItem(wtType)); } else if (rlvCmdOption.isAttachmentPoint()) // ... or it can specify an attachment point { const LLViewerJointAttachment* pAttachPt = rlvCmdOption.getAttachmentPoint(); for (LLViewerJointAttachment::attachedobjs_vec_t::const_iterator itAttachObj = pAttachPt->mAttachedObjects.begin(); itAttachObj != pAttachPt->mAttachedObjects.end(); ++itAttachObj) { m_idItems.push_back((*itAttachObj)->getAttachmentItemID()); } } else if (rlvCmdOption.isEmpty()) // ... or it can be empty (in which case we act on the object that issued the command) { const LLViewerObject* pObj = gObjectList.findObject(rlvCmd.getObjectID()); if ( (pObj) || (pObj->isAttachment()) ) m_idItems.push_back(pObj->getAttachmentItemID()); } else // ... but anything else isn't a valid option { m_fValid = false; } }
// Checked: 2010-11-30 (RLVa-1.3.0b) | Modified: RLVa-1.3.0b RlvCommandOptionGetPath::RlvCommandOptionGetPath(const RlvCommand& rlvCmd) { m_fValid = true; // Assume the option will be a valid one until we find out otherwise // @getpath[:<option>]=<channel> => <option> is transformed to a list of inventory item UUIDs to get the path of RlvCommandOptionGeneric rlvCmdOption(rlvCmd.getOption()); if (rlvCmdOption.isWearableType()) // <option> can be a clothing layer { getItemIDs(rlvCmdOption.getWearableType(), m_idItems, false); } else if (rlvCmdOption.isAttachmentPoint()) // ... or it can specify an attachment point { getItemIDs(rlvCmdOption.getAttachmentPoint(), m_idItems, false); } else if (rlvCmdOption.isEmpty()) // ... or it can be empty (in which case we act on the object that issued the command) { const LLViewerObject* pObj = gObjectList.findObject(rlvCmd.getObjectID()); if ( (pObj) || (pObj->isAttachment()) ) m_idItems.push_back(pObj->getAttachmentItemID()); } else // ... but anything else isn't a valid option { m_fValid = false; } }
// Checked: 2009-12-23 (RLVa-1.1.0k) | Modified: RLVa-1.1.0k bool RlvExtGetSet::processCommand(const RlvCommand& rlvCmd, ERlvCmdRet& eRet) { std::string strBehaviour = rlvCmd.getBehaviour(), strGetSet, strSetting; int idxSetting = strBehaviour.find('_'); if ( (strBehaviour.length() >= 6) && (-1 != idxSetting) && ((int)strBehaviour.length() > idxSetting + 1) ) { strSetting = strBehaviour.substr(idxSetting + 1); strBehaviour.erase(idxSetting); // Get rid of "_<setting>" strGetSet = strBehaviour.substr(0, 3); strBehaviour.erase(0, 3); // Get rid of get/set if ("debug" == strBehaviour) { if ( ("get" == strGetSet) && (RLV_TYPE_REPLY == rlvCmd.getParamType()) ) { RlvUtil::sendChatReply(rlvCmd.getParam(), onGetDebug(strSetting)); eRet = RLV_RET_SUCCESS; return true; } else if ( ("set" == strGetSet) && (RLV_TYPE_FORCE == rlvCmd.getParamType()) ) { if (!gRlvHandler.hasBehaviourExcept(RLV_BHVR_SETDEBUG, rlvCmd.getObjectID())) eRet = onSetDebug(strSetting, rlvCmd.getOption()); else eRet = RLV_RET_FAILED_LOCK; return true; } } else if ("env" == strBehaviour) { if ( ("get" == strGetSet) && (RLV_TYPE_REPLY == rlvCmd.getParamType()) ) { RlvUtil::sendChatReply(rlvCmd.getParam(), onGetEnv(strSetting)); eRet = RLV_RET_SUCCESS; return true; } else if ( ("set" == strGetSet) && (RLV_TYPE_FORCE == rlvCmd.getParamType()) ) { if (!gRlvHandler.hasBehaviourExcept(RLV_BHVR_SETENV, rlvCmd.getObjectID())) eRet = onSetEnv(strSetting, rlvCmd.getOption()); else eRet = RLV_RET_FAILED_LOCK; return true; } } } else if ("setrot" == rlvCmd.getBehaviour()) { // NOTE: if <option> is invalid (or missing) altogether then RLV-1.17 will rotate to 0.0 (which is actually PI / 4) F32 nAngle = 0.0f; if (LLStringUtil::convertToF32(rlvCmd.getOption(), nAngle)) { nAngle = RLV_SETROT_OFFSET - nAngle; gAgent.startCameraAnimation(); LLVector3 at(LLVector3::x_axis); at.rotVec(nAngle, LLVector3::z_axis); at.normalize(); gAgent.resetAxes(at); eRet = RLV_RET_SUCCESS; } else { eRet = RLV_RET_FAILED_OPTION; } return true; } return false; }