summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2015-01-01 09:29:28 +0200
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2015-01-01 22:09:18 +0200
commit8a8c1fc82f5b1f7e5f7d82970e39d6064f2fd0b4 (patch)
treecc28a731930175ac9296c7231f41e92bd09535ab
parentebde3c694f301a99addf02c3b8ff3834f04663af (diff)
downloadmicropython-8a8c1fc82f5b1f7e5f7d82970e39d6064f2fd0b4.tar.gz
micropython-8a8c1fc82f5b1f7e5f7d82970e39d6064f2fd0b4.zip
py: Add basic framework for issuing compile/runtime warnings.
-rw-r--r--py/builtinimport.c2
-rw-r--r--py/emit.h6
-rw-r--r--py/emitnative.c1
-rw-r--r--py/mpconfig.h5
-rw-r--r--py/py.mk1
-rw-r--r--py/runtime.h6
-rw-r--r--py/warning.c54
-rw-r--r--unix/mpconfigport.h1
8 files changed, 75 insertions, 1 deletions
diff --git a/py/builtinimport.c b/py/builtinimport.c
index a8f6a81741..fd804ee356 100644
--- a/py/builtinimport.c
+++ b/py/builtinimport.c
@@ -323,7 +323,7 @@ mp_obj_t mp_builtin___import__(mp_uint_t n_args, const mp_obj_t *args) {
vstr_add_str(&path, "__init__.py");
if (mp_import_stat(vstr_str(&path)) != MP_IMPORT_STAT_FILE) {
vstr_cut_tail_bytes(&path, sizeof("/__init__.py") - 1); // cut off /__init__.py
- printf("Notice: %s is imported as namespace package\n", vstr_str(&path));
+ mp_warning("%s is imported as namespace package", vstr_str(&path));
} else {
do_load(module_obj, &path);
vstr_cut_tail_bytes(&path, sizeof("/__init__.py") - 1); // cut off /__init__.py
diff --git a/py/emit.h b/py/emit.h
index 927e33ea73..f039770a5c 100644
--- a/py/emit.h
+++ b/py/emit.h
@@ -204,4 +204,10 @@ extern const emit_inline_asm_method_table_t emit_inline_thumb_method_table;
emit_inline_asm_t *emit_inline_thumb_new(mp_uint_t max_num_labels);
void emit_inline_thumb_free(emit_inline_asm_t *emit);
+#if MICROPY_WARNINGS
+void mp_emitter_warning(pass_kind_t pass, const char *msg);
+#else
+#define mp_emitter_warning(pass, msg)
+#endif
+
#endif // __MICROPY_INCLUDED_PY_EMIT_H__
diff --git a/py/emitnative.c b/py/emitnative.c
index c2fe951be8..556a977a06 100644
--- a/py/emitnative.c
+++ b/py/emitnative.c
@@ -1636,6 +1636,7 @@ STATIC void emit_native_store_subscr(emit_t *emit) {
STATIC void emit_native_delete_fast(emit_t *emit, qstr qst, mp_uint_t local_num) {
// TODO implement me!
// could support for Python types, just set to None (so GC can reclaim it)
+ mp_emitter_warning(emit->pass, "Native codegeneration doesn't support deleting local");
}
STATIC void emit_native_delete_deref(emit_t *emit, qstr qst, mp_uint_t local_num) {
diff --git a/py/mpconfig.h b/py/mpconfig.h
index b193051c51..bbc791c0b7 100644
--- a/py/mpconfig.h
+++ b/py/mpconfig.h
@@ -251,6 +251,11 @@ typedef long long mp_longint_impl_t;
#define MICROPY_ERROR_REPORTING (MICROPY_ERROR_REPORTING_NORMAL)
#endif
+// Whether issue warnings during compiling/execution
+#ifndef MICROPY_WARNINGS
+#define MICROPY_WARNINGS (0)
+#endif
+
// Float and complex implementation
#define MICROPY_FLOAT_IMPL_NONE (0)
#define MICROPY_FLOAT_IMPL_FLOAT (1)
diff --git a/py/py.mk b/py/py.mk
index f54c06cbcf..4c4094eb66 100644
--- a/py/py.mk
+++ b/py/py.mk
@@ -51,6 +51,7 @@ PY_O_BASENAME = \
nativeglue.o \
stackctrl.o \
argcheck.o \
+ warning.o \
map.o \
obj.o \
objarray.o \
diff --git a/py/runtime.h b/py/runtime.h
index 59d61e708d..711b15f0da 100644
--- a/py/runtime.h
+++ b/py/runtime.h
@@ -126,4 +126,10 @@ extern struct _mp_obj_list_t mp_sys_argv_obj;
#define mp_sys_path ((mp_obj_t)&mp_sys_path_obj)
#define mp_sys_argv ((mp_obj_t)&mp_sys_argv_obj)
+#if MICROPY_WARNINGS
+void mp_warning(const char *msg, ...);
+#else
+#define mp_warning(msg, ...)
+#endif
+
#endif // __MICROPY_INCLUDED_PY_RUNTIME_H__
diff --git a/py/warning.c b/py/warning.c
new file mode 100644
index 0000000000..c7461c0f54
--- /dev/null
+++ b/py/warning.c
@@ -0,0 +1,54 @@
+/*
+ * This file is part of the Micro Python project, http://micropython.org/
+ *
+ * The MIT License (MIT)
+ *
+ * Copyright (c) 2014 Damien P. George
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+#include <stdint.h>
+#include <stdarg.h>
+#include <stdio.h>
+
+#include "mpconfig.h"
+#include "misc.h"
+#include "qstr.h"
+#include "obj.h"
+#include "compile.h"
+#include "scope.h"
+#include "emit.h"
+
+#if MICROPY_WARNINGS
+
+void mp_warning(const char *msg, ...) {
+ va_list args;
+ va_start(args, msg);
+ printf("Warning: ");
+ vprintf(msg, args);
+ printf("\n");
+}
+
+void mp_emitter_warning(pass_kind_t pass, const char *msg) {
+ if (pass == MP_PASS_CODE_SIZE) {
+ mp_warning(msg, NULL);
+ }
+}
+
+#endif // MICROPY_WARNINGS
diff --git a/unix/mpconfigport.h b/unix/mpconfigport.h
index a895aeab0c..fc2a18278f 100644
--- a/unix/mpconfigport.h
+++ b/unix/mpconfigport.h
@@ -74,6 +74,7 @@
// Define to MICROPY_ERROR_REPORTING_DETAILED to get function, etc.
// names in exception messages (may require more RAM).
#define MICROPY_ERROR_REPORTING (MICROPY_ERROR_REPORTING_DETAILED)
+#define MICROPY_WARNINGS (1)
// Define to 1 to use undertested inefficient GC helper implementation
// (if more efficient arch-specific one is not available).