summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorColin Cross <ccross@android.com>2021-10-13 19:46:23 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2021-10-13 19:46:23 +0000
commitffe9223a19b30ae2b73bcf00ba6124ffd23a7f48 (patch)
tree6ac8e6df2b1f70f000be32836c0fb8f7e65362cf
parent8dc0de5a4b54ba8c73dd474cd89ec453b38ea34c (diff)
parentc22026c70ccea6c060b33d0bcb345f495e2a31f2 (diff)
downloadobstack-ffe9223a19b30ae2b73bcf00ba6124ffd23a7f48.tar.gz
Add obstack_printf to libobstack am: 5bef457686 am: c22026c70c
Original change: https://android-review.googlesource.com/c/platform/external/obstack/+/1843836 Change-Id: I50b6dcd154dd19cdfd6cffc82ea97e028763e4cd
-rw-r--r--Android.bp2
-rw-r--r--android/include/obstack.h26
-rw-r--r--android/obstack_printf.c42
3 files changed, 70 insertions, 0 deletions
diff --git a/Android.bp b/Android.bp
index e37836e..00a3134 100644
--- a/Android.bp
+++ b/Android.bp
@@ -18,9 +18,11 @@ cc_library_host_static {
},
srcs: [
"libiberty/obstack.c",
+ "android/obstack_printf.c",
],
local_include_dirs: ["android"],
export_include_dirs: [
+ "android/include",
"include",
],
visibility: [
diff --git a/android/include/obstack.h b/android/include/obstack.h
new file mode 100644
index 0000000..a45421e
--- /dev/null
+++ b/android/include/obstack.h
@@ -0,0 +1,26 @@
+/*
+ * Copyright 2021, The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/*
+ * This is a wrapper around gnulib's obstack.h to add obstack_printf.
+ */
+
+#pragma once
+
+#include_next <obstack.h>
+
+int obstack_printf(struct obstack *obs, const char *format, ...)
+ __attribute__((__format__(printf, 2, 3)));
diff --git a/android/obstack_printf.c b/android/obstack_printf.c
new file mode 100644
index 0000000..647d7f7
--- /dev/null
+++ b/android/obstack_printf.c
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2021, The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/*
+ * This is a reimplementation of obstack_printf for use by libcpu, which
+ * uses it to print an error message.
+ */
+
+#include <stdarg.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <obstack.h>
+
+int __attribute__((__format__(printf, 2, 3))) obstack_printf(struct obstack *obs, const char *format, ...) {
+
+ va_list ap;
+ va_start(ap, format);
+
+ char* str = NULL;
+ int len = vasprintf(&str, format, ap);
+ if (len < 0) {
+ return len;
+ }
+
+ obstack_grow(obs, str, len);
+ free(str);
+
+ return len;
+}