1. /*
  2. * Copyright 1999-2004 The Apache Software Foundation.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. /*
  17. * $Id: FuncGenerateId.java,v 1.10 2004/02/17 04:34:01 minchau Exp $
  18. */
  19. package com.sun.org.apache.xpath.internal.functions;
  20. import com.sun.org.apache.xml.internal.dtm.DTM;
  21. import com.sun.org.apache.xpath.internal.XPathContext;
  22. import com.sun.org.apache.xpath.internal.objects.XObject;
  23. import com.sun.org.apache.xpath.internal.objects.XString;
  24. /**
  25. * Execute the GenerateId() function.
  26. * @xsl.usage advanced
  27. */
  28. public class FuncGenerateId extends FunctionDef1Arg
  29. {
  30. /**
  31. * Execute the function. The function must return
  32. * a valid object.
  33. * @param xctxt The current execution context.
  34. * @return A valid XObject.
  35. *
  36. * @throws javax.xml.transform.TransformerException
  37. */
  38. public XObject execute(XPathContext xctxt) throws javax.xml.transform.TransformerException
  39. {
  40. int which = getArg0AsNode(xctxt);
  41. if (DTM.NULL != which)
  42. {
  43. // Note that this is a different value than in previous releases
  44. // of Xalan. It's sensitive to the exact encoding of the node
  45. // handle anyway, so fighting to maintain backward compatability
  46. // really didn't make sense; it may change again as we continue
  47. // to experiment with balancing document and node numbers within
  48. // that value.
  49. return new XString("N" + Integer.toHexString(which).toUpperCase());
  50. }
  51. else
  52. return XString.EMPTYSTRING;
  53. }
  54. }