* [Caml-list] format type @ 2002-11-03 7:08 Cezary Kaliszyk 2002-11-04 4:00 ` Ken Wakita 0 siblings, 1 reply; 5+ messages in thread From: Cezary Kaliszyk @ 2002-11-03 7:08 UTC (permalink / raw) To: caml-list [-- Attachment #1: Type: text/plain, Size: 1275 bytes --] I'm trying to write a function that takes a format and a function and applies some (got from elsewere) arguments to the function. All works ok for nonempty format. Ie: myfun "%c%s" is of type: (char -> string -> unit) -> unit IS IT POSSIBLE (with the current implementation) of the format type type checking to pass some format that would require a (unit -> unit) function? Ie: I'd like: myfun "" to be of type: (unit -> unit) -> unit If such construnction is not possible at all perheapes some new identifier "%?" should be added to fromat type type checking. This argument would take exacly one argument of type unit. My current implementation: let receive (fmt : (('a, unit, unit) format)) (f : 'a) : unit = let fmt_str = string_of_format fmt in let rec parse f i = match fmt.[i] with ... I call recursively: parse (lazified ((forced f) with applied arg)) (i + 1) ... in Obj.magic (parse (fun () -> f) 0) () ;; The only known workaround for me for now is to pass "%t" and make my function not (unit -> unit) but ('a -> unit). Writing code with changed types just for the sake of the language is very bad. And with "%t" 'a seems to be (unit -> unit). Cezary Kaliszyk -- [-- Attachment #2: Type: application/pgp-signature, Size: 254 bytes --] ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Caml-list] format type 2002-11-03 7:08 [Caml-list] format type Cezary Kaliszyk @ 2002-11-04 4:00 ` Ken Wakita 2002-11-04 7:54 ` Alessandro Baretta 0 siblings, 1 reply; 5+ messages in thread From: Ken Wakita @ 2002-11-04 4:00 UTC (permalink / raw) To: Cezary Kaliszyk, caml-list Did you try "%t"? Printf.printf "%t": (out_channel -> unit) -> unit = <fun> You could simply ignore out_channel if you are not interested. Ken Wakita > From: Cezary Kaliszyk <ck189400@zodiac.mimuw.edu.pl> > Date: Sun, 3 Nov 2002 08:08:58 +0100 > To: caml-list@inria.fr > Subject: [Caml-list] format type > > I'm trying to write a function that takes a format and a function and > applies some (got from elsewere) arguments to the function. > > All works ok for nonempty format. > Ie: > myfun "%c%s" > is of type: > (char -> string -> unit) -> unit > > IS IT POSSIBLE (with the current implementation) of the format type type > checking to pass some format that would require a (unit -> unit) > function? > > Ie: I'd like: > myfun "" > to be of type: > (unit -> unit) -> unit > > If such construnction is not possible at all perheapes some new > identifier "%?" should be added to fromat type type checking. This > argument would take exacly one argument of type unit. > > My current implementation: > > let receive (fmt : (('a, unit, unit) format)) (f : 'a) : unit = > let fmt_str = string_of_format fmt in > let rec parse f i = > match fmt.[i] with > ... > I call recursively: > parse (lazified ((forced f) with applied arg)) (i + 1) > ... > in > Obj.magic (parse (fun () -> f) 0) () > ;; > > The only known workaround for me for now is to pass "%t" and > make my function not (unit -> unit) but ('a -> unit). > > Writing code with changed types just for the sake of the language is > very bad. And with "%t" 'a seems to be (unit -> unit). > > Cezary Kaliszyk > -- > ------------------- To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/ Beginner's list: http://groups.yahoo.com/group/ocaml_beginners ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Caml-list] format type 2002-11-04 4:00 ` Ken Wakita @ 2002-11-04 7:54 ` Alessandro Baretta 2002-11-04 11:03 ` Cezary Kaliszyk 0 siblings, 1 reply; 5+ messages in thread From: Alessandro Baretta @ 2002-11-04 7:54 UTC (permalink / raw) To: Ken Wakita; +Cc: Cezary Kaliszyk, caml-list Ken Wakita wrote: > Did you try "%t"? > > Printf.printf "%t": (out_channel -> unit) -> unit = <fun> Since Cezary mentions parsing, I suppose he meant Scanf, rather than Printf. > You could simply ignore out_channel if you are not interested. > > Ken Wakita > > >>From: Cezary Kaliszyk <ck189400@zodiac.mimuw.edu.pl> >>Date: Sun, 3 Nov 2002 08:08:58 +0100 >>To: caml-list@inria.fr >>Subject: [Caml-list] format type >> >>I'm trying to write a function that takes a format and a function and >>applies some (got from elsewere) arguments to the function. >> >><snip> >> >>The only known workaround for me for now is to pass "%t" and >>make my function not (unit -> unit) but ('a -> unit). As far as I can see from the docs, "%t" is only meaningful with the Printf module. I see no mention of it in Scanf. What exactly are you trying to do anyway? Assuming you are talking about the Scanf module, I'd say you can't. Of course, if your function takes a unit input, it can very well be a perfectly polymorphic function (à la ignore) with type ('a -> unit). In which case you can force a call to such function while scanning the input buffer by passing it a range conversion with an empty range: "%[^\000-\255]". Your function would be called with an empty string as an actual parameter. Or, better yet, you can use the "%N" conversion, which passes the number of characters consumed. Just discard this value. >>Writing code with changed types just for the sake of the language is >>very bad. And with "%t" 'a seems to be (unit -> unit). It is also very bad to complain without doing any work yourself. You are probably the only one on this list wishing to call a function with no input while parsing a buffer. Nothing wrong with this, apart from stylistic considerations, but it implies two things: 1) I don't suppose Pierre ever even thought of such a conversion for Scanf, and 2) even if he did, I doubt he'd care to implement it. If you really think it is necessary, you might consider hacking it into the Scanf module and submitting the patch to the maintainers. Alex ------------------- To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/ Beginner's list: http://groups.yahoo.com/group/ocaml_beginners ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Caml-list] format type 2002-11-04 7:54 ` Alessandro Baretta @ 2002-11-04 11:03 ` Cezary Kaliszyk 2002-11-04 11:56 ` Alessandro Baretta 0 siblings, 1 reply; 5+ messages in thread From: Cezary Kaliszyk @ 2002-11-04 11:03 UTC (permalink / raw) To: Alessandro Baretta, caml-list [-- Attachment #1: Type: text/plain, Size: 3346 bytes --] On Mon, Nov 04, 2002 at 08:54:13AM +0100, Alessandro Baretta wrote: > >>From: Cezary Kaliszyk <ck189400@zodiac.mimuw.edu.pl> > >>Date: Sun, 3 Nov 2002 08:08:58 +0100 > >>To: caml-list@inria.fr > >>Subject: [Caml-list] format type > >> > >>I'm trying to write a function that takes a format and a function and > >>applies some (got from elsewere) arguments to the function. > >> > >><snip> > >> > >>The only known workaround for me for now is to pass "%t" and > >>make my function not (unit -> unit) but ('a -> unit). > > As far as I can see from the docs, "%t" is only meaningful > with the Printf module. I see no mention of it in Scanf. > What exactly are you trying to do anyway? I am trying to create a protocol for passing messages via network. Each message may be acompanied by a certain amount of parameters (of type char, int, float or string) (the parameters are dependant on the message). output/input_value aren't apropriate. (For network speed reasons, and no type extensibility) I am writing a function which adds a message to the protocol, which takes the type of arguments accompanying the message and the receiving function. It should return function used to send this message type. Eg: let two_char_sender = add_to_protocol "%c%c" two_char_receiver;; Where two_char_receiver : (char -> char -> unit) And tho_char_sender : (char -> char -> unit). And I'd like the types to be controlled. And I've written it. But it doesn't work if I want to create a message that does not take any parameters. And I suppose the builtin type format doesn't have the functionality necessary to write it. > Assuming you are talking about the Scanf module, I'd say you > can't. Of course, if your function takes a unit input, it > can very well be a perfectly polymorphic function (? la > ignore) with type ('a -> unit). In which case you can force > a call to such function while scanning the input buffer by > passing it a range conversion with an empty range: > "%[^\000-\255]". Your function would be called with an empty > string as an actual parameter. I'm not talkin about Printf nor Scanf, but about my module that uses the format type. > Or, better yet, you can use the "%N" conversion, which > passes the number of characters consumed. Just discard this > value. As above. > >>Writing code with changed types just for the sake of the language is > >>very bad. And with "%t" 'a seems to be (unit -> unit). > > It is also very bad to complain without doing any work > yourself. You are probably the only one on this list wishing > to call a function with no input while parsing a buffer. I'm not parsing a buffer... > Nothing wrong with this, apart from stylistic > considerations, but it implies two things: 1) I don't > suppose Pierre ever even thought of such a conversion for > Scanf, and 2) even if he did, I doubt he'd care to implement > it. If you really think it is necessary, you might consider > hacking it into the Scanf module and submitting the patch to > the maintainers. It's not scanf relative... > Alex The format argument is parsed by me, not by scanf or printf (as I wrote in the example code) and I don't know where in ocaml code is type checking of the arguments accompanying the format type. Cezary Kaliszyk -- [-- Attachment #2: Type: application/pgp-signature, Size: 254 bytes --] ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Caml-list] format type 2002-11-04 11:03 ` Cezary Kaliszyk @ 2002-11-04 11:56 ` Alessandro Baretta 0 siblings, 0 replies; 5+ messages in thread From: Alessandro Baretta @ 2002-11-04 11:56 UTC (permalink / raw) To: Cezary Kaliszyk, Ocaml Cezary Kaliszyk wrote: > On Mon, Nov 04, 2002 at 08:54:13AM +0100, Alessandro Baretta wrote: > >>>>The only known workaround for me for now is to pass "%t" and >>>>make my function not (unit -> unit) but ('a -> unit). >>> >>As far as I can see from the docs, "%t" is only meaningful >>with the Printf module. I see no mention of it in Scanf. >>What exactly are you trying to do anyway? > > I am trying to create a protocol for passing messages via network. > Each message may be acompanied by a certain amount of parameters > (of type char, int, float or string) (the parameters are dependant on the > message). > > output/input_value aren't apropriate. (For network speed reasons, and no > type extensibility) I'd avoid "reinventing the wheel" and stick with well known protocols. Did you try anything XML based? It's versatile and well supported. And it will spare you a lot of low level parsing routines. But of course, it is suboptimal, bitrate-wise. > I am writing a function which adds a message to the protocol, which takes the > type of arguments accompanying the message and the receiving function. > It should return function used to send this message type. Eg: > > let two_char_sender = add_to_protocol "%c%c" two_char_receiver;; > > Where two_char_receiver : (char -> char -> unit) > And tho_char_sender : (char -> char -> unit). > > And I'd like the types to be controlled. > > And I've written it. But it doesn't work if I want to create a message > that does not take any parameters. And I suppose the builtin type format > doesn't have the functionality necessary to write it. I have a feeling you are asking more of the format type than it was meant to handle. The format type is meant to be used with the Scanf and Printf modules. You can parse a message according to a format with Scanf, and by the same means you can format a message with Printf. If you are using format values in different contexts, you are probably abusing them. >>Assuming you are talking about the Scanf module, I'd say you >>can't. Of course, if your function takes a unit input, it >>can very well be a perfectly polymorphic function (? la >>ignore) with type ('a -> unit). In which case you can force >>a call to such function while scanning the input buffer by >>passing it a range conversion with an empty range: >>"%[^\000-\255]". Your function would be called with an empty >>string as an actual parameter. > > I'm not talkin about Printf nor Scanf, but about my module that uses the > format type. <snip> > The format argument is parsed by me, not by scanf or printf (as I wrote > in the example code) and I don't know where in ocaml code is type > checking of the arguments accompanying the format type. > > Cezary Kaliszyk I lost track of what you are trying to do. Sorry for this. But I have a feeling you are making things much more complex than necessary. Did you consider using yacc to parse your data stream according to your protocol specification? Format strings are sad heritage from C, and good for quick hacks where you do not want to take the time to write up a lexer and a parser, but you must realize they have some limitations. I'm sorry for not being any more helpful. Alex ------------------- To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/ Beginner's list: http://groups.yahoo.com/group/ocaml_beginners ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2002-11-05 8:55 UTC | newest] Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2002-11-03 7:08 [Caml-list] format type Cezary Kaliszyk 2002-11-04 4:00 ` Ken Wakita 2002-11-04 7:54 ` Alessandro Baretta 2002-11-04 11:03 ` Cezary Kaliszyk 2002-11-04 11:56 ` Alessandro Baretta
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox