/*
 * Copyright 2012 Google Inc.
 *
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#ifndef path_utils_DEFINED
#define path_utils_DEFINED

class SkFILEWStream;
class SkPath;

namespace sk_tools {
    // These utilities help write paths to a .cpp file in a compileable form.
    // To use call them in the order:
    //      dump_path_prefix - once per program invocation
    //      dump_path - once for each path of interest
    //      dump_path_suffix - once per program invocation
    //
    // The output system relies on a global current path ID and assumes that
    // only one set of aggregation arrays will be written per program
    // invocation. These utilities are not thread safe.

    // Write of the headers needed to compile the resulting .cpp file
    void dump_path_prefix(SkFILEWStream* pathStream);

    // Write out a single path in the form:
    //      static const int numPts# = ...;
    //      SkPoint pts#[] = { ... };
    //      static const int numVerbs# = ...;
    //      uint8_t verbs#[] = { ... };
    // Where # is a globally unique identifier
    void dump_path(SkFILEWStream* pathStream, const SkPath& path);

    // Write out structures to aggregate info about the written paths:
    //      int numPaths = ...;
    //      int sizes[] = {
    //          numPts#, numVerbs#,
    //          ...
    //      };
    //      const SkPoint* points[] = { pts#, ... };
    //      const uint8_t* verbs[] = { verbs#, ... };
    void dump_path_suffix(SkFILEWStream* pathStream);
}

#endif