On Thu, 04 Nov 2010 22:20:04 -0000 Charles Forsyth <fors...@terzarima.net>  
wrote:
> >But why isn't the source for mk (3929 lines w/ headers, okay 4661 with mkfil
> e and acid)
> >at least as long as all that Java in the ant distribution (213151 lines)?
> >That's a lot of catching up to do.
> >The market has clearly spoken, and it appears that more lines dominates the 
> soup.
> 
> one interesting thing about that example is that if it were done again
> for the Plan 9 environment, mk might well be even smaller, since
> some of the existing functionality isn't really used,
> or might be achieved by simpler mechanisms, or with functionality
> added instead by further composition with other programs;
> alternatively, it might be redone in a radically different way.
> 
> either way you probably wouldn't get an entire O'Reilly book out of it though.

Some random thoughts triggered by Charles'es message:

1.  The idea is to map mk to a special filesystem -- "mkfs"
    takes on a whole new meaning! One would overlay mkfs on
    a source tree.

    We are going to build foo
        mkdir foo foo/src
        <put foo's source files in foo/src/>
        cd foo

    Specify a build rule for command foo:
        echo 8c src/*.c -o .build > .rule

    Specify dependencies a b & c of foo:
        ln -s ../^(a b c) .dep/

    Build foo:
        ls .build
    This checks dependencies a b c (if they are directories,
    checks a/.build etc) and builds them.  This will need to
    be fleshed out the most... Default rules can be added
    with something like plumb....

    Install foo:
        cp .build /bin/foo

    Remove temporary files
        rm .obj/* .build

    I used symlinks to point to dependencies but may be there
    is a smarter way.

    A default .rule can be derived depending on what is in src/

    Initial .dep/ may be derived by mkfs running a dependency
    deriving program.

    Objects in .obj/ may be similarly derived.

    The utility if any is that a small set of mechanisms is
    used, coupled with a simple convention.

    This was fun little exercise (spent more time on
    writing this email) so I am sure there are lots of holes.
    Probably not worth building.  It'd be too slow.

2.  Factor out a way to track changes in any fs and trigger
    commands.  This would probably obviate the need to build a
    number of special purpose file systems.

Reply via email to