From c41c7a6a9a78aef2d1eba25137b75329431a55b5 Mon Sep 17 00:00:00 2001
From: Andy Cedilnik <andy.cedilnik@kitware.com>
Date: Thu, 8 Aug 2002 15:13:20 -0400
Subject: [PATCH] Add option of storing output to the variable

---
 Source/cmExecProgramCommand.cxx | 30 +++++++++++++++++++++++++++++-
 Source/cmExecProgramCommand.h   |  2 +-
 2 files changed, 30 insertions(+), 2 deletions(-)

diff --git a/Source/cmExecProgramCommand.cxx b/Source/cmExecProgramCommand.cxx
index 685e2fc50..431c31679 100644
--- a/Source/cmExecProgramCommand.cxx
+++ b/Source/cmExecProgramCommand.cxx
@@ -28,9 +28,28 @@ bool cmExecProgramCommand::InitialPass(std::vector<std::string> const& args)
   std::string arguments;
   bool doingargs = false;
   int count = 0;
+  std::string variable;
+  bool havevariable = false;
+  std::string e_command;
   for(size_t i=0; i < args.size(); ++i)
     {
-    if(doingargs)
+    if(args[i] == "OUTPUT_VARIABLE")
+      {
+      count++;
+      doingargs = false;
+      havevariable = true;
+      }    
+    else if ( havevariable )
+      {
+      if ( variable.size() > 0 )
+        {
+        this->SetError("called with incorrect number of arguments");
+        return false;
+        }
+      variable = args[i];
+      count ++;
+      }
+    else if(doingargs)
       {
       arguments += args[i];
       arguments += " ";
@@ -65,6 +84,15 @@ bool cmExecProgramCommand::InitialPass(std::vector<std::string> const& args)
     {
     cmSystemTools::RunCommand(command.c_str(), output);
     }
+
+  if ( variable.size() > 0 )
+    {    
+    std::string::size_type first = output.find_first_not_of(" \n\t\r");
+    std::string::size_type last = output.find_last_not_of(" \n\t\r");
+    std::string coutput = std::string(output, first, last);
+    m_Makefile->AddDefinition(variable.c_str(), coutput.c_str());
+    }
+  
   return true;
 }
 
diff --git a/Source/cmExecProgramCommand.h b/Source/cmExecProgramCommand.h
index 01acc1bc0..39af8b21c 100644
--- a/Source/cmExecProgramCommand.h
+++ b/Source/cmExecProgramCommand.h
@@ -64,7 +64,7 @@ public:
   virtual const char* GetFullDocumentation()
     {
     return
-      "EXEC_PROGRAM(Executable [Directory to run in] [ARGS arguments to executable])"
+      "EXEC_PROGRAM(Executable [Directory to run in] [ARGS arguments to executable] [OUTPUT_VARIABLE var])"
       "The executable is run in the optionally specified Directory.  The executable "
       "can include arguments if it is double quoted, but it is better to use the "
       "optional ARGS argument to specify arguments to the program.   This is because "