Go to file
John Benediktsson 034b5a255d math.transforms.fft: using 2map-index to simplify. 2012-08-09 08:36:26 -07:00
Factor.app/Contents updated copyright 2011-05-04 17:19:30 -07:00
basis math.matrices: adding the outer product. 2012-08-08 17:02:39 -07:00
build-support build-support: make factor.sh check the git branch. 2012-07-11 12:08:29 -07:00
core sequences: adding 2each-index. 2012-08-08 20:08:08 -07:00
extra math.transforms.fft: using 2map-index to simplify. 2012-08-09 08:36:26 -07:00
misc misc: support new escapes in vim. 2012-07-26 19:24:52 -07:00
unmaintained unmaintained: removing old math.transforms.fft. 2012-08-08 20:29:02 -07:00
vm vm: make sure we zero out the end of the bignums. 2012-08-04 18:02:27 -07:00
work Add file to work dir to ensure it gets checked in 2008-09-12 04:36:32 -05:00
.gitignore GNUmakefile: use PCH so compiler goes faster 2011-11-08 08:42:46 -08:00
GNUmakefile fix build for linux (issue #480). thanks, jcollado! 2012-03-25 14:45:17 -07:00
Nmakefile vm: strip out call-counting profiler 2011-11-10 16:01:07 -08:00
README.md Adding a readme that github can understand. 2012-05-17 11:50:12 -07:00
license.txt Remove copyright notice from license 2009-04-21 16:25:04 -05:00
readme.html Update readme.html, because "Getting started" has moved 2011-03-05 21:54:12 +09:00

README.md

Factor

The Factor programming language combines powerful language features with a full-featured library. The implementation is fully compiled for performance, while still supporting interactive development. Factor applications are portable between all common platforms. Factor can deploy stand-alone applications on all platforms. Full source code for the Factor project is available under a BSD license.

Getting Started

If you are reading this README file, you either downloaded a binary package, or checked out Factor sources from the GIT repository.

To run Factor:

  • Windows: Double-click factor.exe, or run .\factor.com in a command prompt
  • Mac OS X: Double-click Factor.app or run open Factor.app in a Terminal
  • Unix: Run ./factor in a shell

A tutorial is available that can be accessed from the Factor environment:

"first-program" help

Some other simple things you can try in the listener:

"Hello, world" print

{ 4 8 15 16 23 42 } [ 2 * ] map .

1000 [1,b] sum .

4 iota  [
    "Happy Birthday " write
    2 = "dear NAME" "to You" ? print
] each

Documentation

The Factor environment includes extensive reference documentation and a short "cookbook" to help you get started. The best way to read the documentation is in the UI; press F1 in the UI listener to open the help browser tool. You can also browse the documentation online.

Command Line Usage

Factor supports a number of command line switches:

Usage: factor [Factor arguments] [script] [script arguments]

Common arguments:
    -help            print this message and exit
    -i=<image>       load Factor image file <image> (default factor.image)
    -run=<vocab>     run the MAIN: entry point of <vocab>
        -run=listener    run terminal listener
        -run=ui.tools    run Factor development UI
    -e=<code>        evaluate <code>
    -no-user-init    suppress loading of .factor-rc

Enter
    "command-line" help
from within Factor for more information.

You can also write scripts that can be run from the terminal, by putting #!/path/to/factor at the top of your scripts and making them executable.

Source Organization

The Factor source tree is organized as follows:

  • build-support/ - scripts used for compiling Factor (not present in binary packages)
  • vm/ - Factor VM source code (not present in binary packages)
  • core/ - Factor core library
  • basis/ - Factor basis library, compiler, tools
  • extra/ - more libraries and applications
  • misc/ - editor modes, icons, etc
  • unmaintained/ - unmaintained contributions, please help!

Community

Factor developers meet in the #concatenative channel on irc.freenode.net. Drop by if you want to discuss anything related to Factor or language design in general.

Have fun!