File: faq.rst

package info (click to toggle)
svgpp 1.3.1%2Bdfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,520 kB
  • sloc: cpp: 30,524; makefile: 165; python: 73; xml: 48; sh: 36
file content (81 lines) | stat: -rw-r--r-- 3,596 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
FAQ
==========

Compiler error: "Too many template arguments for class template 'document_traversal'"
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""

Increase BOOST_PARAMETER_MAX_ARITY value from default ``8`` value. Place define like this before any Boost or SVG++ include::

  #define BOOST_PARAMETER_MAX_ARITY 15


SVG++ stops parsing on incorrect attribute value and throws exception
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""

SVG Specification says "The document shall be rendered up to, but not including, the first element which has an error". 
Therefore such behavior is correct, it will be better to fix SVG document.

But if you want to continue rendering document ignoring error in an attribute, you should inherit your class 
from ``policy::error::raise_exception``, override its ``parse_failed`` method to not throw exception, 
but return ``true`` instead::

  struct custom_error_policy: svgpp::policy::error::raise_exception<BaseContext>
  {
      template<class AttributeTag, class AttributeValue>
      static bool parse_failed(BaseContext const &, AttributeTag,
                               AttributeValue const & value)
      {
          return true;
      }
  };

where ``BaseContext`` is common base class for all contexts.
Then pass this new class as template parameter ``error_policy`` to ``document_traversal`` class::

  document_traversal<
    error_policy<custom_error_policy>
    /* ... */
  >::/* ... */

.. _external-parser_section:

Compiler is out of memory or compilation takes too long
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""

Some compilers (e.g. Visual C++, especially 2015) may have difficulties building advanced applications
that uses SVG++ library. 
Heavy usage of templates in SVG++ itself and also in its dependencies Boost.Spirit and Boost.MPL 
results in large number of templates instantiated during compilation.

SVG++ 1.1 introduces some workaround about this problem - some Boost.Spirit parsers now can be
moved to another translation unit at the cost of additional call to the virtual function on each value that
the parser produces.

Before first SVG++ header is included some macro should be defined for each parser to be moved::

  #define SVGPP_USE_EXTERNAL_PATH_DATA_PARSER
  #define SVGPP_USE_EXTERNAL_TRANSFORM_PARSER
  #define SVGPP_USE_EXTERNAL_PRESERVE_ASPECT_RATIO_PARSER
  #define SVGPP_USE_EXTERNAL_PAINT_PARSER
  #define SVGPP_USE_EXTERNAL_MISC_PARSER
  #define SVGPP_USE_EXTERNAL_COLOR_PARSER
  #define SVGPP_USE_EXTERNAL_LENGTH_PARSER


And new source file should be added to the project that contains instantiations for some templates with 
parameters used in the application::

  #include <svgpp/parser/external_function/parse_all_impl.hpp>

  SVGPP_PARSE_PATH_DATA_IMPL(const char *, double)
  SVGPP_PARSE_TRANSFORM_IMPL(const char *, double)
  SVGPP_PARSE_PAINT_IMPL    (const char *, color_factory_t, svgpp::factory::icc_color::default_factory)
  SVGPP_PARSE_COLOR_IMPL    (const char *, color_factory_t, svgpp::factory::icc_color::default_factory)
  SVGPP_PARSE_PRESERVE_ASPECT_RATIO_IMPL(const char *)
  SVGPP_PARSE_MISC_IMPL     (const char *, double)
  SVGPP_PARSE_CLIP_IMPL     (const char *, length_factory_t)
  SVGPP_PARSE_LENGTH_IMPL   (const char *, length_factory_t)

First parameters to ``SVGPP_PARSE_..._IMPL()`` macros are type of iterators
that are provided by used XML parser policy. 
And the other parameters are *coordinate* type or different factories types used.