Pass CreateDirectory errors up to IndexedDB.
[chromium-blink-merge.git] / courgette / courgette.h
blob4831228e279ad8fd18bc5ebd84c91e65e898985e
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COURGETTE_COURGETTE_H_
6 #define COURGETTE_COURGETTE_H_
8 #include <stddef.h> // Required to define size_t on GCC
10 #include "base/files/file_path.h"
12 namespace courgette {
14 // Status codes for Courgette APIs.
16 // Client code should only rely on the distintion between C_OK and the other
17 // status codes.
19 enum Status {
20 C_OK = 1, // Successful operation.
22 C_GENERAL_ERROR = 2, // Error other than listed below.
24 C_READ_OPEN_ERROR = 3, // Could not open input file for reading.
25 C_READ_ERROR = 4, // Could not read from opened input file.
27 C_WRITE_OPEN_ERROR = 3, // Could not open output file for writing.
28 C_WRITE_ERROR = 4, // Could not write to opened output file.
30 C_BAD_ENSEMBLE_MAGIC = 5, // Ensemble patch has bad magic.
31 C_BAD_ENSEMBLE_VERSION = 6, // Ensemble patch has wrong version.
32 C_BAD_ENSEMBLE_HEADER = 7, // Ensemble patch has corrupt header.
33 C_BAD_ENSEMBLE_CRC = 8, // Ensemble patch has corrupt data.
35 C_BAD_TRANSFORM = 12, // Transform mis-specified.
36 C_BAD_BASE = 13, // Base for transform malformed.
38 C_BINARY_DIFF_CRC_ERROR = 14, // Internal diff input doesn't have expected
39 // CRC.
41 // Internal errors.
42 C_STREAM_ERROR = 20, // Unexpected error from streams.h.
43 C_STREAM_NOT_CONSUMED = 21, // Stream has extra data, is expected to be
44 // used up.
45 C_SERIALIZATION_FAILED = 22, //
46 C_DESERIALIZATION_FAILED = 23, //
47 C_INPUT_NOT_RECOGNIZED = 24, // Unrecognized input (not an executable).
48 C_DISASSEMBLY_FAILED = 25, //
49 C_ASSEMBLY_FAILED = 26, //
50 C_ADJUSTMENT_FAILED = 27, //
53 // What type of executable is something
54 // This is part of the patch format. Never reuse an id number.
55 enum ExecutableType {
56 EXE_UNKNOWN = 0,
57 EXE_WIN_32_X86 = 1,
58 EXE_ELF_32_X86 = 2,
59 EXE_ELF_32_ARM = 3,
62 class SinkStream;
63 class SinkStreamSet;
64 class SourceStream;
65 class SourceStreamSet;
67 class AssemblyProgram;
68 class EncodedProgram;
70 // Applies the patch to the bytes in |old| and writes the transformed ensemble
71 // to |output|.
72 // Returns C_OK unless something went wrong.
73 Status ApplyEnsemblePatch(SourceStream* old, SourceStream* patch,
74 SinkStream* output);
76 // Applies the patch in |patch_file_name| to the bytes in |old_file_name| and
77 // writes the transformed ensemble to |new_file_name|.
78 // Returns C_OK unless something went wrong.
79 // This function first validates that the patch file has a proper header, so the
80 // function can be used to 'try' a patch.
81 Status ApplyEnsemblePatch(const base::FilePath::CharType* old_file_name,
82 const base::FilePath::CharType* patch_file_name,
83 const base::FilePath::CharType* new_file_name);
85 // Generates a patch that will transform the bytes in |old| into the bytes in
86 // |target|.
87 // Returns C_OK unless something when wrong (unexpected).
88 Status GenerateEnsemblePatch(SourceStream* old, SourceStream* target,
89 SinkStream* patch);
91 // Detects the type of an executable file, and it's length. The length
92 // may be slightly smaller than some executables (like ELF), but will include
93 // all bytes the courgette algorithm has special benefit for.
94 // On sucess:
95 // Fill in type and detected_length, and return C_OK.
96 // On failure:
97 // Fill in type with UNKNOWN, detected_length with 0, and
98 // return C_INPUT_NOT_RECOGNIZED
99 Status DetectExecutableType(const void* buffer, size_t length,
100 ExecutableType* type,
101 size_t* detected_length);
103 // Attempts to detect the type of executable, and parse it with the
104 // appropriate tools, storing the pointer to the AssemblyProgram in |*output|.
105 // Returns C_OK if successful, otherwise returns an error status and sets
106 // |*output| to NULL.
107 Status ParseDetectedExecutable(const void* buffer, size_t length,
108 AssemblyProgram** output);
110 // Converts |program| into encoded form, returning it as |*output|.
111 // Returns C_OK if succeeded, otherwise returns an error status and
112 // sets |*output| to NULL
113 Status Encode(AssemblyProgram* program, EncodedProgram** output);
115 // Serializes |encoded| into the stream set.
116 // Returns C_OK if succeeded, otherwise returns an error status.
117 Status WriteEncodedProgram(EncodedProgram* encoded, SinkStreamSet* sink);
119 // Assembles |encoded|, emitting the bytes into |buffer|.
120 // Returns C_OK if succeeded, otherwise returns an error status and leaves
121 // |buffer| in an undefined state.
122 Status Assemble(EncodedProgram* encoded, SinkStream* buffer);
124 // Deserializes program from the stream set.
125 // Returns C_OK if succeeded, otherwise returns an error status and
126 // sets |*output| to NULL
127 Status ReadEncodedProgram(SourceStreamSet* source, EncodedProgram** output);
129 // Used to free an AssemblyProgram returned by other APIs.
130 void DeleteAssemblyProgram(AssemblyProgram* program);
132 // Used to free an EncodedProgram returned by other APIs.
133 void DeleteEncodedProgram(EncodedProgram* encoded);
135 // Adjusts |program| to look more like |model|.
137 Status Adjust(const AssemblyProgram& model, AssemblyProgram *program);
139 } // namespace courgette
140 #endif // COURGETTE_COURGETTE_H_