diff --git a/src/main/res/raw/collections.forth b/src/main/res/raw/collections.forth index 47e09a0..38a125d 100644 --- a/src/main/res/raw/collections.forth +++ b/src/main/res/raw/collections.forth @@ -1,19 +1,19 @@ -: ( -- c ) 'com.vectron.fcl.types.Dic/empty' jvm-call-static ; -: ( -- c ) 'com.vectron.fcl.types.Lst/empty' jvm-call-static ; -: size ( c -- n ) 'size' jvm-call-method ; -: put ( c k v -- ) swap rot 'put/OO' jvm-call-method ; -: at ( c k -- v ) swap 'at/O' jvm-call-method ; +: ( -- c ) :com.vectron.fcl.types.Dic/empty jvm-call-static ; +: ( -- c ) :com.vectron.fcl.types.Lst/empty jvm-call-static ; +: size ( c -- n ) :size jvm-call-method ; +: put ( c k v -- ) swap rot :put/OO jvm-call-method ; +: at ( c k -- v ) swap :at/O jvm-call-method ; : 1st ( c -- e ) 0 at ; : 2nd ( c -- e ) 1 at ; -: clear ( c -- ) 'clear' jvm-call-method ; -: add ( c v -- ) swap 'append/O' jvm-call-method ; -: prep ( c v -- ) swap 'prep/O' jvm-call-method ; -: iter ( c -- ) 'iterator' jvm-call-method ; -: next? ( i -- ) 'hasNext' jvm-call-method ; -: next ( i -- o ) 'next' jvm-call-method ; -: jvmValue ( p -- o ) 'value' jvm-call-method ; -: reverse ( l -- l ) 'reverse' jvm-call-method ; -: format ( l s -- s ) 'format/t' jvm-call-method ; +: clear ( c -- ) :clear jvm-call-method ; +: add ( c v -- ) swap :append/O jvm-call-method ; +: prep ( c v -- ) swap :prep/O jvm-call-method ; +: iter ( c -- ) :iterator jvm-call-method ; +: next? ( i -- ) :hasNext jvm-call-method ; +: next ( i -- o ) :next jvm-call-method ; +: jvmValue ( p -- o ) :value jvm-call-method ; +: reverse ( l -- l ) :reverse jvm-call-method ; +: format ( l s -- s ) :format/t jvm-call-method ; : each ( c q -- ) -> q iter -> it @@ -80,23 +80,23 @@ loop result ; -: sublst ( l n n -- l ) swap rot 'subList/ii' jvm-call-method ; -: remove-at ( l n -- l ) swap 'removeAt/i' jvm-call-method ; -: remove ( l o -- l ) swap 'remove/O' jvm-call-method ; -: keys ( d -- l ) 'keys' jvm-call-method ; -: values ( d -- l ) 'values' jvm-call-method ; +: sublst ( l n n -- l ) swap rot :subList/ii jvm-call-method ; +: remove-at ( l n -- l ) swap :removeAt/i jvm-call-method ; +: remove ( l o -- l ) swap :remove/O jvm-call-method ; +: keys ( d -- l ) :keys jvm-call-method ; +: values ( d -- l ) :values jvm-call-method ; -: ... ( lower upper -- lst ) 'com.vectron.fcl.types.Range/create/iii' jvm-call-static ; +: ... ( lower upper -- lst ) :com.vectron.fcl.types.Range/create/iii jvm-call-static ; : .. ( lower upper -- lst ) 1 ... ; : times ( q n -- ) -> n -> q n 0 do q yield loop ; -: substr ( s n n -- s ) swap rot 'substr/ii' jvm-call-method ; -: split ( str s -- s ) swap 'split/s' jvm-call-method ; -: upper ( s -- s ) 'upper' jvm-call-method ; -: lower ( s -- s ) 'lower' jvm-call-method ; -: trim ( s -- s ) 'trim' jvm-call-method ; -: index-of ( s sub -- n ) swap 'indexOf/O' jvm-call-method ; -: replace ( s old new -- s ) swap rot 'replace/ss' jvm-call-method ; -: concat ( s1 s2 -- s ) swap 'concat/O' jvm-call-method ; -: >str ( o -- s ) 'asStr' jvm-call-method ; \ No newline at end of file +: substr ( s n n -- s ) swap rot :substr/ii jvm-call-method ; +: split ( str s -- s ) swap :split/s jvm-call-method ; +: upper ( s -- s ) :upper jvm-call-method ; +: lower ( s -- s ) :lower jvm-call-method ; +: trim ( s -- s ) :trim jvm-call-method ; +: index-of ( s sub -- n ) swap :indexOf/O jvm-call-method ; +: replace ( s old new -- s ) swap rot :replace/ss jvm-call-method ; +: concat ( s1 s2 -- s ) swap :concat/O jvm-call-method ; +: >str ( o -- s ) :asStr jvm-call-method ; \ No newline at end of file diff --git a/src/main/res/raw/core.forth b/src/main/res/raw/core.forth index 538b887..d018bc3 100644 --- a/src/main/res/raw/core.forth +++ b/src/main/res/raw/core.forth @@ -59,4 +59,4 @@ var: exit.prim ( primitive exit - in case some word needs to override ) ['] lit , ['] unimplemented , ['] exec , ['] exit , ; -: is: ( xt -- ) ` 'longValue' jvm-call-method 1+ ! ; \ No newline at end of file +: is: ( xt -- ) ` :longValue jvm-call-method 1+ ! ; \ No newline at end of file diff --git a/src/main/res/raw/http.forth b/src/main/res/raw/http.forth index d51f53c..d329490 100644 --- a/src/main/res/raw/http.forth +++ b/src/main/res/raw/http.forth @@ -2,19 +2,19 @@ 'application/json' val: APPLICATION/JSON : http-get ( u -- n b ) - 'com.vectron.forthcalc.support.HttpClient/get/s' jvm-call-static -> response + :com.vectron.forthcalc.support.HttpClient/get/s jvm-call-static -> response response 'body' jvm-call-method response 'code' jvm-call-method ; : http-post ( d u -- n b ) -> url -> request - request url 'com.vectron.forthcalc.support.HttpClient/post/sM' jvm-call-static -> response + request url :com.vectron.forthcalc.support.HttpClient/post/sM jvm-call-static -> response response 'body' jvm-call-method response 'code' jvm-call-method ; : http-put ( d u -- n b ) -> url -> request - request url 'com.vectron.forthcalc.support.HttpClient/put/sM' jvm-call-static -> response + request url :com.vectron.forthcalc.support.HttpClient/put/sM jvm-call-static -> response response 'body' jvm-call-method response 'code' jvm-call-method ; diff --git a/src/main/res/raw/misc.forth b/src/main/res/raw/misc.forth index 46c8d23..8892cd9 100644 --- a/src/main/res/raw/misc.forth +++ b/src/main/res/raw/misc.forth @@ -15,5 +15,8 @@ : ms ( n -- ) 'java.lang.Thread/sleep/l' jvm-call-static ; -: tone ( hz ms -- ) swap 'com.vectron.forthcalc.support.Tone/play/di' jvm-call-static ; -: torch ( n -- ) 'com.vectron.forthcalc.support.Torch/toggle/O' jvm-call-static ; \ No newline at end of file +: tone ( hz ms -- ) swap :com.vectron.forthcalc.support.Tone/play/di jvm-call-static ; +: torch ( n -- ) :com.vectron.forthcalc.support.Torch/toggle/O jvm-call-static ; + +: draw-circle ( x y r -- ) :com.vectron.forthcalc.CanvasView/drawCircle/ddd jvm-call-static ; +: draw-rect ( left top right bottom -- ) :com.vectron.forthcalc.CanvasView/drawRect/dddd jvm-call-static ; \ No newline at end of file diff --git a/src/main/res/raw/ops.forth b/src/main/res/raw/ops.forth index f663b03..09c9830 100644 --- a/src/main/res/raw/ops.forth +++ b/src/main/res/raw/ops.forth @@ -22,24 +22,24 @@ : tip1 ( n -- n ) 15 percent ; : tip2 ( bill split -- total tip ) / dup 115 percent swap 15 percent ; ( trigonometry ) -: pi ( n -- n ) 'java.lang.Math/PI' jvm-static-var ; -: sin ( n -- n ) 'java.lang.Math/sin/d' jvm-call-static ; -: cos ( n -- n ) 'java.lang.Math/cos/d' jvm-call-static ; -: tan ( n -- n ) 'java.lang.Math/tan/d' jvm-call-static ; -: asin ( n -- n ) 'java.lang.Math/asin/d' jvm-call-static ; -: acos ( n -- n ) 'java.lang.Math/acos/d' jvm-call-static ; -: atan ( n -- n ) 'java.lang.Math/atan/d' jvm-call-static ; -: sinh ( n -- n ) 'java.lang.Math/sinh/d' jvm-call-static ; -: cosh ( n -- n ) 'java.lang.Math/cosh/d' jvm-call-static ; -: tanh ( n -- n ) 'java.lang.Math/tanh/d' jvm-call-static ; +: pi ( n -- n ) :java.lang.Math/PI jvm-static-var ; +: sin ( n -- n ) :java.lang.Math/sin/d jvm-call-static ; +: cos ( n -- n ) :java.lang.Math/cos/d jvm-call-static ; +: tan ( n -- n ) :java.lang.Math/tan/d jvm-call-static ; +: asin ( n -- n ) :java.lang.Math/asin/d jvm-call-static ; +: acos ( n -- n ) :java.lang.Math/acos/d jvm-call-static ; +: atan ( n -- n ) :java.lang.Math/atan/d jvm-call-static ; +: sinh ( n -- n ) :java.lang.Math/sinh/d jvm-call-static ; +: cosh ( n -- n ) :java.lang.Math/cosh/d jvm-call-static ; +: tanh ( n -- n ) :java.lang.Math/tanh/d jvm-call-static ; ( math ) -: e ( n -- n ) 'java.lang.Math/E' jvm-static-var ; -: round ( n -- n ) 'java.lang.Math/round/d' jvm-call-static ; -: sqrt ( n -- n ) 'java.lang.Math/sqrt/d' jvm-call-static ; -: 10log ( n -- n ) 'java.lang.Math/log10/d' jvm-call-static ; +: e ( n -- n ) :java.lang.Math/E jvm-static-var ; +: round ( n -- n ) :java.lang.Math/round/d jvm-call-static ; +: sqrt ( n -- n ) :java.lang.Math/sqrt/d jvm-call-static ; +: 10log ( n -- n ) :java.lang.Math/log10/d jvm-call-static ; : nlog ( n n -- n ) swap 10log swap 10log / ; : 2log ( n -- n ) 2.0 nlog ; -: elog ( n -- n ) 'java.lang.Math/log/d' jvm-call-static ; +: elog ( n -- n ) :java.lang.Math/log/d jvm-call-static ; : n! ( n -- n ) dup 1 <= if drop 1 @@ -47,7 +47,7 @@ round dup 1 do i * loop then ; : avg* ( .. -- n ) depth dup 1 < if drop else >r sum* r> / then ; -: rnd ( -- n ) 'com.vectron.fcl.interop.JvmInterOp/random' jvm-call-static ; +: rnd ( -- n ) :com.vectron.fcl.interop.JvmInterOp/random jvm-call-static ; : min* ( .. -- n ) depth 1- 0 do min loop ; : max* ( .. -- n ) depth 1- 0 do max loop ; ( unit conversion ) @@ -79,18 +79,18 @@ : pa>b ( n -- n ) 100000 / ; : t>pa ( n -- n ) 133.322387415 * ; : pa>t ( n -- n ) 133.322387415 / ; -: uptime ( -- millis ) 'android.os.SystemClock/elapsedRealtime' jvm-call-static ; -: >num ( s -- n ) 'com.vectron.fcl.types.Num/parse/s' jvm-call-static ; +: uptime ( -- millis ) :android.os.SystemClock/elapsedRealtime jvm-call-static ; +: >num ( s -- n ) :com.vectron.fcl.types.Num/parse/s jvm-call-static ; : year ( -- y ) - 'java.util.Calendar/YEAR' jvm-static-var - 'java.util.Calendar/getInstance' jvm-call-static - 'get/i' jvm-call-method ; + :java.util.Calendar/YEAR jvm-static-var + :java.util.Calendar/getInstance jvm-call-static + :get/i jvm-call-method ; : month ( -- y ) - 'java.util.Calendar/MONTH' jvm-static-var - 'java.util.Calendar/getInstance' jvm-call-static - 'get/i' jvm-call-method + :java.util.Calendar/MONTH jvm-static-var + :java.util.Calendar/getInstance jvm-call-static + :get/i jvm-call-method 1 + ; : day ( -- y ) - 'java.util.Calendar/DAY_OF_MONTH' jvm-static-var - 'java.util.Calendar/getInstance' jvm-call-static - 'get/i' jvm-call-method ; \ No newline at end of file + :java.util.Calendar/DAY_OF_MONTH jvm-static-var + :java.util.Calendar/getInstance jvm-call-static + :get/i jvm-call-method ; \ No newline at end of file diff --git a/src/main/res/raw/quotations.forth b/src/main/res/raw/quotations.forth index 9b89577..8528197 100644 --- a/src/main/res/raw/quotations.forth +++ b/src/main/res/raw/quotations.forth @@ -1,6 +1,6 @@ -: ( adr sfp -- c ) 'com.vectron.fcl.types.Quot/create/ii' jvm-call-static ; -: qt.adr ( q -- a ) 'address' jvm-call-method ; -: qt.sfp ( q -- a ) 'stackFrame' jvm-call-method ; +: ( adr sfp -- c ) :com.vectron.fcl.types.Quot/create/ii jvm-call-static ; +: qt.adr ( q -- a ) :address jvm-call-method ; +: qt.sfp ( q -- a ) :stackFrame jvm-call-method ; : { immediate frame.allocated @ not if ( We need to have a PSP up front for , because quotations might have its own locals ) diff --git a/src/test/java/com/vectron/fcl/FclTest.java b/src/test/java/com/vectron/fcl/FclTest.java index a93e145..b2cd7dd 100644 --- a/src/test/java/com/vectron/fcl/FclTest.java +++ b/src/test/java/com/vectron/fcl/FclTest.java @@ -391,12 +391,12 @@ public class FclTest { assertEquals(1.1752, evalPop("1 sinh").doubleValue(), 0.001); assertEquals(1.5430, evalPop("1 cosh").doubleValue(), 0.001); assertEquals(0.7616, evalPop("1 tanh").doubleValue(), 0.001); - assertEquals(1, evalPop("1.3 'intValue' jvm-call-method").doubleValue(), 0.01); + assertEquals(1, evalPop("1.3 :intValue jvm-call-method").doubleValue(), 0.01); assertFalse(evalPop("1.3 'nosuch' jvm-has-method").boolValue()); assertTrue(evalPop("1.3 'round' jvm-has-method").boolValue()); assertTrue(evalPop("[ 1 2 ] 'iterator' jvm-has-method").boolValue()); assertTrue(evalPop("[ 1 2 ] 'append/O' jvm-has-method").boolValue()); - assertFalse(evalPop("[ 1 2 ] 'append/i' jvm-has-method").boolValue()); + assertFalse(evalPop("[ 1 2 ] :append/i jvm-has-method").boolValue()); assertFalse(evalPop("[ 1 2 ] 'append/OO' jvm-has-method").boolValue()); }