blob: 9ae22189222858ec3e3e6fa3810d5d012916e46c [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_WEB_RESOURCE_JSON_ASYNCHRONOUS_UNPACKER_H_
#define CHROME_BROWSER_WEB_RESOURCE_JSON_ASYNCHRONOUS_UNPACKER_H_
#include <string>
#include "base/values.h"
// A delegate interface for users of JSONAsynchronousUnpacker.
class JSONAsynchronousUnpackerDelegate {
public:
virtual ~JSONAsynchronousUnpackerDelegate() {}
// This will be called when the response is parsed properly. |parsed_json|
// contains the decoded information.
virtual void OnUnpackFinished(const base::DictionaryValue& parsed_json) = 0;
// This will be called if there is an error while parsing the data.
virtual void OnUnpackError(const std::string& error_message) = 0;
};
// This class coordinates a web resource unpack and parse task which is run
// asynchronously. Results are sent back to the delegate via one of its
// OnUnpack<xxx> methods.
class JSONAsynchronousUnpacker {
public:
// Creates a WebResourceServiceUnpacker appropriate for the platform. The
// delegate must be kept around until one of the delegate methods is called.
// In case the delegate is no longer valid, ClearDelegate() must be called.
static JSONAsynchronousUnpacker*
Create(JSONAsynchronousUnpackerDelegate* delegate);
virtual ~JSONAsynchronousUnpacker() {}
// Start the decoding. The concrete implementation should delete itself after
// calling the delegate method.
virtual void Start(const std::string& json_data) = 0;
// If the delegate is going away it needs to inform the unpacker about it.
void ClearDelegate() {
delegate_ = NULL;
};
protected:
explicit JSONAsynchronousUnpacker(JSONAsynchronousUnpackerDelegate* delegate)
: delegate_(delegate) {
}
JSONAsynchronousUnpackerDelegate* delegate_;
};
#endif // CHROME_BROWSER_WEB_RESOURCE_JSON_ASYNCHRONOUS_UNPACKER_H_