os/ossrv/ossrv_pub/boost_apis/boost/bind/storage.hpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
#ifndef BOOST_BIND_STORAGE_HPP_INCLUDED
sl@0
     2
#define BOOST_BIND_STORAGE_HPP_INCLUDED
sl@0
     3
sl@0
     4
// MS compatible compilers support #pragma once
sl@0
     5
sl@0
     6
#if defined(_MSC_VER) && (_MSC_VER >= 1020)
sl@0
     7
# pragma once
sl@0
     8
#endif
sl@0
     9
sl@0
    10
//
sl@0
    11
//  bind/storage.hpp
sl@0
    12
//
sl@0
    13
//  boost/bind.hpp support header, optimized storage
sl@0
    14
//
sl@0
    15
//  Copyright (c) 2006 Peter Dimov
sl@0
    16
//
sl@0
    17
//  Distributed under the Boost Software License, Version 1.0.
sl@0
    18
//  See accompanying file LICENSE_1_0.txt or copy at
sl@0
    19
//  http://www.boost.org/LICENSE_1_0.txt
sl@0
    20
//
sl@0
    21
//  See http://www.boost.org/libs/bind/bind.html for documentation.
sl@0
    22
//
sl@0
    23
sl@0
    24
#include <boost/config.hpp>
sl@0
    25
#include <boost/bind/arg.hpp>
sl@0
    26
sl@0
    27
#ifdef BOOST_MSVC
sl@0
    28
# pragma warning(push)
sl@0
    29
# pragma warning(disable: 4512) // assignment operator could not be generated
sl@0
    30
#endif
sl@0
    31
sl@0
    32
