使用反引号时程序不输出

时间:2014-10-16 14:10:32

标签: c++ linux shell output backticks

我希望将detectUpdateHomeML的输出作为命令行参数传递给名为insertElement的程序。

当我尝试使用命令

./insertElement  `./detectUpdateHomeML`

程序detectUpdateHomeML不再输出到控制台,也不会将insertElement插入XML文件。

当我用测试输出程序替换detectUpdateHomeML时,它按预期工作,输出程序输出,insertElement将输出的信息插入XML。

为什么不能使用detectUpdateHomeML

detectUpdateHomeML输出:

            std::cout << eventCount << " " << cascadeName << " " << timeFound();

            std::cout << std::flush;

int timeFound() {
  time_t rawtime;
  struct tm * timeinfo;
  char buffer [80];
  time (&rawtime);
  timeinfo = localtime (&rawtime);
  strftime (buffer,80," %Y-%m-%dT%H:%M:%S",timeinfo);
  puts (buffer);
  eventCount++;
}

insertElement代码

   #include "tinyxml2.h"
#include <iostream>

using namespace tinyxml2;

int main( int argc, const char* argv[] ) {

    XMLDocument doc;
    doc.LoadFile("homeML.xml");// Gets the root <homeML> element
    XMLElement *pRoot = doc.FirstChildElement("homeML");



/********************************************************************************************************************************************************************************
* Adds new startTimeStamp to <realTimeInformation> -> <startTimeStamp>.
* 
* TODO - data value is hard coded - it needs to enter the first time stamp recorded of that instance of object recognition.
*
********************************************************************************************************************************************************************************/
    XMLElement *pStartTimeStamp = pRoot->FirstChildElement("mobileDevice")->FirstChildElement("realTimeInformation");
    XMLElement *pRealtimeStore = nullptr;
    XMLElement *pIter0 = pStartTimeStamp->FirstChildElement("runID");
    while (pIter0 != nullptr) {
        pRealtimeStore = pIter0;
        pIter0 = pIter0->NextSiblingElement("startTimeStamp");
    }

    if (pRealtimeStore != nullptr) {
        XMLElement *pNewStartTimeStamp = doc.NewElement("startTimeStamp");
        pNewStartTimeStamp->SetText("pNewTimeStamp");
        pStartTimeStamp->InsertAfterChild(pRealtimeStore, pNewStartTimeStamp);

    }

/********************************************************************************************************************************************************************************
* Adds new mEventID to <event> -> <mEventID>
* 
* It takes in the first argument pass to the program. 
*
********************************************************************************************************************************************************************************/
    XMLElement *pmEventID = pRoot->FirstChildElement("mobileDevice")->FirstChildElement("event");
    XMLElement *pmEventIDStore = nullptr;
    XMLElement *pIter2 = pmEventID->FirstChildElement("mEventID");
    while (pIter2 != nullptr) {
        pmEventIDStore = pIter2;
        pIter2 = pIter2->NextSiblingElement("mEventID");
    }
    if (pmEventIDStore != nullptr) {
        XMLElement *pNewmEventID = doc.NewElement("mEventID");
        pNewmEventID->SetText(argv[1]);
        pmEventID->InsertAfterChild(pmEventIDStore, pNewmEventID);
    }

/********************************************************************************************************************************************************************************
* Adds new timeStamp to <event> -> <timeStamp>.
* 
* It takes in the third argument passed to the program.
*
********************************************************************************************************************************************************************************/
    XMLElement *pEvent = pRoot->FirstChildElement("mobileDevice")->FirstChildElement("event");// Gets the <event> element
    XMLElement *pPrecedent = nullptr;// This is to store the element after which will insert the new element <timeStamp>
    XMLElement *pIter = pEvent->FirstChildElement("mEventID");// Gets the first location immediately before where a <timeStamp> element should be placed
    while (pIter != nullptr) {// Loops through the children of <event> and finds the last <timeStamp> element
        pPrecedent = pIter;// Store pIter as the best known location for the new <timeStamp> element
        pIter = pIter->NextSiblingElement("timeStamp");// Attempt to find the next <timeStamp> element
    }
    if (pPrecedent != nullptr) {
        XMLElement *pNewTimeStamp = doc.NewElement("timeStamp");// Create a new <timeStamp> element
        pNewTimeStamp->SetText(argv[3]);
        pEvent->InsertAfterChild(pPrecedent, pNewTimeStamp);// Insert the new element into the document
    }

/********************************************************************************************************************************************************************************
* Adds new data to <event> -> <data>.
* 
* It takes in the second argument passed to the program.
*
********************************************************************************************************************************************************************************/
    XMLElement *pEventData = pRoot->FirstChildElement("mobileDevice")->FirstChildElement("event");
    XMLElement *pEventDataStore = nullptr;
    XMLElement *pIter1 = pEventData->FirstChildElement("timeStamp");
    while (pIter1 != nullptr) {
        pEventDataStore = pIter1;
        pIter1 = pIter1->NextSiblingElement("data");
    }

    if (pEventDataStore != nullptr) {
        XMLElement *pNewDataEvent = doc.NewElement("data");
        pNewDataEvent->SetText(argv[2]);
        pEventData->InsertAfterChild(pEventDataStore, pNewDataEvent);

    }






    doc.SaveFile("homeML.xml");
}

TestInput.cpp

#include <iostream>
int main()
{using namespace std;
    std::cout << "Hello World!" << " ";
    std:cout << "after space";
    return 0;
}

2 个答案:

答案 0 :(得分:0)

当您在反引号中运行程序时,shell会捕获其标准输出并将其替换为命令行。所以,你实际上正在执行

./insertElement {... whatever the output of ./detectUpdateHomeML is ...}

并且由于捕获了输出,因此它自然不会显示。尝试运行

OUTPUT=`./detectUpdateHomeML`
echo "output is: $OUTPUT"
./insertElement $OUTPUT

(或仅set -x)了解实际情况。


哦,这似乎只是一个shell问题 - 输出本身比你的C ++代码更有帮助。

答案 1 :(得分:0)

我认为问题是insertElement只处理它的第二个参数,因此你需要将./detectUpdateHomeML封装到引号中:

./insertElement "" "`./detectUpdateHomeML`"

甚至更好:

./insertElement "" "$( ./detectUpdateHomeML )"
相关问题