[Haskell-cafe] How to build a generic spreadsheet?
Sebastian Sylvan
sebastian.sylvan at gmail.com
Fri Feb 23 18:00:54 EST 2007
On 2/23/07, Sebastian Sylvan <sebastian.sylvan at gmail.com> wrote:
> On 2/23/07, Greg Fitzgerald <garious at gmail.com> wrote:
> > I want to write a program where a user would update a bunch of variables,
> > and everything that depends on those variables (and nothing else) are
> > recalculated. Basically, a spreadsheet, but generalized for any
> > computation. Could someone recommend an elegant way to do it or some good
> > reading material?
>
> Off the top of my head, one cool way of doing it would be to have each
> variable be a separate thread (they're lightweight, so it's okay!
> :-)), and you would have a list of input connections and output
> connections, in the form of TVars.
>
> In its resting state you would have a transaction which simply reads
> all of the input variables, and returns the new list of inputs if and
> only if either of them are changed, something like:
>
> -- not compiled, consider it pseudocode :-)
> getInputs :: (Eq a ) => [( a, TVar a)] -> STM [a]
> getInputs inp = do
> let (vals, vars) = unzip inp
> newVals <- mapM readTVar vars
> when ( newVals /= vals ) retry -- at least one input must've been changed
Bah, this should be:
when ( newVals == vals ) retry
Of course...
--
Sebastian Sylvan
+46(0)736-818655
UIN: 44640862
More information about the Haskell-Cafe
mailing list