- From: graham glass <graham@themindelectric.com>
- Date: Fri, 17 Aug 2001 19:00:03 -0400 (EDT)
- To: <soapbuilders@yahoogroups.com>, <xml-dist-app@w3.org>, <SOAP@DISCUSS.DEVELOP.COM>
- Cc: <frankd@tibco.com>
- Message-ID: <NDBBKIMDGDFEBNNMEMMNKEMNEGAA.graham@themindelectric.com>
hi there if the response is serialized just like a NULL return value, doesn't this mean that you should put xsi:nil='1' in the response? to me, returning void means "i am not designed to return anything", whereas returning nil means "i return something, and in this case, it's nil". i think that returning nil is different from returning void and should be represented differently. comments? cheers, graham -----Original Message----- From: Jacek Kopecky [mailto:jacek@idoox.com] Sent: Friday, August 17, 2001 5:08 PM To: xml-dist-app@w3.org; SOAP@DISCUSS.DEVELOP.COM; soapbuilders@yahoogroups.com Cc: frankd@tibco.com Subject: [soapbuilders] Proposal for naming the SOAP RPC return value Hello all. 8-) The RPC Task Force has considered the issues #16 [1] and #113 [2] and the feedback to the message [3] in the soapbuilders' list (summarized in [4]) and proposes the following rewording of the appropriate three bullets in SOAP version 1.2 section 7.1 [5] (editors' draft) and adding the following examples and the ending note. This proposal is based on solution #3 from the message [4] but it solves the possibility of naming conflicts. -------------------------- proposal begins - An RPC response is modeled as a struct. - The response is viewed as a single struct containing an accessor for the return value and each [out] or [in/out] parameter. The accessors for the parameters SHOULD be in the same order as in the procedure or method signature, with the return value accessor being the first. - Each parameter accessor has a name corresponding to the name of the parameter and type corresponding to the type of the parameter. The name of the return value accessor is "result" and it is namespace-qualified with the namespace identifier "http://www.w3.org/2001/06/rpc". The name of the struct is not significant. However, a convention is to name it after the procedure or method name with the string "Response" appended. An example of an envelope with a simple successful RPC response: <env:Envelope xmlns:env="http://www.w3.org/2001/06/soap-envelope"> <env:Body> <m:GetLastTradePriceResponse env:encodingStyle="http://www.w3.org/2001/06/soap-encoding" xmlns:m="http://example.org/2001/06/quotes" xmlns:r="http://www.w3.org/2001/06/rpc"> <r:result>34.1</r:result> </m:GetLastTradePriceResponse> </env:Body> </env:Envelope> An example of an envelope with a successful RPC response of a void procedure with no [in/out] or [out] parameters: <env:Envelope xmlns:env="http://www.w3.org/2001/06/soap-envelope"> <env:Body> <m:SetDateResponse env:encodingStyle="http://www.w3.org/2001/06/soap-encoding" xmlns:m="http://example.org/2001/06/clock" > </m:SetDateResponse> </env:Body> </env:Envelope> An example of an envelope with a successful RPC response of a procedure with a return value and an [out] parameter: <env:Envelope xmlns:env="http://www.w3.org/2001/06/soap-envelope"> <env:Body> <m:GetLastTradePriceResponse env:encodingStyle="http://www.w3.org/2001/06/soap-encoding" xmlns:m="http://example.org/2001/06/quotes" xmlns:r="http://www.w3.org/2001/06/rpc"> <r:result>34.1</r:result> <StockName>Foo, inc.</StockName> </m:GetLastTradePriceResponse> </env:Body> </env:Envelope> An example of an envelope with a successful RPC response of a procedure with no return value and two [out] parameters: <env:Envelope xmlns:env="http://www.w3.org/2001/06/soap-envelope"> <env:Body> <m:GetLastTradePriceResponse env:encodingStyle="http://www.w3.org/2001/06/soap-encoding" xmlns:m="http://example.org/2001/06/quotes" xmlns:r="http://www.w3.org/2001/06/rpc"> <Price>34.1</Price> <StockName>Foo, inc.</StockName> </m:GetLastTradePriceResponse> </env:Body> </env:Envelope> Please note that according to the SOAP Encoding rules [6], rule no. 9 (the very last in section 5.1), a procedure with a void return type is serialized equally to a procedure with a non-void return type but with a NULL return value. -------------------------- proposal ends This proposal directly resolves issues #16 and #113. We believe that this proposal is fully consistent with the encoding rules of SOAP section 5. The RPC Task force is likely to put this proposal forward to the XMLP Working Group for decision, and so your feedback can make a difference. Please send your replies to the list xml-dist-app@w3.org. As usual, we will take silence for assent after a reasonable time so please voice your opinion soon. Jacek Kopecky Idoox http://www.idoox.com/ [1] http://www.w3.org/2000/xp/Group/xmlp-issues.html#x16 [2] http://www.w3.org/2000/xp/Group/xmlp-issues.html#x113 [3] http://groups.yahoo.com/group/soapbuilders/message/4907 [4] http://lists.w3.org/Archives/Public/xml-dist-app/2001Aug/0131.html [5] http://www.w3.org/TR/2001/WD-soap12-20010709/#_Toc478383533 [6] http://www.w3.org/2000/xp/Group/1/06/01/soap-02-infoset.html#encrules Yahoo! Groups Sponsor ----------------------------------------------------------------- This group is a forum for builders of SOAP implementations to discuss implementation and interoperability issues. Please stay on-topic. To unsubscribe from this group, send an email to: soapbuilders-unsubscribe@yahoogroups.com Your use of Yahoo! Groups is subject to the Yahoo! Terms of Service.
Received on Monday, 20 August 2001 08:53:27 UTC