aboutsummaryrefslogtreecommitdiff
path: root/luxc
diff options
context:
space:
mode:
authorEduardo Julian2018-08-05 01:57:38 -0400
committerEduardo Julian2018-08-05 01:57:38 -0400
commit27d0955180c137813af1dcc36fe4db0ab25d21a8 (patch)
tree404e99333fddc0091a24e541412c0d776136aaa1 /luxc
parent221cf3ea1bd48a8c678d3447558ea94631114ebc (diff)
Some small improvements and fixes.
Diffstat (limited to '')
-rw-r--r--luxc/src/lux/analyser/proc/jvm.clj8
1 files changed, 5 insertions, 3 deletions
diff --git a/luxc/src/lux/analyser/proc/jvm.clj b/luxc/src/lux/analyser/proc/jvm.clj
index 98c2435e9..9bcb9f616 100644
--- a/luxc/src/lux/analyser/proc/jvm.clj
+++ b/luxc/src/lux/analyser/proc/jvm.clj
@@ -729,7 +729,8 @@
super-params*))))
(defn ^:private check-method! [only-interface? class method]
- (|do [!class! (&/de-alias-class class)
+ (|do [!class!* (&/de-alias-class class)
+ :let [!class! (string/replace !class!* "/" ".")]
class-loader &/loader
_ (try (assert! (let [=class (Class/forName !class! true class-loader)]
(= only-interface? (.isInterface =class)))
@@ -737,7 +738,7 @@
(str "[Analyser Error] Can only invoke method \"" method "\"" " on interface.")
(str "[Analyser Error] Can only invoke method \"" method "\"" " on class.")))
(catch Exception e
- (&/fail-with-loc (str "[Analyser Error] Unknown class: " class))))]
+ (&/fail-with-loc (str "[Analyser Error] Unknown class: " !class!))))]
(return (&/T [!class! class-loader]))))
(let [dummy-type-param (&/$Primitive "java.lang.Object" &/$Nil)]
@@ -883,6 +884,7 @@
:let [name (->> scope &/|reverse &/|tail &host/location)
class-decl (&/T [name &/$Nil])
anon-class (str (string/replace module "/" ".") "." name)
+ class-type-decl (&/T [anon-class &/$Nil])
anon-class-type (&/$Primitive anon-class &/$Nil)]
=ctor-args (&/map% (fn [ctor-arg]
(|let [[arg-type arg-term] ctor-arg]
@@ -893,7 +895,7 @@
(&/$Cons default-<init>)
(&host/use-dummy-class class-decl super-class interfaces (&/$Some =ctor-args) &/$Nil))
[=methods =captured] (let [all-supers (&/$Cons super-class interfaces)]
- (analyse-methods analyse class-decl all-supers methods))
+ (analyse-methods analyse class-type-decl all-supers methods))
_ (let [=fields (&/|map (fn [^objects idx+capt]
(|let [[idx _] idx+capt]
(&/$VariableFieldAnalysis (str &c!base/closure-prefix idx)