author Mike Hommey <>
Thu, 20 Jul 2017 14:06:23 +0900
changeset 612007 499490d18b16ae716794ae027179cce6cb20147c
parent 301569 e8c7dfe727cd970e2c3294934e2927b14143c205
child 489668 cbb8fdf1daf98a15f7d57f6b08d273bdf96aa1a0
child 648192 c236dfe7dc98c387219d7cb45d0693560db708fd
child 652109 df5b4f5fe775d341647f85abcf9a0ca0aa573a67
permissions -rw-r--r--
Bug 1382525 - Move LLVM_CONFIG out of mozconfig.common. r?chmanchester LLVM_CONFIG, per the contents of toolkit/moz.configure, is tied to --enable-stylo, but it currently is set on all types of builds. It currently happens to work, but it's actually not meant to, and sure enough, the fix for bug 1374727 exacerbates that. So we create a new mozconfig.stylo file that enables stylo and sets LLVM_CONFIG, such that only build types that do enable stylo have LLVM_CONFIG set.

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 * vim: sw=2 ts=2 et lcs=trail\:.,tab\:>~ :
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at */

#ifndef mozilla_storage_mozStorageAsyncStatement_h_
#define mozilla_storage_mozStorageAsyncStatement_h_

#include "nsAutoPtr.h"
#include "nsString.h"

#include "nsTArray.h"

#include "mozStorageBindingParamsArray.h"
#include "mozStorageStatementData.h"
#include "mozIStorageAsyncStatement.h"
#include "StorageBaseStatementInternal.h"
#include "mozilla/Attributes.h"

class nsIXPConnectJSObjectHolder;

namespace mozilla {
namespace storage {

class AsyncStatementJSHelper;
class Connection;

class AsyncStatement final : public mozIStorageAsyncStatement
                           , public StorageBaseStatementInternal


   * Initializes the object on aDBConnection by preparing the SQL statement
   * given by aSQLStatement.
   * @param aDBConnection
   *        The Connection object this statement is associated with.
   * @param aNativeConnection
   *        The native Sqlite connection this statement is associated with.
   * @param aSQLStatement
   *        The SQL statement to prepare that this object will represent.
  nsresult initialize(Connection *aDBConnection,
                      sqlite3 *aNativeConnection,
                      const nsACString &aSQLStatement);

   * Obtains and transfers ownership of the array of parameters that are bound
   * to this statment.  This can be null.
  inline already_AddRefed<BindingParamsArray> bindingParamsArray()
    return mParamsArray.forget();


   * @return a pointer to the BindingParams object to use with our Bind*
   *         method.
  mozIStorageBindingParams *getParams();

   * The SQL string as passed by the user.  We store it because we create the
   * async statement on-demand on the async thread.
  nsCString mSQLString;

   * Holds the array of parameters to bind to this statement when we execute
   * it asynchronously.
  RefPtr<BindingParamsArray> mParamsArray;

   * Caches the JS 'params' helper for this statement.
  nsMainThreadPtrHandle<nsIXPConnectJSObjectHolder> mStatementParamsHolder;

   * Have we been explicitly finalized by the user?
  bool mFinalized;

   * Required for access to private mStatementParamsHolder field by
   * AsyncStatementJSHelper::getParams.
  friend class AsyncStatementJSHelper;

} // namespace storage
} // namespace mozilla

#endif // mozilla_storage_mozStorageAsyncStatement_h_