]>
git.saurik.com Git - cycript.git/blob - sig/copy.cpp
e78cfd183a8b9cf879715fc7b65640e4bb11c0df
1 /* Cycript - Remove Execution Server and Disassembler
2 * Copyright (C) 2009 Jay Freeman (saurik)
5 /* Modified BSD License {{{ */
7 * Redistribution and use in source and binary
8 * forms, with or without modification, are permitted
9 * provided that the following conditions are met:
11 * 1. Redistributions of source code must retain the
12 * above copyright notice, this list of conditions
13 * and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the
15 * above copyright notice, this list of conditions
16 * and the following disclaimer in the documentation
17 * and/or other materials provided with the
19 * 3. The name of the author may not be used to endorse
20 * or promote products derived from this software
21 * without specific prior written permission.
23 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS''
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
25 * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
28 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
29 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
30 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
34 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
35 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
36 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
44 #include "minimal/stdlib.h"
45 #include <apr_strings.h>
46 #include "Pooling.hpp"
47 #include "sig/parse.hpp"
52 void Copy(apr_pool_t
*pool
, Element
&lhs
, Element
&rhs
) {
53 lhs
.name
= apr_pstrdup(pool
, rhs
.name
);
57 lhs
.type
= new(pool
) Type
;
58 Copy(pool
, *lhs
.type
, *rhs
.type
);
60 lhs
.offset
= rhs
.offset
;
63 void Copy(apr_pool_t
*pool
, Signature
&lhs
, Signature
&rhs
) {
64 size_t count(rhs
.count
);
66 lhs
.elements
= new(pool
) Element
[count
];
67 for (size_t index(0); index
!= count
; ++index
)
68 Copy(pool
, lhs
.elements
[index
], rhs
.elements
[index
]);
71 void Copy(apr_pool_t
*pool
, Type
&lhs
, Type
&rhs
) {
72 lhs
.primitive
= rhs
.primitive
;
73 lhs
.name
= apr_pstrdup(pool
, rhs
.name
);
74 lhs
.flags
= rhs
.flags
;
76 if (sig::IsAggregate(rhs
.primitive
))
77 Copy(pool
, lhs
.data
.signature
, rhs
.data
.signature
);
79 sig::Type
*&lht(lhs
.data
.data
.type
);
80 sig::Type
*&rht(rhs
.data
.data
.type
);
86 Copy(pool
, *lht
, *rht
);
89 lhs
.data
.data
.size
= rhs
.data
.data
.size
;
93 void Copy(apr_pool_t
*pool
, ffi_type
&lhs
, ffi_type
&rhs
) {
95 lhs
.alignment
= rhs
.alignment
;
97 if (rhs
.elements
== NULL
)
101 while (rhs
.elements
[count
] != NULL
)
104 lhs
.elements
= new(pool
) ffi_type
*[count
+ 1];
105 lhs
.elements
[count
] = NULL
;
107 for (size_t index(0); index
!= count
; ++index
) {
108 // XXX: if these are libffi native then you can just take them
109 ffi_type
*ffi(new(pool
) ffi_type
);
110 lhs
.elements
[index
] = ffi
;
111 sig::Copy(pool
, *ffi
, *rhs
.elements
[index
]);