a8e3321fbd
We'd like to start using ##mixed## instead of ##var## for attribute types to be consistent with Hack. As a followup to this (once released), we would codemod all ##var## to ##mixed##.
78 linhas
2.6 KiB
C++
78 linhas
2.6 KiB
C++
/*
|
|
+----------------------------------------------------------------------+
|
|
| HipHop for PHP |
|
|
+----------------------------------------------------------------------+
|
|
| Copyright (c) 2010-2013 Facebook, Inc. (http://www.facebook.com) |
|
|
| Copyright (c) 1998-2010 Zend Technologies Ltd. (http://www.zend.com) |
|
|
+----------------------------------------------------------------------+
|
|
| This source file is subject to version 2.00 of the Zend license, |
|
|
| that is bundled with this package in the file LICENSE, and is |
|
|
| available through the world-wide-web at the following url: |
|
|
| http://www.zend.com/license/2_00.txt. |
|
|
| If you did not receive a copy of the Zend license and are unable to |
|
|
| obtain it through the world-wide-web, please send a note to |
|
|
| license@zend.com so we can mail you a copy immediately. |
|
|
+----------------------------------------------------------------------+
|
|
*/
|
|
|
|
#ifndef incl_HPHP_SWEEPABLE_H_
|
|
#define incl_HPHP_SWEEPABLE_H_
|
|
|
|
#include "hphp/util/base.h"
|
|
|
|
namespace HPHP {
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
/*
|
|
* Objects that need to do special clean up at the end of the request
|
|
* may register themselves for this by deriving from Sweepable. After
|
|
* every request, Sweepable::SweepAll is called so the objects may
|
|
* clear out request-local allocations that are not smart-allocated.
|
|
*/
|
|
class Sweepable {
|
|
public:
|
|
struct Node {
|
|
Node *next, *prev;
|
|
void enlist(Node& head);
|
|
void delist();
|
|
void init();
|
|
};
|
|
static void SweepAll();
|
|
static void InitSweepableList();
|
|
|
|
public:
|
|
Sweepable();
|
|
virtual ~Sweepable();
|
|
|
|
/*
|
|
* Default sweep behavior is to delete ourselves. Note that this is
|
|
* not appropriate for a smart-allocated class.
|
|
*/
|
|
virtual void sweep() { delete this; }
|
|
|
|
/*
|
|
* Note: "Persistent" here means that the object will stay alive
|
|
* across requests, but *as a thread local*. It can be reused once
|
|
* the same server thread gets around to handling a new request. If
|
|
* you need this you probably should be using it via PersistentObjectStore.
|
|
*/
|
|
void incPersistent() { ++m_persistentCount; }
|
|
void decPersistent() { --m_persistentCount; }
|
|
bool isPersistent() { return m_persistentCount > 0; }
|
|
|
|
/*
|
|
* Remove this object from the sweepable list, so it won't have
|
|
* sweep() called at the next SweepAll.
|
|
*/
|
|
void unregister();
|
|
|
|
private:
|
|
Node m_sweepNode;
|
|
int m_persistentCount;
|
|
};
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
}
|
|
|
|
#endif
|