blob: b5b3621b2457ba77873c226bc2476e22ecb685a8 [file] [log] [blame]
// Copyright 2011 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_PROXY_RESOLUTION_PROXY_RESOLVER_ERROR_OBSERVER_H_
#define NET_PROXY_RESOLUTION_PROXY_RESOLVER_ERROR_OBSERVER_H_
#include <string>
#include "net/base/net_export.h"
namespace net {
// Interface for observing JavaScript error messages from PAC scripts.
class NET_EXPORT_PRIVATE ProxyResolverErrorObserver {
public:
ProxyResolverErrorObserver() = default;
ProxyResolverErrorObserver(const ProxyResolverErrorObserver&) = delete;
ProxyResolverErrorObserver& operator=(const ProxyResolverErrorObserver&) =
delete;
virtual ~ProxyResolverErrorObserver() = default;
// Handler for when an error is encountered. |line_number| may be -1
// if a line number is not applicable to this error. |error| is a message
// describing the error.
//
// Note on threading: This may get called from a worker thread. If the
// backing proxy resolver is ProxyResolverV8Tracing, then it will not
// be called concurrently, however it will be called from a different
// thread than the proxy resolver's origin thread.
virtual void OnPACScriptError(int line_number,
const std::u16string& error) = 0;
};
} // namespace net
#endif // NET_PROXY_RESOLUTION_PROXY_RESOLVER_ERROR_OBSERVER_H_