Merge pull request #1729 from Kodiologist/recursive-require-star
Make (require [foo [*]]) pull in macros required by `foo`
This commit is contained in:
commit
ada524e887
@ -190,14 +190,9 @@ def require(source_module, target_module, assignments, prefix=""):
|
|||||||
prefix += "."
|
prefix += "."
|
||||||
|
|
||||||
if assignments == "ALL":
|
if assignments == "ALL":
|
||||||
# Only add macros/tags created in/by the source module.
|
name_assigns = [(k, k) for k in
|
||||||
name_assigns = [(n, n) for n, f in source_macros.items()
|
tuple(source_macros.keys()) + tuple(source_tags.keys())]
|
||||||
if inspect.getmodule(f) == source_module]
|
|
||||||
name_assigns += [(n, n) for n, f in source_tags.items()
|
|
||||||
if inspect.getmodule(f) == source_module]
|
|
||||||
else:
|
else:
|
||||||
# If one specifically requests a macro/tag not created in the source
|
|
||||||
# module, I guess we allow it?
|
|
||||||
name_assigns = assignments
|
name_assigns = assignments
|
||||||
|
|
||||||
for name, alias in name_assigns:
|
for name, alias in name_assigns:
|
||||||
|
@ -378,10 +378,6 @@ in expansions."
|
|||||||
|
|
||||||
(require [tests.resources.macro-with-require [*]])
|
(require [tests.resources.macro-with-require [*]])
|
||||||
|
|
||||||
;; Make sure our local version wasn't overwritten by a faulty `require` of the
|
|
||||||
;; one in tests.resources.macro-with-require.
|
|
||||||
(assert (= nonlocal-test-macro (get __macros__ "nonlocal_test_macro")))
|
|
||||||
|
|
||||||
(setv module-name-var "tests.native_tests.native_macros.test-macro-namespace-resolution")
|
(setv module-name-var "tests.native_tests.native_macros.test-macro-namespace-resolution")
|
||||||
(assert (= (+ "This macro was created in tests.resources.macros, "
|
(assert (= (+ "This macro was created in tests.resources.macros, "
|
||||||
"expanded in tests.native_tests.native_macros.test-macro-namespace-resolution "
|
"expanded in tests.native_tests.native_macros.test-macro-namespace-resolution "
|
||||||
@ -479,3 +475,11 @@ in expansions."
|
|||||||
;; ensure that an imported module used the cached bytecode. We'll simply have
|
;; ensure that an imported module used the cached bytecode. We'll simply have
|
||||||
;; to trust that the .pyc loading convention was followed.
|
;; to trust that the .pyc loading convention was followed.
|
||||||
(test-requires-and-macros))
|
(test-requires-and-macros))
|
||||||
|
|
||||||
|
|
||||||
|
(defn test-recursive-require-star []
|
||||||
|
"(require [foo [*]]) should pull in macros required by `foo`."
|
||||||
|
(require [tests.resources.macro-with-require [*]])
|
||||||
|
|
||||||
|
(test-macro)
|
||||||
|
(assert (= blah 1)))
|
||||||
|
Loading…
Reference in New Issue
Block a user