summaryrefslogtreecommitdiff
path: root/gettext-tools/gnulib-lib/styled-ostream.h
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2014-12-24 07:38:37 +0000
committer <>2015-02-02 12:02:29 +0000
commit482840e61f86ca321838a91e902c41d40c098bbb (patch)
tree01ea2e242fd2792d19fe192476601587901db794 /gettext-tools/gnulib-lib/styled-ostream.h
downloadgettext-tarball-482840e61f86ca321838a91e902c41d40c098bbb.tar.gz
Imported from /home/lorry/working-area/delta_gettext-tarball/gettext-0.19.4.tar.xz.gettext-0.19.4
Diffstat (limited to 'gettext-tools/gnulib-lib/styled-ostream.h')
-rw-r--r--gettext-tools/gnulib-lib/styled-ostream.h144
1 files changed, 144 insertions, 0 deletions
diff --git a/gettext-tools/gnulib-lib/styled-ostream.h b/gettext-tools/gnulib-lib/styled-ostream.h
new file mode 100644
index 0000000..9079bf8
--- /dev/null
+++ b/gettext-tools/gnulib-lib/styled-ostream.h
@@ -0,0 +1,144 @@
+/* DO NOT EDIT! GENERATED AUTOMATICALLY! */
+
+#line 1 "styled-ostream.oo.h"
+/* Abstract output stream for CSS styled text.
+ Copyright (C) 2006 Free Software Foundation, Inc.
+ Written by Bruno Haible <bruno@clisp.org>, 2006.
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
+
+#ifndef _STYLED_OSTREAM_H
+#define _STYLED_OSTREAM_H
+
+#include "ostream.h"
+
+
+/* A styled output stream is an object to which one can feed a sequence of
+ bytes, marking some runs of text as belonging to specific CSS classes,
+ where the rendering of the CSS classes is defined through a CSS (cascading
+ style sheet). */
+
+#line 33 "styled-ostream.h"
+struct styled_ostream_representation;
+/* styled_ostream_t is defined as a pointer to struct styled_ostream_representation.
+ In C++ mode, we use a smart pointer class.
+ In C mode, we have no other choice than a typedef to the root class type. */
+#if IS_CPLUSPLUS
+struct styled_ostream_t
+{
+private:
+ struct styled_ostream_representation *_pointer;
+public:
+ styled_ostream_t () : _pointer (NULL) {}
+ styled_ostream_t (struct styled_ostream_representation *pointer) : _pointer (pointer) {}
+ struct styled_ostream_representation * operator -> () { return _pointer; }
+ operator struct styled_ostream_representation * () { return _pointer; }
+ operator struct any_ostream_representation * () { return (struct any_ostream_representation *) _pointer; }
+ operator void * () { return _pointer; }
+ bool operator == (const void *p) { return _pointer == p; }
+ bool operator != (const void *p) { return _pointer != p; }
+ operator ostream_t () { return (ostream_t) (struct any_ostream_representation *) _pointer; }
+ explicit styled_ostream_t (ostream_t x) : _pointer ((struct styled_ostream_representation *) (void *) x) {}
+};
+#else
+typedef ostream_t styled_ostream_t;
+#endif
+
+/* Functions that invoke the methods. */
+extern void styled_ostream_write_mem (styled_ostream_t first_arg, const void *data, size_t len);
+extern void styled_ostream_flush (styled_ostream_t first_arg);
+extern void styled_ostream_free (styled_ostream_t first_arg);
+extern void styled_ostream_begin_use_class (styled_ostream_t first_arg, const char *classname);
+extern void styled_ostream_end_use_class (styled_ostream_t first_arg, const char *classname);
+
+/* Type representing an implementation of styled_ostream_t. */
+struct styled_ostream_implementation
+{
+ const typeinfo_t * const *superclasses;
+ size_t superclasses_length;
+ size_t instance_size;
+#define THIS_ARG styled_ostream_t first_arg
+#include "styled_ostream.vt.h"
+#undef THIS_ARG
+};
+
+/* Public portion of the object pointed to by a styled_ostream_t. */
+struct styled_ostream_representation_header
+{
+ const struct styled_ostream_implementation *vtable;
+};
+
+#if HAVE_INLINE
+
+/* Define the functions that invoke the methods as inline accesses to
+ the styled_ostream_implementation.
+ Use #define to avoid a warning because of extern vs. static. */
+
+# define styled_ostream_write_mem styled_ostream_write_mem_inline
+static inline void
+styled_ostream_write_mem (styled_ostream_t first_arg, const void *data, size_t len)
+{
+ const struct styled_ostream_implementation *vtable =
+ ((struct styled_ostream_representation_header *) (struct styled_ostream_representation *) first_arg)->vtable;
+ vtable->write_mem (first_arg,data,len);
+}
+
+# define styled_ostream_flush styled_ostream_flush_inline
+static inline void
+styled_ostream_flush (styled_ostream_t first_arg)
+{
+ const struct styled_ostream_implementation *vtable =
+ ((struct styled_ostream_representation_header *) (struct styled_ostream_representation *) first_arg)->vtable;
+ vtable->flush (first_arg);
+}
+
+# define styled_ostream_free styled_ostream_free_inline
+static inline void
+styled_ostream_free (styled_ostream_t first_arg)
+{
+ const struct styled_ostream_implementation *vtable =
+ ((struct styled_ostream_representation_header *) (struct styled_ostream_representation *) first_arg)->vtable;
+ vtable->free (first_arg);
+}
+
+# define styled_ostream_begin_use_class styled_ostream_begin_use_class_inline
+static inline void
+styled_ostream_begin_use_class (styled_ostream_t first_arg, const char *classname)
+{
+ const struct styled_ostream_implementation *vtable =
+ ((struct styled_ostream_representation_header *) (struct styled_ostream_representation *) first_arg)->vtable;
+ vtable->begin_use_class (first_arg,classname);
+}
+
+# define styled_ostream_end_use_class styled_ostream_end_use_class_inline
+static inline void
+styled_ostream_end_use_class (styled_ostream_t first_arg, const char *classname)
+{
+ const struct styled_ostream_implementation *vtable =
+ ((struct styled_ostream_representation_header *) (struct styled_ostream_representation *) first_arg)->vtable;
+ vtable->end_use_class (first_arg,classname);
+}
+
+#endif
+
+extern DLL_VARIABLE const typeinfo_t styled_ostream_typeinfo;
+#define styled_ostream_SUPERCLASSES &styled_ostream_typeinfo, ostream_SUPERCLASSES
+#define styled_ostream_SUPERCLASSES_LENGTH (1 + ostream_SUPERCLASSES_LENGTH)
+
+extern DLL_VARIABLE const struct styled_ostream_implementation styled_ostream_vtable;
+
+#line 42 "styled-ostream.oo.h"
+
+
+#endif /* _STYLED_OSTREAM_H */