print-reexports: rehome, tbd4 support, cross compilation

This commit is contained in:
Andrew Childs 2020-11-19 16:48:10 +09:00
parent 1182552332
commit 257cb1c8e8
4 changed files with 99 additions and 11 deletions

View file

@ -7,11 +7,11 @@ stdenv.mkDerivation {
buildInputs = [ libyaml ]; buildInputs = [ libyaml ];
buildPhase = '' buildPhase = ''
$CC -lyaml -o $name main.c $CC -lyaml -o print-reexports main.c
''; '';
installPhase = '' installPhase = ''
mkdir -p $out/bin mkdir -p $out/bin
mv $name $out/bin mv print-reexports $out/bin
''; '';
} }

View file

@ -21,6 +21,10 @@
#include <sys/errno.h> #include <sys/errno.h>
#include <yaml.h> #include <yaml.h>
#define LOG(str, ...) fprintf(stderr, "%s", str)
#define LOGF(...) fprintf(stderr, __VA_ARGS__)
static yaml_node_t *get_mapping_entry(yaml_document_t *document, yaml_node_t *mapping, const char *name) { static yaml_node_t *get_mapping_entry(yaml_document_t *document, yaml_node_t *mapping, const char *name) {
if (!mapping) { if (!mapping) {
fprintf(stderr, "get_mapping_entry: mapping is null\n"); fprintf(stderr, "get_mapping_entry: mapping is null\n");
@ -35,12 +39,12 @@ static yaml_node_t *get_mapping_entry(yaml_document_t *document, yaml_node_t *ma
yaml_node_t *key = yaml_document_get_node(document, pair->key); yaml_node_t *key = yaml_document_get_node(document, pair->key);
if (!key) { if (!key) {
fprintf(stderr, "get_mapping_entry: key (%i) is null\n", pair->key); LOGF("key (%d) is null\n", pair->key);
return NULL; return NULL;
} }
if (key->type != YAML_SCALAR_NODE) { if (key->type != YAML_SCALAR_NODE) {
fprintf(stderr, "get_mapping_entry: key is not a scalar\n"); LOG("get_mapping_entry: key is not a scalar\n");
return NULL; return NULL;
} }
@ -54,18 +58,17 @@ static yaml_node_t *get_mapping_entry(yaml_document_t *document, yaml_node_t *ma
return NULL; return NULL;
} }
static int emit_reexports(yaml_document_t *document) { static int emit_reexports_v2(yaml_document_t *document) {
yaml_node_t *root = yaml_document_get_root_node(document); yaml_node_t *root = yaml_document_get_root_node(document);
yaml_node_t *exports = get_mapping_entry(document, root, "exports"); yaml_node_t *exports = get_mapping_entry(document, root, "exports");
if (!exports) { if (!exports) {
fprintf(stderr, "emit_reexports: no exports found\n"); return 1;
return 0;
} }
if (exports->type != YAML_SEQUENCE_NODE) { if (exports->type != YAML_SEQUENCE_NODE) {
fprintf(stderr, "emit_reexports, value is not a sequence\n"); LOG("value is not a sequence\n");
return 0; return 0;
} }
@ -82,6 +85,11 @@ static int emit_reexports(yaml_document_t *document) {
continue; continue;
} }
if (reexports->type != YAML_SEQUENCE_NODE) {
LOG("re-exports is not a sequence\n");
return 0;
}
for ( for (
yaml_node_item_t *reexport = reexports->data.sequence.items.start; yaml_node_item_t *reexport = reexports->data.sequence.items.start;
reexport < reexports->data.sequence.items.top; reexport < reexports->data.sequence.items.top;
@ -90,7 +98,58 @@ static int emit_reexports(yaml_document_t *document) {
yaml_node_t *val = yaml_document_get_node(document, *reexport); yaml_node_t *val = yaml_document_get_node(document, *reexport);
if (val->type != YAML_SCALAR_NODE) { if (val->type != YAML_SCALAR_NODE) {
fprintf(stderr, "item is not a scalar\n"); LOG("item is not a scalar\n");
return 0;
}
fwrite(val->data.scalar.value, val->data.scalar.length, 1, stdout);
putchar('\n');
}
}
return 1;
}
static int emit_reexports_v4(yaml_document_t *document) {
yaml_node_t *root = yaml_document_get_root_node(document);
yaml_node_t *reexports = get_mapping_entry(document, root, "reexported-libraries");
if (!reexports) {
return 1;
}
if (reexports->type != YAML_SEQUENCE_NODE) {
LOG("value is not a sequence\n");
return 0;
}
for (
yaml_node_item_t *entry = reexports->data.sequence.items.start;
entry < reexports->data.sequence.items.top;
++entry
) {
yaml_node_t *entry_node = yaml_document_get_node(document, *entry);
yaml_node_t *libs = get_mapping_entry(document, entry_node, "libraries");
if (!libs) {
continue;
}
if (libs->type != YAML_SEQUENCE_NODE) {
LOG("libraries is not a sequence\n");
return 0;
}
for (
yaml_node_item_t *lib = libs->data.sequence.items.start;
lib < libs->data.sequence.items.top;
++lib
) {
yaml_node_t *val = yaml_document_get_node(document, *lib);
if (val->type != YAML_SCALAR_NODE) {
LOG("item is not a scalar\n");
return 0; return 0;
} }
@ -135,7 +194,13 @@ int main(int argc, char **argv) {
goto err_yaml; goto err_yaml;
} }
emit_reexports(&yaml_document); // Try both, only fail if one reports an error. A lack of re-exports is not
// considered an error.
int ok = 1;
ok = ok && emit_reexports_v2(&yaml_document);
ok = ok && emit_reexports_v4(&yaml_document);
result = !ok;
err_yaml: err_yaml:
yaml_parser_delete(&yaml_parser); yaml_parser_delete(&yaml_parser);

View file

@ -0,0 +1,19 @@
fixupOutputHooks+=('checkTbdReexports')
checkTbdReexports() {
local dir="$1"
while IFS= read -r -d $'\0' tbd; do
echo "checkTbdRexports: checking re-exports in $tbd"
while read -r target; do
local expected="${target%.dylib}.tbd"
if ! [ -e "$expected" ]; then
echo -e "Re-export missing:\n\t'$target'\n\t(expected '$expected')"
echo -e "While processing\n\t'$tbd'"
exit 1
else
echo "Re-exported target '$target' ok"
fi
done < <(print-reexports "$tbd")
done < <(find $prefix -type f -name '*.tbd' -print0)
}

View file

@ -68,7 +68,11 @@ impure-cmds // apple-source-releases // {
darwin-stubs = callPackage ../os-specific/darwin/darwin-stubs { }; darwin-stubs = callPackage ../os-specific/darwin/darwin-stubs { };
print-reexports = callPackage ../os-specific/darwin/apple-sdk/print-reexports { }; print-reexports = callPackage ../os-specific/darwin/print-reexports { };
checkReexportsHook = makeSetupHook {
deps = [ pkgs.darwin.print-reexports ];
} ../os-specific/darwin/print-reexports/setup-hook.sh;
maloader = callPackage ../os-specific/darwin/maloader { maloader = callPackage ../os-specific/darwin/maloader {
}; };