namespace boost
sl@0
    33
{
sl@0
    34
sl@0
    35
namespace _bi
sl@0
    36
{
sl@0
    37
sl@0
    38
// 1
sl@0
    39
sl@0
    40
template<class A1> struct storage1
sl@0
    41
{
sl@0
    42
    explicit storage1( A1 a1 ): a1_( a1 ) {}
sl@0
    43
sl@0
    44
    template<class V> void accept(V & v) const
sl@0
    45
    {
sl@0
    46
        BOOST_BIND_VISIT_EACH(v, a1_, 0);
sl@0
    47
    }
sl@0
    48
sl@0
    49
    A1 a1_;
sl@0
    50
};
sl@0
    51
sl@0
    52
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION ) && !defined( __BORLANDC__ )
sl@0
    53
sl@0
    54
template<int I> struct storage1< boost::arg<I> >
sl@0
    55
{
sl@0
    56
    explicit storage1( boost::arg<I> ) {}
sl@0
    57
sl@0
    58
    template<class V> void accept(V &) const { }
sl@0
    59
sl@0
    60
    static boost::arg<I> a1_() { return boost::arg<I>(); }
sl@0
    61
};
sl@0
    62
sl@0
    63
template<int I> struct storage1< boost::arg<I> (*) () >
sl@0
    64
{
sl@0
    65
    explicit storage1( boost::arg<I> (*) () ) {}
sl@0
    66
sl@0
    67
    template<class V> void accept(V &) const { }
sl@0
    68
sl@0
    69
    static boost::arg<I> a1_() { return boost::arg<I>(); }
sl@0
    70
};
sl@0
    71
sl@0
    72
#endif
sl@0
    73
sl@0
    74
// 2
sl@0
    75
sl@0
    76
template<class A1, class A2> struct storage2: public storage1<A1>
sl@0
    77
{
sl@0
    78
    typedef storage1<A1> inherited;
sl@0
    79
sl@0
    80
    storage2( A1 a1, A2 a2 ): storage1<A1>( a1 ), a2_( a2 ) {}
sl@0
    81
sl@0
    82
    template<class V> void accept(V & v) const
sl@0
    83
    {
sl@0
    84
        inherited::accept(v);
sl@0
    85
        BOOST_BIND_VISIT_EACH(v, a2_, 0);
sl@0
    86
    }
sl@0
    87
sl@0
    88
    A2 a2_;
sl@0
    89
};
sl@0
    90
sl@0
    91
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
    92
sl@0
    93
template<class A1, int I> struct storage2< A1, boost::arg<I> >: public storage1<A1>
sl@0
    94
{
sl@0
    95
    typedef storage1<A1> inherited;
sl@0
    96
sl@0
    97
    storage2( A1 a1, boost::arg<I> ): storage1<A1>( a1 ) {}
sl@0
    98
sl@0
    99
    template<class V> void accept(V & v) const
sl@0
   100
    {
sl@0
   101
        inherited::accept(v);
sl@0
   102
    }
sl@0
   103
sl@0
   104
    static boost::arg<I> a2_() { return boost::arg<I>(); }
sl@0
   105
};
sl@0
   106
sl@0
   107
template<class A1, int I> struct storage2< A1, boost::arg<I> (*) () >: public storage1<A1>
sl@0
   108
{
sl@0
   109
    typedef storage1<A1> inherited;
sl@0
   110
sl@0
   111
    storage2( A1 a1, boost::arg<I> (*) () ): storage1<A1>( a1 ) {}
sl@0
   112
sl@0
   113
    template<class V> void accept(V & v) const
sl@0
   114
    {
sl@0
   115
        inherited::accept(v);
sl@0
   116
    }
sl@0
   117
sl@0
   118
    static boost::arg<I> a2_() { return boost::arg<I>(); }
sl@0
   119
};
sl@0
   120
sl@0
   121
#endif
sl@0
   122
sl@0
   123
// 3
sl@0
   124
sl@0
   125
template<class A1, class A2, class A3> struct storage3: public storage2< A1, A2 >
sl@0
   126
{
sl@0
   127
    typedef storage2<A1, A2> inherited;
sl@0
   128
sl@0
   129
    storage3( A1 a1, A2 a2, A3 a3 ): storage2<A1, A2>( a1, a2 ), a3_( a3 ) {}
sl@0
   130
sl@0
   131
    template<class V> void accept(V & v) const
sl@0
   132
    {
sl@0
   133
        inherited::accept(v);
sl@0
   134
        BOOST_BIND_VISIT_EACH(v, a3_, 0);
sl@0
   135
    }
sl@0
   136
sl@0
   137
    A3 a3_;
sl@0
   138
};
sl@0
   139
sl@0
   140
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   141
sl@0
   142
template<class A1, class A2, int I> struct storage3< A1, A2, boost::arg<I> >: public storage2< A1, A2 >
sl@0
   143
{
sl@0
   144
    typedef storage2<A1, A2> inherited;
sl@0
   145
sl@0
   146
    storage3( A1 a1, A2 a2, boost::arg<I> ): storage2<A1, A2>( a1, a2 ) {}
sl@0
   147
sl@0
   148
    template<class V> void accept(V & v) const
sl@0
   149
    {
sl@0
   150
        inherited::accept(v);
sl@0
   151
    }
sl@0
   152
sl@0
   153
    static boost::arg<I> a3_() { return boost::arg<I>(); }
sl@0
   154
};
sl@0
   155
sl@0
   156
template<class A1, class A2, int I> struct storage3< A1, A2, boost::arg<I> (*) () >: public storage2< A1, A2 >
sl@0
   157
{
sl@0
   158
    typedef storage2<A1, A2> inherited;
sl@0
   159
sl@0
   160
    storage3( A1 a1, A2 a2, boost::arg<I> (*) () ): storage2<A1, A2>( a1, a2 ) {}
sl@0
   161
sl@0
   162
    template<class V> void accept(V & v) const
sl@0
   163
    {
sl@0
   164
        inherited::accept(v);
sl@0
   165
    }
sl@0
   166
sl@0
   167
    static boost::arg<I> a3_() { return boost::arg<I>(); }
sl@0
   168
};
sl@0
   169
sl@0
   170
#endif
sl@0
   171
sl@0
   172
// 4
sl@0
   173
sl@0
   174
template<class A1, class A2, class A3, class A4> struct storage4: public storage3< A1, A2, A3 >
sl@0
   175
{
sl@0
   176
    typedef storage3<A1, A2, A3> inherited;
sl@0
   177
sl@0
   178
    storage4( A1 a1, A2 a2, A3 a3, A4 a4 ): storage3<A1, A2, A3>( a1, a2, a3 ), a4_( a4 ) {}
sl@0
   179
sl@0
   180
    template<class V> void accept(V & v) const
sl@0
   181
    {
sl@0
   182
        inherited::accept(v);
sl@0
   183
        BOOST_BIND_VISIT_EACH(v, a4_, 0);
sl@0
   184
    }
sl@0
   185
sl@0
   186
    A4 a4_;
sl@0
   187
};
sl@0
   188
sl@0
   189
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   190
sl@0
   191
template<class A1, class A2, class A3, int I> struct storage4< A1, A2, A3, boost::arg<I> >: public storage3< A1, A2, A3 >
sl@0
   192
{
sl@0
   193
    typedef storage3<A1, A2, A3> inherited;
sl@0
   194
sl@0
   195
    storage4( A1 a1, A2 a2, A3 a3, boost::arg<I> ): storage3<A1, A2, A3>( a1, a2, a3 ) {}
sl@0
   196
sl@0
   197
    template<class V> void accept(V & v) const
sl@0
   198
    {
sl@0
   199
        inherited::accept(v);
sl@0
   200
    }
sl@0
   201
sl@0
   202
    static boost::arg<I> a4_() { return boost::arg<I>(); }
sl@0
   203
};
sl@0
   204
sl@0
   205
template<class A1, class A2, class A3, int I> struct storage4< A1, A2, A3, boost::arg<I> (*) () >: public storage3< A1, A2, A3 >
sl@0
   206
{
sl@0
   207
    typedef storage3<A1, A2, A3> inherited;
sl@0
   208
sl@0
   209
    storage4( A1 a1, A2 a2, A3 a3, boost::arg<I> (*) () ): storage3<A1, A2, A3>( a1, a2, a3 ) {}
sl@0
   210
sl@0
   211
    template<class V> void accept(V & v) const
sl@0
   212
    {
sl@0
   213
        inherited::accept(v);
sl@0
   214
    }
sl@0
   215
sl@0
   216
    static boost::arg<I> a4_() { return boost::arg<I>(); }
sl@0
   217
};
sl@0
   218
sl@0
   219
#endif
sl@0
   220
sl@0
   221
// 5
sl@0
   222
sl@0
   223
template<class A1, class A2, class A3, class A4, class A5> struct storage5: public storage4< A1, A2, A3, A4 >
sl@0
   224
{
sl@0
   225
    typedef storage4<A1, A2, A3, A4> inherited;
sl@0
   226
sl@0
   227
    storage5( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5 ): storage4<A1, A2, A3, A4>( a1, a2, a3, a4 ), a5_( a5 ) {}
sl@0
   228
sl@0
   229
    template<class V> void accept(V & v) const
sl@0
   230
    {
sl@0
   231
        inherited::accept(v);
sl@0
   232
        BOOST_BIND_VISIT_EACH(v, a5_, 0);
sl@0
   233
    }
sl@0
   234
sl@0
   235
    A5 a5_;
sl@0
   236
};
sl@0
   237
sl@0
   238
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   239
sl@0
   240
template<class A1, class A2, class A3, class A4, int I> struct storage5< A1, A2, A3, A4, boost::arg<I> >: public storage4< A1, A2, A3, A4 >
sl@0
   241
{
sl@0
   242
    typedef storage4<A1, A2, A3, A4> inherited;
sl@0
   243
sl@0
   244
    storage5( A1 a1, A2 a2, A3 a3, A4 a4, boost::arg<I> ): storage4<A1, A2, A3, A4>( a1, a2, a3, a4 ) {}
sl@0
   245
sl@0
   246
    template<class V> void accept(V & v) const
sl@0
   247
    {
sl@0
   248
        inherited::accept(v);
sl@0
   249
    }
sl@0
   250
sl@0
   251
    static boost::arg<I> a5_() { return boost::arg<I>(); }
sl@0
   252
};
sl@0
   253
sl@0
   254
template<class A1, class A2, class A3, class A4, int I> struct storage5< A1, A2, A3, A4, boost::arg<I> (*) () >: public storage4< A1, A2, A3, A4 >
sl@0
   255
{
sl@0
   256
    typedef storage4<A1, A2, A3, A4> inherited;
sl@0
   257
sl@0
   258
    storage5( A1 a1, A2 a2, A3 a3, A4 a4, boost::arg<I> (*) () ): storage4<A1, A2, A3, A4>( a1, a2, a3, a4 ) {}
sl@0
   259
sl@0
   260
    template<class V> void accept(V & v) const
sl@0
   261
    {
sl@0
   262
        inherited::accept(v);
sl@0
   263
    }
sl@0
   264
sl@0
   265
    static boost::arg<I> a5_() { return boost::arg<I>(); }
sl@0
   266
};
sl@0
   267
sl@0
   268
#endif
sl@0
   269
sl@0
   270
// 6
sl@0
   271
sl@0
   272
template<class A1, class A2, class A3, class A4, class A5, class A6> struct storage6: public storage5< A1, A2, A3, A4, A5 >
sl@0
   273
{
sl@0
   274
    typedef storage5<A1, A2, A3, A4, A5> inherited;
sl@0
   275
sl@0
   276
    storage6( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6 ): storage5<A1, A2, A3, A4, A5>( a1, a2, a3, a4, a5 ), a6_( a6 ) {}
sl@0
   277
sl@0
   278
    template<class V> void accept(V & v) const
sl@0
   279
    {
sl@0
   280
        inherited::accept(v);
sl@0
   281
        BOOST_BIND_VISIT_EACH(v, a6_, 0);
sl@0
   282
    }
sl@0
   283
sl@0
   284
    A6 a6_;
sl@0
   285
};
sl@0
   286
sl@0
   287
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   288
sl@0
   289
template<class A1, class A2, class A3, class A4, class A5, int I> struct storage6< A1, A2, A3, A4, A5, boost::arg<I> >: public storage5< A1, A2, A3, A4, A5 >
sl@0
   290
{
sl@0
   291
    typedef storage5<A1, A2, A3, A4, A5> inherited;
sl@0
   292
sl@0
   293
    storage6( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, boost::arg<I> ): storage5<A1, A2, A3, A4, A5>( a1, a2, a3, a4, a5 ) {}
sl@0
   294
sl@0
   295
    template<class V> void accept(V & v) const
sl@0
   296
    {
sl@0
   297
        inherited::accept(v);
sl@0
   298
    }
sl@0
   299
sl@0
   300
    static boost::arg<I> a6_() { return boost::arg<I>(); }
sl@0
   301
};
sl@0
   302
sl@0
   303
template<class A1, class A2, class A3, class A4, class A5, int I> struct storage6< A1, A2, A3, A4, A5, boost::arg<I> (*) () >: public storage5< A1, A2, A3, A4, A5 >
sl@0
   304
{
sl@0
   305
    typedef storage5<A1, A2, A3, A4, A5> inherited;
sl@0
   306
sl@0
   307
    storage6( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, boost::arg<I> (*) () ): storage5<A1, A2, A3, A4, A5>( a1, a2, a3, a4, a5 ) {}
sl@0
   308
sl@0
   309
    template<class V> void accept(V & v) const
sl@0
   310
    {
sl@0
   311
        inherited::accept(v);
sl@0
   312
    }
sl@0
   313
sl@0
   314
    static boost::arg<I> a6_() { return boost::arg<I>(); }
sl@0
   315
};
sl@0
   316
sl@0
   317
#endif
sl@0
   318
sl@0
   319
// 7
sl@0
   320
sl@0
   321
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7> struct storage7: public storage6< A1, A2, A3, A4, A5, A6 >
sl@0
   322
{
sl@0
   323
    typedef storage6<A1, A2, A3, A4, A5, A6> inherited;
sl@0
   324
sl@0
   325
    storage7( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7 ): storage6<A1, A2, A3, A4, A5, A6>( a1, a2, a3, a4, a5, a6 ), a7_( a7 ) {}
sl@0
   326
sl@0
   327
    template<class V> void accept(V & v) const
sl@0
   328
    {
sl@0
   329
        inherited::accept(v);
sl@0
   330
        BOOST_BIND_VISIT_EACH(v, a7_, 0);
sl@0
   331
    }
sl@0
   332
sl@0
   333
    A7 a7_;
sl@0
   334
};
sl@0
   335
sl@0
   336
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   337
sl@0
   338
template<class A1, class A2, class A3, class A4, class A5, class A6, int I> struct storage7< A1, A2, A3, A4, A5, A6, boost::arg<I> >: public storage6< A1, A2, A3, A4, A5, A6 >
sl@0
   339
{
sl@0
   340
    typedef storage6<A1, A2, A3, A4, A5, A6> inherited;
sl@0
   341
sl@0
   342
    storage7( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, boost::arg<I> ): storage6<A1, A2, A3, A4, A5, A6>( a1, a2, a3, a4, a5, a6 ) {}
sl@0
   343
sl@0
   344
    template<class V> void accept(V & v) const
sl@0
   345
    {
sl@0
   346
        inherited::accept(v);
sl@0
   347
    }
sl@0
   348
sl@0
   349
    static boost::arg<I> a7_() { return boost::arg<I>(); }
sl@0
   350
};
sl@0
   351
sl@0
   352
template<class A1, class A2, class A3, class A4, class A5, class A6, int I> struct storage7< A1, A2, A3, A4, A5, A6, boost::arg<I> (*) () >: public storage6< A1, A2, A3, A4, A5, A6 >
sl@0
   353
{
sl@0
   354
    typedef storage6<A1, A2, A3, A4, A5, A6> inherited;
sl@0
   355
sl@0
   356
    storage7( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, boost::arg<I> (*) () ): storage6<A1, A2, A3, A4, A5, A6>( a1, a2, a3, a4, a5, a6 ) {}
sl@0
   357
sl@0
   358
    template<class V> void accept(V & v) const
sl@0
   359
    {
sl@0
   360
        inherited::accept(v);
sl@0
   361
    }
sl@0
   362
sl@0
   363
    static boost::arg<I> a7_() { return boost::arg<I>(); }
sl@0
   364
};
sl@0
   365
sl@0
   366
#endif
sl@0
   367
sl@0
   368
// 8
sl@0
   369
sl@0
   370
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8> struct storage8: public storage7< A1, A2, A3, A4, A5, A6, A7 >
sl@0
   371
{
sl@0
   372
    typedef storage7<A1, A2, A3, A4, A5, A6, A7> inherited;
sl@0
   373
sl@0
   374
    storage8( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8 ): storage7<A1, A2, A3, A4, A5, A6, A7>( a1, a2, a3, a4, a5, a6, a7 ), a8_( a8 ) {}
sl@0
   375
sl@0
   376
    template<class V> void accept(V & v) const
sl@0
   377
    {
sl@0
   378
        inherited::accept(v);
sl@0
   379
        BOOST_BIND_VISIT_EACH(v, a8_, 0);
sl@0
   380
    }
sl@0
   381
sl@0
   382
    A8 a8_;
sl@0
   383
};
sl@0
   384
sl@0
   385
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   386
sl@0
   387
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7, int I> struct storage8< A1, A2, A3, A4, A5, A6, A7, boost::arg<I> >: public storage7< A1, A2, A3, A4, A5, A6, A7 >
sl@0
   388
{
sl@0
   389
    typedef storage7<A1, A2, A3, A4, A5, A6, A7> inherited;
sl@0
   390
sl@0
   391
    storage8( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, boost::arg<I> ): storage7<A1, A2, A3, A4, A5, A6, A7>( a1, a2, a3, a4, a5, a6, a7 ) {}
sl@0
   392
sl@0
   393
    template<class V> void accept(V & v) const
sl@0
   394
    {
sl@0
   395
        inherited::accept(v);
sl@0
   396
    }
sl@0
   397
sl@0
   398
    static boost::arg<I> a8_() { return boost::arg<I>(); }
sl@0
   399
};
sl@0
   400
sl@0
   401
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7, int I> struct storage8< A1, A2, A3, A4, A5, A6, A7, boost::arg<I> (*) () >: public storage7< A1, A2, A3, A4, A5, A6, A7 >
sl@0
   402
{
sl@0
   403
    typedef storage7<A1, A2, A3, A4, A5, A6, A7> inherited;
sl@0
   404
sl@0
   405
    storage8( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, boost::arg<I> (*) () ): storage7<A1, A2, A3, A4, A5, A6, A7>( a1, a2, a3, a4, a5, a6, a7 ) {}
sl@0
   406
sl@0
   407
    template<class V> void accept(V & v) const
sl@0
   408
    {
sl@0
   409
        inherited::accept(v);
sl@0
   410
    }
sl@0
   411
sl@0
   412
    static boost::arg<I> a8_() { return boost::arg<I>(); }
sl@0
   413
};
sl@0
   414
sl@0
   415
#endif
sl@0
   416
sl@0
   417
// 9
sl@0
   418
sl@0
   419
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8, class A9> struct storage9: public storage8< A1, A2, A3, A4, A5, A6, A7, A8 >
sl@0
   420
{
sl@0
   421
    typedef storage8<A1, A2, A3, A4, A5, A6, A7, A8> inherited;
sl@0
   422
sl@0
   423
    storage9( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9 ): storage8<A1, A2, A3, A4, A5, A6, A7, A8>( a1, a2, a3, a4, a5, a6, a7, a8 ), a9_( a9 ) {}
sl@0
   424
sl@0
   425
    template<class V> void accept(V & v) const
sl@0
   426
    {
sl@0
   427
        inherited::accept(v);
sl@0
   428
        BOOST_BIND_VISIT_EACH(v, a9_, 0);
sl@0
   429
    }
sl@0
   430
sl@0
   431
    A9 a9_;
sl@0
   432
};
sl@0
   433
sl@0
   434
#if !defined( BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION )
sl@0
   435
sl@0
   436
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8, int I> struct storage9< A1, A2, A3, A4, A5, A6, A7, A8, boost::arg<I> >: public storage8< A1, A2, A3, A4, A5, A6, A7, A8 >
sl@0
   437
{
sl@0
   438
    typedef storage8<A1, A2, A3, A4, A5, A6, A7, A8> inherited;
sl@0
   439
sl@0
   440
    storage9( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, boost::arg<I> ): storage8<A1, A2, A3, A4, A5, A6, A7, A8>( a1, a2, a3, a4, a5, a6, a7, a8 ) {}
sl@0
   441
sl@0
   442
    template<class V> void accept(V & v) const
sl@0
   443
    {
sl@0
   444
        inherited::accept(v);
sl@0
   445
    }
sl@0
   446
sl@0
   447
    static boost::arg<I> a9_() { return boost::arg<I>(); }
sl@0
   448
};
sl@0
   449
sl@0
   450
template<class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8, int I> struct storage9< A1, A2, A3, A4, A5, A6, A7, A8, boost::arg<I> (*) () >: public storage8< A1, A2, A3, A4, A5, A6, A7, A8 >
sl@0
   451
{
sl@0
   452
    typedef storage8<A1, A2, A3, A4, A5, A6, A7, A8> inherited;
sl@0
   453
sl@0
   454
    storage9( A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, boost::arg<I> (*) () ): storage8<A1, A2, A3, A4, A5, A6, A7, A8>( a1, a2, a3, a4, a5, a6, a7, a8 ) {}
sl@0
   455
sl@0
   456
    template<class V> void accept(V & v) const
sl@0
   457
    {
sl@0
   458
        inherited::accept(v);
sl@0
   459
    }
sl@0
   460
sl@0
   461
    static boost::arg<I> a9_() { return boost::arg<I>(); }
sl@0
   462
};
sl@0
   463
sl@0
   464
#endif
sl@0
   465
sl@0
   466
} // namespace _bi
sl@0
   467
sl@0
   468
} // namespace boost
sl@0
   469
sl@0
   470
#ifdef BOOST_MSVC
sl@0
   471
# pragma warning(default: 4512) // assignment operator could not be generated
sl@0
   472
# pragma warning(pop)
sl@0
   473
#endif
sl@0
   474
sl@0
   475
#endif // #ifndef BOOST_BIND_STORAGE_HPP_INCLUDED