Home | History | Annotate | Line # | Download | only in libcc1
rpc.hh revision 1.1.1.1
      1  1.1  mrg /* RPC call and callback templates
      2  1.1  mrg    Copyright (C) 2014 Free Software Foundation, Inc.
      3  1.1  mrg 
      4  1.1  mrg This file is part of GCC.
      5  1.1  mrg 
      6  1.1  mrg GCC is free software; you can redistribute it and/or modify it under
      7  1.1  mrg the terms of the GNU General Public License as published by the Free
      8  1.1  mrg Software Foundation; either version 3, or (at your option) any later
      9  1.1  mrg version.
     10  1.1  mrg 
     11  1.1  mrg GCC is distributed in the hope that it will be useful, but WITHOUT ANY
     12  1.1  mrg WARRANTY; without even the implied warranty of MERCHANTABILITY or
     13  1.1  mrg FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
     14  1.1  mrg for more details.
     15  1.1  mrg 
     16  1.1  mrg You should have received a copy of the GNU General Public License
     17  1.1  mrg along with GCC; see the file COPYING3.  If not see
     18  1.1  mrg <http://www.gnu.org/licenses/>.  */
     19  1.1  mrg 
     20  1.1  mrg #ifndef CC1_PLUGIN_RPC_HH
     21  1.1  mrg #define CC1_PLUGIN_RPC_HH
     22  1.1  mrg 
     23  1.1  mrg #include "status.hh"
     24  1.1  mrg #include "marshall.hh"
     25  1.1  mrg #include "connection.hh"
     26  1.1  mrg 
     27  1.1  mrg namespace cc1_plugin
     28  1.1  mrg {
     29  1.1  mrg   // The plugin API may contain some "const" method parameters.
     30  1.1  mrg   // However, when unmarshalling we cannot unmarshall into a const
     31  1.1  mrg   // object; and furthermore we want to be able to deallocate pointers
     32  1.1  mrg   // when finished with them.  This wrapper class lets us properly
     33  1.1  mrg   // remove the "const" and handle deallocation from pointer types.
     34  1.1  mrg 
     35  1.1  mrg   template<typename T>
     36  1.1  mrg   class argument_wrapper
     37  1.1  mrg   {
     38  1.1  mrg   public:
     39  1.1  mrg 
     40  1.1  mrg     argument_wrapper () { }
     41  1.1  mrg     ~argument_wrapper () { }
     42  1.1  mrg 
     43  1.1  mrg     operator T () const { return m_object; }
     44  1.1  mrg 
     45  1.1  mrg     status unmarshall (connection *conn)
     46  1.1  mrg     {
     47  1.1  mrg       return ::cc1_plugin::unmarshall (conn, &m_object);
     48  1.1  mrg     }
     49  1.1  mrg 
     50  1.1  mrg   private:
     51  1.1  mrg 
     52  1.1  mrg     T m_object;
     53  1.1  mrg 
     54  1.1  mrg     // No copying or assignment allowed.
     55  1.1  mrg     argument_wrapper (const argument_wrapper &);
     56  1.1  mrg     argument_wrapper &operator= (const argument_wrapper &);
     57  1.1  mrg   };
     58  1.1  mrg 
     59  1.1  mrg   // Specialization for any kind of pointer.  This is declared but not
     60  1.1  mrg   // defined to avoid bugs if a new pointer type is introduced into
     61  1.1  mrg   // the API.  Instead you will just get a compilation error.
     62  1.1  mrg   template<typename T>
     63  1.1  mrg   class argument_wrapper<const T *>;
     64  1.1  mrg 
     65  1.1  mrg   // Specialization for string types.
     66  1.1  mrg   template<>
     67  1.1  mrg   class argument_wrapper<const char *>
     68  1.1  mrg   {
     69  1.1  mrg   public:
     70  1.1  mrg     argument_wrapper () : m_object (NULL) { }
     71  1.1  mrg     ~argument_wrapper ()
     72  1.1  mrg     {
     73  1.1  mrg       delete[] m_object;
     74  1.1  mrg     }
     75  1.1  mrg 
     76  1.1  mrg     operator const char * () const
     77  1.1  mrg     {
     78  1.1  mrg       return m_object;
     79  1.1  mrg     }
     80  1.1  mrg 
     81  1.1  mrg     status unmarshall (connection *conn)
     82  1.1  mrg     {
     83  1.1  mrg       return ::cc1_plugin::unmarshall (conn, &m_object);
     84  1.1  mrg     }
     85  1.1  mrg 
     86  1.1  mrg   private:
     87  1.1  mrg 
     88  1.1  mrg     char *m_object;
     89  1.1  mrg 
     90  1.1  mrg     // No copying or assignment allowed.
     91  1.1  mrg     argument_wrapper (const argument_wrapper &);
     92  1.1  mrg     argument_wrapper &operator= (const argument_wrapper &);
     93  1.1  mrg   };
     94  1.1  mrg 
     95  1.1  mrg   // Specialization for gcc_type_array.
     96  1.1  mrg   template<>
     97  1.1  mrg   class argument_wrapper<const gcc_type_array *>
     98  1.1  mrg   {
     99  1.1  mrg   public:
    100  1.1  mrg     argument_wrapper () : m_object (NULL) { }
    101  1.1  mrg     ~argument_wrapper ()
    102  1.1  mrg     {
    103  1.1  mrg       // It would be nicer if gcc_type_array could have a destructor.
    104  1.1  mrg       // But, it is in code shared with gdb and cannot.
    105  1.1  mrg       if (m_object != NULL)
    106  1.1  mrg 	delete[] m_object->elements;
    107  1.1  mrg       delete m_object;
    108  1.1  mrg     }
    109  1.1  mrg 
    110  1.1  mrg     operator const gcc_type_array * () const
    111  1.1  mrg     {
    112  1.1  mrg       return m_object;
    113  1.1  mrg     }
    114  1.1  mrg 
    115  1.1  mrg     status unmarshall (connection *conn)
    116  1.1  mrg     {
    117  1.1  mrg       return ::cc1_plugin::unmarshall (conn, &m_object);
    118  1.1  mrg     }
    119  1.1  mrg 
    120  1.1  mrg   private:
    121  1.1  mrg 
    122  1.1  mrg     gcc_type_array *m_object;
    123  1.1  mrg 
    124  1.1  mrg     // No copying or assignment allowed.
    125  1.1  mrg     argument_wrapper (const argument_wrapper &);
    126  1.1  mrg     argument_wrapper &operator= (const argument_wrapper &);
    127  1.1  mrg   };
    128  1.1  mrg 
    129  1.1  mrg   // There are two kinds of template functions here: "call" and
    130  1.1  mrg   // "callback".  They are each repeated multiple times to handle
    131  1.1  mrg   // different numbers of arguments.  (This would be improved with
    132  1.1  mrg   // C++11, though applying a call is still tricky until C++14 can be
    133  1.1  mrg   // used.)
    134  1.1  mrg 
    135  1.1  mrg   // The "call" template is used for making a remote procedure call.
    136  1.1  mrg   // It starts a query ('Q') packet, marshalls its arguments, waits
    137  1.1  mrg   // for a result, and finally reads and returns the result via an
    138  1.1  mrg   // "out" parameter.
    139  1.1  mrg 
    140  1.1  mrg   // The "callback" template is used when receiving a remote procedure
    141  1.1  mrg   // call.  This template function is suitable for use with the
    142  1.1  mrg   // "callbacks" and "connection" classes.  It decodes incoming
    143  1.1  mrg   // arguments, passes them to the wrapped function, and finally
    144  1.1  mrg   // marshalls a reply packet.
    145  1.1  mrg 
    146  1.1  mrg   template<typename R>
    147  1.1  mrg   status
    148  1.1  mrg   call (connection *conn, const char *method, R *result)
    149  1.1  mrg   {
    150  1.1  mrg     if (!conn->send ('Q'))
    151  1.1  mrg       return FAIL;
    152  1.1  mrg     if (!marshall (conn, method))
    153  1.1  mrg       return FAIL;
    154  1.1  mrg     if (!marshall (conn, 0))
    155  1.1  mrg       return FAIL;
    156  1.1  mrg     if (!conn->wait_for_result ())
    157  1.1  mrg       return FAIL;
    158  1.1  mrg     if (!unmarshall (conn, result))
    159  1.1  mrg       return FAIL;
    160  1.1  mrg     return OK;
    161  1.1  mrg   }
    162  1.1  mrg 
    163  1.1  mrg   template<typename R, R (*func) (connection *)>
    164  1.1  mrg   status
    165  1.1  mrg   callback (connection *conn)
    166  1.1  mrg   {
    167  1.1  mrg     R result;
    168  1.1  mrg 
    169  1.1  mrg     if (!unmarshall_check (conn, 0))
    170  1.1  mrg       return FAIL;
    171  1.1  mrg     result = func (conn);
    172  1.1  mrg     if (!conn->send ('R'))
    173  1.1  mrg       return FAIL;
    174  1.1  mrg     return marshall (conn, result);
    175  1.1  mrg   }
    176  1.1  mrg 
    177  1.1  mrg   template<typename R, typename A>
    178  1.1  mrg   status
    179  1.1  mrg   call (connection *conn, const char *method, R *result, A arg)
    180  1.1  mrg   {
    181  1.1  mrg     if (!conn->send ('Q'))
    182  1.1  mrg       return FAIL;
    183  1.1  mrg     if (!marshall (conn, method))
    184  1.1  mrg       return FAIL;
    185  1.1  mrg     if (!marshall (conn, 1))
    186  1.1  mrg       return FAIL;
    187  1.1  mrg     if (!marshall (conn, arg))
    188  1.1  mrg       return FAIL;
    189  1.1  mrg     if (!conn->wait_for_result ())
    190  1.1  mrg       return FAIL;
    191  1.1  mrg     if (!unmarshall (conn, result))
    192  1.1  mrg       return FAIL;
    193  1.1  mrg     return OK;
    194  1.1  mrg   }
    195  1.1  mrg 
    196  1.1  mrg   template<typename R, typename A, R (*func) (connection *, A)>
    197  1.1  mrg   status
    198  1.1  mrg   callback (connection *conn)
    199  1.1  mrg   {
    200  1.1  mrg     argument_wrapper<A> arg;
    201  1.1  mrg     R result;
    202  1.1  mrg 
    203  1.1  mrg     if (!unmarshall_check (conn, 1))
    204  1.1  mrg       return FAIL;
    205  1.1  mrg     if (!arg.unmarshall (conn))
    206  1.1  mrg       return FAIL;
    207  1.1  mrg     result = func (conn, arg);
    208  1.1  mrg     if (!conn->send ('R'))
    209  1.1  mrg       return FAIL;
    210  1.1  mrg     return marshall (conn, result);
    211  1.1  mrg   }
    212  1.1  mrg 
    213  1.1  mrg   template<typename R, typename A1, typename A2>
    214  1.1  mrg   status
    215  1.1  mrg   call (connection *conn, const char *method, R *result, A1 arg1, A2 arg2)
    216  1.1  mrg   {
    217  1.1  mrg     if (!conn->send ('Q'))
    218  1.1  mrg       return FAIL;
    219  1.1  mrg     if (!marshall (conn, method))
    220  1.1  mrg       return FAIL;
    221  1.1  mrg     if (!marshall (conn, 2))
    222  1.1  mrg       return FAIL;
    223  1.1  mrg     if (!marshall (conn, arg1))
    224  1.1  mrg       return FAIL;
    225  1.1  mrg     if (!marshall (conn, arg2))
    226  1.1  mrg       return FAIL;
    227  1.1  mrg     if (!conn->wait_for_result ())
    228  1.1  mrg       return FAIL;
    229  1.1  mrg     if (!unmarshall (conn, result))
    230  1.1  mrg       return FAIL;
    231  1.1  mrg     return OK;
    232  1.1  mrg   }
    233  1.1  mrg 
    234  1.1  mrg   template<typename R, typename A1, typename A2, R (*func) (connection *,
    235  1.1  mrg 							    A1, A2)>
    236  1.1  mrg   status
    237  1.1  mrg   callback (connection *conn)
    238  1.1  mrg   {
    239  1.1  mrg     argument_wrapper<A1> arg1;
    240  1.1  mrg     argument_wrapper<A2> arg2;
    241  1.1  mrg     R result;
    242  1.1  mrg 
    243  1.1  mrg     if (!unmarshall_check (conn, 2))
    244  1.1  mrg       return FAIL;
    245  1.1  mrg     if (!arg1.unmarshall (conn))
    246  1.1  mrg       return FAIL;
    247  1.1  mrg     if (!arg2.unmarshall (conn))
    248  1.1  mrg       return FAIL;
    249  1.1  mrg     result = func (conn, arg1, arg2);
    250  1.1  mrg     if (!conn->send ('R'))
    251  1.1  mrg       return FAIL;
    252  1.1  mrg     return marshall (conn, result);
    253  1.1  mrg   }
    254  1.1  mrg 
    255  1.1  mrg   template<typename R, typename A1, typename A2, typename A3>
    256  1.1  mrg   status
    257  1.1  mrg   call (connection *conn, const char *method, R *result, A1 arg1, A2 arg2,
    258  1.1  mrg 	A3 arg3)
    259  1.1  mrg   {
    260  1.1  mrg     if (!conn->send ('Q'))
    261  1.1  mrg       return FAIL;
    262  1.1  mrg     if (!marshall (conn, method))
    263  1.1  mrg       return FAIL;
    264  1.1  mrg     if (!marshall (conn, 3))
    265  1.1  mrg       return FAIL;
    266  1.1  mrg     if (!marshall (conn, arg1))
    267  1.1  mrg       return FAIL;
    268  1.1  mrg     if (!marshall (conn, arg2))
    269  1.1  mrg       return FAIL;
    270  1.1  mrg     if (!marshall (conn, arg3))
    271  1.1  mrg       return FAIL;
    272  1.1  mrg     if (!conn->wait_for_result ())
    273  1.1  mrg       return FAIL;
    274  1.1  mrg     if (!unmarshall (conn, result))
    275  1.1  mrg       return FAIL;
    276  1.1  mrg     return OK;
    277  1.1  mrg   }
    278  1.1  mrg 
    279  1.1  mrg   template<typename R, typename A1, typename A2, typename A3,
    280  1.1  mrg 	   R (*func) (connection *, A1, A2, A3)>
    281  1.1  mrg   status
    282  1.1  mrg   callback (connection *conn)
    283  1.1  mrg   {
    284  1.1  mrg     argument_wrapper<A1> arg1;
    285  1.1  mrg     argument_wrapper<A2> arg2;
    286  1.1  mrg     argument_wrapper<A3> arg3;
    287  1.1  mrg     R result;
    288  1.1  mrg 
    289  1.1  mrg     if (!unmarshall_check (conn, 3))
    290  1.1  mrg       return FAIL;
    291  1.1  mrg     if (!arg1.unmarshall (conn))
    292  1.1  mrg       return FAIL;
    293  1.1  mrg     if (!arg2.unmarshall (conn))
    294  1.1  mrg       return FAIL;
    295  1.1  mrg     if (!arg3.unmarshall (conn))
    296  1.1  mrg       return FAIL;
    297  1.1  mrg     result = func (conn, arg1, arg2, arg3);
    298  1.1  mrg     if (!conn->send ('R'))
    299  1.1  mrg       return FAIL;
    300  1.1  mrg     return marshall (conn, result);
    301  1.1  mrg   }
    302  1.1  mrg 
    303  1.1  mrg   template<typename R, typename A1, typename A2, typename A3, typename A4>
    304  1.1  mrg   status
    305  1.1  mrg   call (connection *conn, const char *method, R *result, A1 arg1, A2 arg2,
    306  1.1  mrg 	A3 arg3, A4 arg4)
    307  1.1  mrg   {
    308  1.1  mrg     if (!conn->send ('Q'))
    309  1.1  mrg       return FAIL;
    310  1.1  mrg     if (!marshall (conn, method))
    311  1.1  mrg       return FAIL;
    312  1.1  mrg     if (!marshall (conn, 4))
    313  1.1  mrg       return FAIL;
    314  1.1  mrg     if (!marshall (conn, arg1))
    315  1.1  mrg       return FAIL;
    316  1.1  mrg     if (!marshall (conn, arg2))
    317  1.1  mrg       return FAIL;
    318  1.1  mrg     if (!marshall (conn, arg3))
    319  1.1  mrg       return FAIL;
    320  1.1  mrg     if (!marshall (conn, arg4))
    321  1.1  mrg       return FAIL;
    322  1.1  mrg     if (!conn->wait_for_result ())
    323  1.1  mrg       return FAIL;
    324  1.1  mrg     if (!unmarshall (conn, result))
    325  1.1  mrg       return FAIL;
    326  1.1  mrg     return OK;
    327  1.1  mrg   }
    328  1.1  mrg 
    329  1.1  mrg   template<typename R, typename A1, typename A2, typename A3, typename A4,
    330  1.1  mrg 	   R (*func) (connection *, A1, A2, A3, A4)>
    331  1.1  mrg   status
    332  1.1  mrg   callback (connection *conn)
    333  1.1  mrg   {
    334  1.1  mrg     argument_wrapper<A1> arg1;
    335  1.1  mrg     argument_wrapper<A2> arg2;
    336  1.1  mrg     argument_wrapper<A3> arg3;
    337  1.1  mrg     argument_wrapper<A4> arg4;
    338  1.1  mrg     R result;
    339  1.1  mrg 
    340  1.1  mrg     if (!unmarshall_check (conn, 4))
    341  1.1  mrg       return FAIL;
    342  1.1  mrg     if (!arg1.unmarshall (conn))
    343  1.1  mrg       return FAIL;
    344  1.1  mrg     if (!arg2.unmarshall (conn))
    345  1.1  mrg       return FAIL;
    346  1.1  mrg     if (!arg3.unmarshall (conn))
    347  1.1  mrg       return FAIL;
    348  1.1  mrg     if (!arg4.unmarshall (conn))
    349  1.1  mrg       return FAIL;
    350  1.1  mrg     result = func (conn, arg1, arg2, arg3, arg4);
    351  1.1  mrg     if (!conn->send ('R'))
    352  1.1  mrg       return FAIL;
    353  1.1  mrg     return marshall (conn, result);
    354  1.1  mrg   }
    355  1.1  mrg 
    356  1.1  mrg   template<typename R, typename A1, typename A2, typename A3, typename A4,
    357  1.1  mrg 	   typename A5>
    358  1.1  mrg   status
    359  1.1  mrg   call (connection *conn, const char *method, R *result, A1 arg1, A2 arg2,
    360  1.1  mrg 	A3 arg3, A4 arg4, A5 arg5)
    361  1.1  mrg   {
    362  1.1  mrg     if (!conn->send ('Q'))
    363  1.1  mrg       return FAIL;
    364  1.1  mrg     if (!marshall (conn, method))
    365  1.1  mrg       return FAIL;
    366  1.1  mrg     if (!marshall (conn, 5))
    367  1.1  mrg       return FAIL;
    368  1.1  mrg     if (!marshall (conn, arg1))
    369  1.1  mrg       return FAIL;
    370  1.1  mrg     if (!marshall (conn, arg2))
    371  1.1  mrg       return FAIL;
    372  1.1  mrg     if (!marshall (conn, arg3))
    373  1.1  mrg       return FAIL;
    374  1.1  mrg     if (!marshall (conn, arg4))
    375  1.1  mrg       return FAIL;
    376  1.1  mrg     if (!marshall (conn, arg5))
    377  1.1  mrg       return FAIL;
    378  1.1  mrg     if (!conn->wait_for_result ())
    379  1.1  mrg       return FAIL;
    380  1.1  mrg     if (!unmarshall (conn, result))
    381  1.1  mrg       return FAIL;
    382  1.1  mrg     return OK;
    383  1.1  mrg   }
    384  1.1  mrg 
    385  1.1  mrg   template<typename R, typename A1, typename A2, typename A3, typename A4,
    386  1.1  mrg 	   typename A5, R (*func) (connection *, A1, A2, A3, A4, A5)>
    387  1.1  mrg   status
    388  1.1  mrg   callback (connection *conn)
    389  1.1  mrg   {
    390  1.1  mrg     argument_wrapper<A1> arg1;
    391  1.1  mrg     argument_wrapper<A2> arg2;
    392  1.1  mrg     argument_wrapper<A3> arg3;
    393  1.1  mrg     argument_wrapper<A4> arg4;
    394  1.1  mrg     argument_wrapper<A5> arg5;
    395  1.1  mrg     R result;
    396  1.1  mrg 
    397  1.1  mrg     if (!unmarshall_check (conn, 5))
    398  1.1  mrg       return FAIL;
    399  1.1  mrg     if (!arg1.unmarshall (conn))
    400  1.1  mrg       return FAIL;
    401  1.1  mrg     if (!arg2.unmarshall (conn))
    402  1.1  mrg       return FAIL;
    403  1.1  mrg     if (!arg3.unmarshall (conn))
    404  1.1  mrg       return FAIL;
    405  1.1  mrg     if (!arg4.unmarshall (conn))
    406  1.1  mrg       return FAIL;
    407  1.1  mrg     if (!arg5.unmarshall (conn))
    408  1.1  mrg       return FAIL;
    409  1.1  mrg     result = func (conn, arg1, arg2, arg3, arg4, arg5);
    410  1.1  mrg     if (!conn->send ('R'))
    411  1.1  mrg       return FAIL;
    412  1.1  mrg     return marshall (conn, result);
    413  1.1  mrg   }
    414  1.1  mrg 
    415  1.1  mrg   template<typename R, typename A1, typename A2, typename A3, typename A4,
    416  1.1  mrg 	   typename A5, typename A6, typename A7>
    417  1.1  mrg   status
    418  1.1  mrg   call (connection *conn, const char *method, R *result, A1 arg1, A2 arg2,
    419  1.1  mrg 	A3 arg3, A4 arg4, A5 arg5, A6 arg6, A7 arg7)
    420  1.1  mrg   {
    421  1.1  mrg     if (!conn->send ('Q'))
    422  1.1  mrg       return FAIL;
    423  1.1  mrg     if (!marshall (conn, method))
    424  1.1  mrg       return FAIL;
    425  1.1  mrg     if (!marshall (conn, 7))
    426  1.1  mrg       return FAIL;
    427  1.1  mrg     if (!marshall (conn, arg1))
    428  1.1  mrg       return FAIL;
    429  1.1  mrg     if (!marshall (conn, arg2))
    430  1.1  mrg       return FAIL;
    431  1.1  mrg     if (!marshall (conn, arg3))
    432  1.1  mrg       return FAIL;
    433  1.1  mrg     if (!marshall (conn, arg4))
    434  1.1  mrg       return FAIL;
    435  1.1  mrg     if (!marshall (conn, arg5))
    436  1.1  mrg       return FAIL;
    437  1.1  mrg     if (!marshall (conn, arg6))
    438  1.1  mrg       return FAIL;
    439  1.1  mrg     if (!marshall (conn, arg7))
    440  1.1  mrg       return FAIL;
    441  1.1  mrg     if (!conn->wait_for_result ())
    442  1.1  mrg       return FAIL;
    443  1.1  mrg     if (!unmarshall (conn, result))
    444  1.1  mrg       return FAIL;
    445  1.1  mrg     return OK;
    446  1.1  mrg   }
    447  1.1  mrg 
    448  1.1  mrg   template<typename R, typename A1, typename A2, typename A3, typename A4,
    449  1.1  mrg 	   typename A5, typename A6, typename A7,
    450  1.1  mrg 	   R (*func) (connection *, A1, A2, A3, A4, A5, A6, A7)>
    451  1.1  mrg   status
    452  1.1  mrg   callback (connection *conn)
    453  1.1  mrg   {
    454  1.1  mrg     argument_wrapper<A1> arg1;
    455  1.1  mrg     argument_wrapper<A2> arg2;
    456  1.1  mrg     argument_wrapper<A3> arg3;
    457  1.1  mrg     argument_wrapper<A4> arg4;
    458  1.1  mrg     argument_wrapper<A5> arg5;
    459  1.1  mrg     argument_wrapper<A6> arg6;
    460  1.1  mrg     argument_wrapper<A7> arg7;
    461  1.1  mrg     R result;
    462  1.1  mrg 
    463  1.1  mrg     if (!unmarshall_check (conn, 7))
    464  1.1  mrg       return FAIL;
    465  1.1  mrg     if (!arg1.unmarshall (conn))
    466  1.1  mrg       return FAIL;
    467  1.1  mrg     if (!arg2.unmarshall (conn))
    468  1.1  mrg       return FAIL;
    469  1.1  mrg     if (!arg3.unmarshall (conn))
    470  1.1  mrg       return FAIL;
    471  1.1  mrg     if (!arg4.unmarshall (conn))
    472  1.1  mrg       return FAIL;
    473  1.1  mrg     if (!arg5.unmarshall (conn))
    474  1.1  mrg       return FAIL;
    475  1.1  mrg     if (!arg6.unmarshall (conn))
    476  1.1  mrg       return FAIL;
    477  1.1  mrg     if (!arg7.unmarshall (conn))
    478  1.1  mrg       return FAIL;
    479  1.1  mrg     result = func (conn, arg1, arg2, arg3, arg4, arg5, arg6, arg7);
    480  1.1  mrg     if (!conn->send ('R'))
    481  1.1  mrg       return FAIL;
    482  1.1  mrg     return marshall (conn, result);
    483  1.1  mrg   }
    484  1.1  mrg };
    485  1.1  mrg 
    486  1.1  mrg #endif // CC1_PLUGIN_RPC_HH
    487