]> git.saurik.com Git - cycript.git/blame - sig/copy.cpp
Make Functor/struct output fancy type definitions.
[cycript.git] / sig / copy.cpp
CommitLineData
7341eedb
JF
1/* Cycript - The Truly Universal Scripting Language
2 * Copyright (C) 2009-2016 Jay Freeman (saurik)
3c1c3635
JF
3*/
4
f95d2598 5/* GNU Affero General Public License, Version 3 {{{ */
3c1c3635 6/*
f95d2598
JF
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
c15969fd 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f95d2598
JF
15 * GNU Affero General Public License for more details.
16
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
b3378a02 19**/
3c1c3635
JF
20/* }}} */
21
22#ifndef _GNU_SOURCE
23#define _GNU_SOURCE
24#endif
25
3c1c3635
JF
26#include "Pooling.hpp"
27#include "sig/parse.hpp"
b128dfee 28
3c1c3635
JF
29namespace sig {
30
84aef9a7 31void Copy(CYPool &pool, Element &lhs, const Element &rhs) {
b799113b 32 lhs.name = pool.strdup(rhs.name);
3c1c3635
JF
33 if (rhs.type == NULL)
34 lhs.type = NULL;
0559abf8
JF
35 else
36 lhs.type = rhs.type->Copy(pool);
3c1c3635
JF
37 lhs.offset = rhs.offset;
38}
39
84aef9a7 40void Copy(CYPool &pool, Signature &lhs, const Signature &rhs) {
3c1c3635
JF
41 size_t count(rhs.count);
42 lhs.count = count;
43 lhs.elements = new(pool) Element[count];
44 for (size_t index(0); index != count; ++index)
45 Copy(pool, lhs.elements[index], rhs.elements[index]);
46}
47
a109809e 48Void *Void::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
49 return new(pool) Void();
50}
3c1c3635 51
a109809e 52Unknown *Unknown::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
53 return new(pool) Unknown();
54}
3c1c3635 55
a109809e 56String *String::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
57 return new(pool) String();
58}
59
e2ce853b 60#ifdef CY_OBJECTIVEC
a109809e 61Meta *Meta::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
62 return new(pool) Meta();
63}
64
a109809e 65Selector *Selector::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
66 return new(pool) Selector();
67}
e2ce853b 68#endif
0559abf8 69
a109809e 70Bits *Bits::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
71 return new(pool) Bits(size);
72}
73
a109809e 74Pointer *Pointer::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
75 return new(pool) Pointer(*type.Copy(pool));
76}
77
a109809e 78Array *Array::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
79 return new(pool) Array(*type.Copy(pool), size);
80}
81
e2ce853b 82#ifdef CY_OBJECTIVEC
a109809e
JF
83Object *Object::Copy(CYPool &pool, const char *rename) const {
84 return new(pool) Object(pool.strdup(name));
0559abf8 85}
e2ce853b 86#endif
0559abf8 87
a109809e 88Aggregate *Aggregate::Copy(CYPool &pool, const char *rename) const {
53cb77ff
JF
89 if (rename == NULL)
90 rename = pool.strdup(name);
91 else if (rename[0] == '\0')
92 rename = NULL;
93 Aggregate *copy(new(pool) Aggregate(overlap, rename));
0559abf8 94 sig::Copy(pool, copy->signature, signature);
0559abf8
JF
95 return copy;
96}
97
a109809e 98Function *Function::Copy(CYPool &pool, const char *rename) const {
574d4720 99 Function *copy(new(pool) Function(variadic));
0559abf8
JF
100 sig::Copy(pool, copy->signature, signature);
101 return copy;
102}
103
e2ce853b 104#ifdef CY_OBJECTIVEC
a109809e 105Block *Block::Copy(CYPool &pool, const char *rename) const {
0559abf8
JF
106 Block *copy(new(pool) Block());
107 sig::Copy(pool, copy->signature, signature);
108 return copy;
3c1c3635 109}
e2ce853b 110#endif
3c1c3635 111
b799113b 112void Copy(CYPool &pool, ffi_type &lhs, ffi_type &rhs) {
3c1c3635
JF
113 lhs.size = rhs.size;
114 lhs.alignment = rhs.alignment;
115 lhs.type = rhs.type;
116 if (rhs.elements == NULL)
117 lhs.elements = NULL;
118 else {
119 size_t count(0);
120 while (rhs.elements[count] != NULL)
121 ++count;
122
123 lhs.elements = new(pool) ffi_type *[count + 1];
124 lhs.elements[count] = NULL;
125
126 for (size_t index(0); index != count; ++index) {
127 // XXX: if these are libffi native then you can just take them
128 ffi_type *ffi(new(pool) ffi_type);
129 lhs.elements[index] = ffi;
130 sig::Copy(pool, *ffi, *rhs.elements[index]);
131 }
132 }
133}
134
0559abf8
JF
135const char *Type::GetName() const {
136 return NULL;
137}
138
0559abf8
JF
139const char *Aggregate::GetName() const {
140 return name;
141}
142
3c1c3635 143}