[Libreoffice-commits] core.git: Branch 'feature/calc-group-interpreter-4' - sc/source

Kohei Yoshida kohei.yoshida at collabora.com
Wed Oct 30 14:28:03 CET 2013


 sc/source/core/opencl/formulagroupcl.cxx |   37 +++++++++++++++----------------
 sc/source/core/opencl/opbase.cxx         |    2 -
 sc/source/core/opencl/opbase.hxx         |   11 ++++++---
 3 files changed, 27 insertions(+), 23 deletions(-)

New commits:
commit 4a72c7e47639688875761eb633cdf2bd60825353
Author: Kohei Yoshida <kohei.yoshida at collabora.com>
Date:   Wed Oct 30 09:29:24 2013 -0400

    Let's use typedef for this.
    
    Change-Id: If2523ee085285dc47d18fce425f784caa664d73e

diff --git a/sc/source/core/opencl/formulagroupcl.cxx b/sc/source/core/opencl/formulagroupcl.cxx
index a3b21a9..b583e7c 100644
--- a/sc/source/core/opencl/formulagroupcl.cxx
+++ b/sc/source/core/opencl/formulagroupcl.cxx
@@ -93,7 +93,7 @@ class ConstStringArgument: public DynamicKernelArgument
 {
 public:
     ConstStringArgument(const std::string &s,
-        boost::shared_ptr<FormulaTreeNode> ft):
+        FormulaTreeNodeRef ft):
             DynamicKernelArgument(s, ft) {}
     /// Generate declaration
     virtual void GenDecl(std::stringstream &ss) const
@@ -151,7 +151,7 @@ class DynamicKernelConstantArgument: public DynamicKernelArgument
 {
 public:
     DynamicKernelConstantArgument(const std::string &s,
-        boost::shared_ptr<FormulaTreeNode> ft):
+        FormulaTreeNodeRef ft):
             DynamicKernelArgument(s, ft) {}
     /// Generate declaration
     virtual void GenDecl(std::stringstream &ss) const
@@ -195,7 +195,7 @@ class DynamicKernelStringArgument: public DynamicKernelArgument
 {
 public:
     DynamicKernelStringArgument(const std::string &s,
-        boost::shared_ptr<FormulaTreeNode> ft):
+        FormulaTreeNodeRef ft):
         DynamicKernelArgument(s, ft) {}
 
     virtual void GenSlidingWindowFunction(std::stringstream &) {}
@@ -268,7 +268,7 @@ class DynamicKernelSlidingArgument: public Base
 {
 public:
     DynamicKernelSlidingArgument(const std::string &s,
-        boost::shared_ptr<FormulaTreeNode> ft):
+        FormulaTreeNodeRef ft):
         Base(s, ft)
     {
         FormulaToken *t = ft->GetFormulaToken();
@@ -665,7 +665,7 @@ public:
     typedef std::vector<SubArgument> SubArgumentsType;
 
     DynamicKernelSoPArguments(const std::string &s,
-        boost::shared_ptr<FormulaTreeNode> ft);
+        FormulaTreeNodeRef ft);
 
     /// Create buffer and pass the buffer to a given kernel
     virtual size_t Marshal(cl_kernel k, int argno, int nVectorWidth)
