--- /dev/null
+int foo(int *__mem);
+template < typename _Tp > class new_allocator {
+};
+
+template < typename _CharT > struct char_traits;
+template < typename _Tp > class allocator:public new_allocator < _Tp > {
+};
+
+template < typename _CharT, typename _Traits =
+ char_traits < _CharT >, typename _Alloc =
+ allocator < _CharT > >class basic_string;
+typedef basic_string < char >string;
+template < typename _CharT, typename _Traits,
+ typename _Alloc > class basic_string {
+ typedef _Alloc allocator_type;
+ private:struct _Rep_base {
+ int _M_refcount;
+ };
+ struct _Rep:_Rep_base {
+ void _M_dispose(const _Alloc & __a) {
+ if (this != &_S_empty_rep()) {
+ if (foo(&this->_M_refcount)) ;
+ }
+ }};
+ struct _Alloc_hider:_Alloc {
+ };
+ public: private:mutable _Alloc_hider _M_dataplus;
+ _Rep *_M_rep() const {
+ } static _Rep & _S_empty_rep() {
+ }
+ public: basic_string():_M_dataplus(_S_empty_rep()._M_refdata(),
+ _Alloc()) {
+ }
+ ~basic_string() {
+ _M_rep()->_M_dispose(this->get_allocator());
+ }
+ allocator_type get_allocator() const {
+}};
+template < class T > class intrusive_ptr {
+ public:typedef T element_type;
+ ~intrusive_ptr() {
+ intrusive_ptr_release(px);
+ }
+ private:T * px;
+};
+
+template < typename T > struct intrusive_base {
+ friend void intrusive_ptr_release(T * ptr) {
+ delete ptr;
+}};
+struct si:intrusive_base < si > {
+ intrusive_ptr < si > parent;
+ string id_1_1;
+};
+string normalize_id(string)
+{
+}
+
+void add_id_to_section(string & id)
+{
+ string id_part = id;
+ normalize_id(id);
+ intrusive_ptr < si > parent;
+};