/usr/include/cairomm-1.0/cairomm/script.h is in libcairomm-1.0-dev 1.12.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 | /* Copyright (C) 2014 The cairomm Development Team
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA.
*/
#ifndef __CAIROMM_SCRIPT_H
#define __CAIROMM_SCRIPT_H
#include <string>
#include <cairomm/device.h>
#include <cairomm/surface.h> // SlotWriteFunc
#include <cairomm/enums.h>
#ifdef CAIRO_HAS_SCRIPT_SURFACE
#include <cairo-script.h>
#endif
namespace Cairo {
#ifdef CAIRO_HAS_SCRIPT_SURFACE
class ScriptSurface;
/**
* A set of script output variants for the script surface.
*
* @since 1.12
*/
enum ScriptMode {
/// The output will be in readable text (default).
SCRIPT_MODE_ASCII = CAIRO_SCRIPT_MODE_ASCII,
/// The output will use byte codes.
SCRIPT_MODE_BINARY = CAIRO_SCRIPT_MODE_BINARY
};
/**
* The script surface provides the ability to render to a native script that
* matches the cairo drawing model. The scripts can be replayed using tools under
* the util/cairo-script directoriy, or with cairo-perf-trace.
*
* @since 1.12
*/
class Script : public Device {
public:
/**
* Create a C++ wrapper for the C instance. This C++ instance should then be
* given to a RefPtr.
*
* @param cobject The C instance.
* @param has_reference whether we already have a reference. Otherwise, the
* constructor will take an extra reference.
*
* @since 1.12
*/
explicit Script(cairo_device_t* cobject, bool has_reference = false);
virtual ~Script();
/**
* Converts the record operations in recording_surface into a script.
*
* @param recording_surface The recording surface to replay
*
* Throws an exception on error.
*
* @since 1.12
*/
void add_from_recording_surface(const RefPtr<ScriptSurface>& recording_surface);
/**
* Queries the script for its current output mode.
*
* @since 1.12
*/
ScriptMode get_mode() const;
/**
* Change the output mode of the script.
*
* @param mode The new mode.
*
* @since 1.12
*/
void set_mode(ScriptMode new_mode);
/**
* Emit a string verbatim into the script.
*
* @param comment The string to emit
*/
void write_comment(const std::string& comment);
/**
* Creates a output device for emitting the script, used when creating the
* individual surfaces.
*
* @param filename The name (path) of the file to write the script to.
*
* Throws an exception on error.
*
* @since 1.12
*/
static RefPtr<Script> create(const std::string& filename);
/**
* Creates a output device for emitting the script, used when creating the
* individual surfaces.
*
* @param write_func Callback function passed the bytes written to the script
*
* @since 1.12
*/
static RefPtr<Script> create_for_stream(const Surface::SlotWriteFunc& write_func);
};
#endif // CAIRO_HAS_SCRIPT_SURFACE
} // namespace Cairo
#endif //__CAIROMM_SCRIPT_SURFACE_H
|