@@ -766,7 +766,7 @@ private:
 
 template <class Op>
 boost::shared_ptr<DynamicKernelArgument> SoPHelper(const std::string &ts,
-    boost::shared_ptr<FormulaTreeNode> ft)
+    FormulaTreeNodeRef ft)
 {
     return boost::shared_ptr<DynamicKernelArgument>(
         new DynamicKernelSoPArguments<Op>(ts, ft));
@@ -774,7 +774,7 @@ boost::shared_ptr<DynamicKernelArgument> SoPHelper(const std::string &ts,
 
 template <class Op>
 DynamicKernelSoPArguments<Op>::DynamicKernelSoPArguments(const std::string &s,
-    boost::shared_ptr<FormulaTreeNode> ft):
+    FormulaTreeNodeRef ft):
     DynamicKernelArgument(s, ft) {
     size_t nChildren = ft->Children.size();
 
@@ -1113,7 +1113,7 @@ public:
     typedef std::list< boost::shared_ptr<DynamicKernelArgument> > ArgumentList;
     SymbolTable(void):mCurId(0) {}
     template <class T>
-    const DynamicKernelArgument *DeclRefArg(boost::shared_ptr<FormulaTreeNode>);
+    const DynamicKernelArgument *DeclRefArg(FormulaTreeNodeRef);
     /// Used to generate sliding window helpers
     void DumpSlidingWindowFunctions(std::stringstream &ss)
     {
@@ -1144,7 +1144,7 @@ void SymbolTable::Marshal(cl_kernel k, int nVectorWidth)
 /// Code generation
 class DynamicKernel {
 public:
-    DynamicKernel(boost::shared_ptr<FormulaTreeNode> r):mpRoot(r),
+    DynamicKernel(FormulaTreeNodeRef r):mpRoot(r),
         mpProgram(NULL), mpKernel(NULL), mpResClmem(NULL) {}
     /// Code generation in OpenCL
     std::string CodeGen() {
@@ -1228,8 +1228,8 @@ public:
     ~DynamicKernel();
     cl_mem GetResultBuffer(void) const { return mpResClmem; }
 private:
-    void TraverseAST(boost::shared_ptr<FormulaTreeNode>);
-    boost::shared_ptr<FormulaTreeNode> mpRoot;
+    void TraverseAST(FormulaTreeNodeRef);
+    FormulaTreeNodeRef mpRoot;
     SymbolTable mSyms;
     std::string mKernelSignature, mKernelHash;
     std::string mFullProgramSrc;
@@ -1290,7 +1290,7 @@ void DynamicKernel::CreateKernel(void)
 // The template argument T must be a subclass of DynamicKernelArgument
 template <typename T>
 const DynamicKernelArgument *SymbolTable::DeclRefArg(
-                  boost::shared_ptr<FormulaTreeNode> t)
+                  FormulaTreeNodeRef t)
 {
     FormulaToken *ref = t->GetFormulaToken();
     ArgumentMap::iterator it = mSymbols.find(ref);
@@ -1351,15 +1351,15 @@ bool FormulaGroupInterpreterOpenCL::interpret( ScDocument& rDoc,
     // Constructing "AST"
     FormulaTokenIterator aCode = rCode;
     std::list<FormulaToken *> list;
-    std::map<FormulaToken *, boost::shared_ptr<FormulaTreeNode> > m_hash_map;
+    std::map<FormulaToken *, FormulaTreeNodeRef> m_hash_map;
     FormulaToken*  pCur;
     while( (pCur = (FormulaToken*)(aCode.Next()) ) != NULL)
     {
         OpCode eOp = pCur->GetOpCode();
         if ( eOp != ocPush )
         {
-            boost::shared_ptr<FormulaTreeNode> m_currNode =
-                 boost::shared_ptr<FormulaTreeNode>(new FormulaTreeNode(pCur));
+            FormulaTreeNodeRef m_currNode =
+                 FormulaTreeNodeRef(new FormulaTreeNode(pCur));
             sal_uInt8 m_ParamCount =  pCur->GetParamCount();
             for(int i=0; i<m_ParamCount; i++)
             {
@@ -1373,8 +1373,8 @@ bool FormulaGroupInterpreterOpenCL::interpret( ScDocument& rDoc,
                 }
                 else
                 {
-                    boost::shared_ptr<FormulaTreeNode> m_ChildTreeNode =
-                      boost::shared_ptr<FormulaTreeNode>(
+                    FormulaTreeNodeRef m_ChildTreeNode =
+                      FormulaTreeNodeRef(
                                new FormulaTreeNode(m_TempFormula));
                     m_currNode->Children.push_back(m_ChildTreeNode);
                 }
@@ -1386,8 +1386,7 @@ bool FormulaGroupInterpreterOpenCL::interpret( ScDocument& rDoc,
         list.push_back(pCur);
     }
 
-    boost::shared_ptr<FormulaTreeNode> Root =
-            boost::shared_ptr<FormulaTreeNode>(new FormulaTreeNode(NULL));
+    FormulaTreeNodeRef Root = FormulaTreeNodeRef(new FormulaTreeNode(NULL));
     Root->Children.push_back(m_hash_map[list.back()]);
     // Code generation
     mpKernel = new DynamicKernel(Root);
diff --git a/sc/source/core/opencl/opbase.cxx b/sc/source/core/opencl/opbase.cxx
index ec59e7a..88042ef 100644
--- a/sc/source/core/opencl/opbase.cxx
+++ b/sc/source/core/opencl/opbase.cxx
@@ -16,7 +16,7 @@ using namespace formula;
 namespace sc { namespace opencl {
 
 DynamicKernelArgument::DynamicKernelArgument(const std::string &s,
-   boost::shared_ptr<FormulaTreeNode> ft):
+   FormulaTreeNodeRef ft):
     mSymName(s), mFormulaTree(ft), mpClmem(NULL) {}
 
 /// Generate declaration
diff --git a/sc/source/core/opencl/opbase.hxx b/sc/source/core/opencl/opbase.hxx
index a858ede..63327b1 100644
--- a/sc/source/core/opencl/opbase.hxx
+++ b/sc/source/core/opencl/opbase.hxx
@@ -19,6 +19,9 @@
 #define ISNAN
 
 namespace sc { namespace opencl {
+
+class FormulaTreeNode;
+
 /// Exceptions
 
 /// Failed in parsing
@@ -46,6 +49,8 @@ public:
     Unhandled() {}
 };
 
+typedef boost::shared_ptr<FormulaTreeNode> FormulaTreeNodeRef;
+
 class FormulaTreeNode
 {
 public:
@@ -53,7 +58,7 @@ public:
     {
         Children.reserve(8);
     }
-    std::vector<boost::shared_ptr<FormulaTreeNode> > Children;
+    std::vector<FormulaTreeNodeRef> Children;
     formula::FormulaToken *GetFormulaToken(void) const
     {
         return mpCurrentFormula;
@@ -70,7 +75,7 @@ private:
 class DynamicKernelArgument
 {
 public:
-    DynamicKernelArgument(const std::string &s, boost::shared_ptr<FormulaTreeNode> ft);
+    DynamicKernelArgument(const std::string &s, FormulaTreeNodeRef ft);
 
     const std::string &GetNameAsString(void) const { return mSymName; }
     /// Generate declaration
@@ -98,7 +103,7 @@ public:
     const std::string& GetName(void) const { return mSymName; }
 protected:
     const std::string mSymName;
-    boost::shared_ptr<FormulaTreeNode> mFormulaTree;
+    FormulaTreeNodeRef mFormulaTree;
     // Used by marshaling
     cl_mem mpClmem;
 };


More information about the Libreoffice-commits mailing list